Private as in the content is not public by default and discovery requires a human touch. Please refer to manifesto for more details.
If you want to follow the development, there is a youtube playlist with demos!
- Install go, asdf, postgres, watchexec
asdf install
npm install -g yarn
cd cmd/web; yarn install
go install github.com/rubenv/sql-migrate/...@latest
go install github.com/volatiletech/sqlboiler/v4@latest
go install github.com/volatiletech/sqlboiler/v4/drivers/sqlboiler-psql@latest
createuser pcom -W
usepcom
as a password therecreatedb --owner=pcom pcom_dev
echo 'SESSION_SALT=random' >> cmd/web/.env
echo 'SITE_ROOT=http://localhost:8000' >> cmd/web/.env
echo 'DATABASE_URL=postgres://pcom:pcom@localhost:5432/pcom_dev?sslmode=disable' >> cmd/web/.env
./sqlmigrate up
cd cmd/web; yarn watch
cd cmd/web; make watchexec
psql -U pcom pcom_dev
./sql-migrate new migration_name
Edit the file given by sql-migrate
./sql-migrate up
./generate.sh
-
change remote and push to the new repo
-
change flytoml to point to the new app pcom
-
create the app on fly
flyctl apps create pcom
-
create db, set 4gb ram
fly postgres create -n pcomdb
-
attach db to the app
flyctl postgres attach -a pcom pcomdb
-
Set secrets:
flyctl secrets set SESSION_SALT=<random string> flyctl secrets set SITE_ROOT=https://pcom.com flyctl secrets set MJ_APIKEY_PUBLIC=<public key from mailjet> flyctl secrets set MJ_APIKEY_PRIVATE=<private key from mailjet> flyctl secrets set USER_MEDIA_ENDPOINT=<endpoint> flyctl secrets set USER_MEDIA_BUCKET=<bucket> flyctl secrets set USER_MEDIA_KEY=<key> flyctl secrets set USER_MEDIA_REGION=<region> flyctl secrets set USER_MEDIA_SECRET=<secret> flyctl secrets set SENDER_ADDRESS=<address> flyctl secrets set ADMIN_ADDRESS=<address> flyctl secrets set STATIC_CDN=<address> # in case you want to put static resources behind the cdn flyctl secrets set USER_MEDIA_CDN=<address> # in case you want to put user images behind the cdn
-
Before
-
Do first deploy
fly deploy
, make sure you can reach the app via .fly.dev -
Create a cert for your custom domain
fly certs add pcom.com
-
After it screams at you, add required A and AAAA records
-
You might need to run
fly certs check pcom.com
a couple of times,fly certs list
should show your domain with the statusready
. -
You should be able to reach your app via custom domain at this point
-
Got to mailjet and add new domain
-
Add sender email address there
-
Add required txt record to validate domain
-
Add required txt records to add DKIM and SPF settings
-
Add postgres db env var to
cmd/web/.env
via./env.pl > cmd/web/.env
, removesslmode=disable
and replace domain name with localhost -
Run the following from the project root to get the database schema in place
Tab 1:
fly proxy 5433:5432 -a pcomdb
Tab 2
./run.sh
./sqlmigrate.sh up
cd cmd/web
yarn
yarn watch # in one tab
make watchexec # in another tab
-
App instance is running in a wrong dc:
fly scale count 0 fly scale count 1 --region ams
The project has been generated by gogo-cli and uses gogo library