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!
Initial Setup
-
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>
-
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 status ready
.
-
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
, remove sslMode=disable
and replace domain name with localhost
-
Run the following from the project root to get the database schema in place and generate orm files
./sqlmigrate.sh
./generate.sh
Development
cd cmd/web
yarn
yarn watch # in one tab
make watchexec # in another tab
Credits
The project has been generated by gogo-cli and uses gogo library