A simple reddit-style voting app.
- Download and install Go and Postgres
- Create a
DB_CONN
environment variable for pg. See below for details - Run the app!
go run main.go
DB_CONN
connection string to Postgres database- Local example:
export DB_CONN="password=mysecretpassword host=localhost port=5432 sslmode=disable"
- Local example:
POSTGRES_ADDR
address to pg db. Ignore when linking to pg containerPOSTGRES_PORT
port for pg db. Ignore when linking to pg containerPOSTGRES_DATABASE
name of pg databasePOSTGRES_USERNAME
username for pg dbPOSTGRES_PASSWORD
password for pg dbAUTH_SECRET
a random string of characters used to encrypt cookiesGIN_MODE
{'debug', 'release'} release mode doesn't show route:function mappings
- Voting mode, as seen above
- Admin Panel for exporting CSV reports
- Presentation mode for showing a question fullscreen (click on the TV icon)
- Read-only mode for viewing data outside of a DoubleDutch app (note that the Auto-Refresh toggle can be turned on to keep getting a stream of new data)
- Moderation mode for deleting questions
Build the go api container from the root directory
GOOS=linux GOARCH=amd64 go build && docker build -t dd-vote .
Build the Postgres database container from the /pg
directory
docker build -t dd-vote-pg .
To access the admin tools, we need to create our SuperAdmin. First create a user in the users table
INSERT INTO users (email, password) VALUES ('superadmin@doubledutch.me', 'supercomplexpassword');
Using the id for that user, give the user SuperAdmin permission
INSERT INTO permissions (user_id, role) VALUES (1, 0);
- Add ModifiedSince header to avoid getting all questions every time
- Use a websocket or push-based data to provide instant updates to clients
- Hash passwords
- Improve process for db migrations and seeding