@dinosaur
- setup ButtCloud.org and various linked services (GitHub, Docker Cloud, Twitter, Gmail)
- started
buttcloud/meta
repo to store any meta information (including these dev diary entries) - started `buttcloud/butt-landing to be a simple public landing page for pub servers
- working towards a multi-service pub using Docker Compose, i realized
ssb-viewer
andgit-ssb-web
were non-trivial to install in typical environments - the plan is to use this as a simple secondary service to get a multi-service pub working, then later can focus on the other secondary services
- working towards a multi-service pub using Docker Compose, i realized
@dinosaur
- made Docker image for
buttcloud/butt-landing
- extracted minimal peer server and client code from
scuttlebot
intobuttcloud/butt-peer
- added custom logging plugin which uses
pino
, to try and have a consistent logging system across services - made two Docker images, one for
butt-peer-server
and one forbutt-peer-client
- i combined them so i could use the client code in the server healthcheck
- added custom logging plugin which uses
@dinosaur
- started
buttcloud/butt
asdocker-compose.yml
of peer server, landing server, and nginx proxy - update
butt-peer-server
andbutt-peer-client
to not usenode
user, easier to start with defaultroot
user- why? i ran into an error with volume data permissions, would rather punt to later
- UPDATE: changed this back, got it working with
node
user, needed to create volume inDockerfile
then mount external volume at same path
- update
butt-landing
to auto re-connect to sbot, so it doesn't error when sbot is not yet up- why? this is the recommended way to have docker services depend on each other,
docker-compose.yml
v3 not longer supportsdepends_on: condition: healthy
- why? this is the recommended way to have docker services depend on each other,
- setup Docker Hub automated builds to build tagged images based on git version tags
- match tag name:
/^v[0-9.]+$/
, docker tag is same
- match tag name:
@dinosaur
- got minimal
buttcloud/butt
working! - iron out some kinks...
@dinosaur
- switch to focus on Docker Swarm
- change to use Traefik instead of Nginx Proxy
@dinosaur
- keep trying to get the Swarm setup to work, grr...!
@dinosaur
- take a break from Swarm for meow
- first pass at scaffolding
buttcloud/buttcloud-provider
- have a working web server, browser app, and worker, but not yet complete to start feature development
@dinosaur
- more progress toward provider app scaffolding
@dinosaur
provider app has landed!
- integrate
redux-bundler
- add emojis
- found seamless background image to tile on landing page
- start onboarding workflow
- implement start step of onboarding
- validate forms on client
- validate service calls on server, show errors in form
- show success or failure messages as snackbar
- after form submission (which creates the user)
- generate json web token that identifies user
- send welcome email to next page of onboarding with token
- emails are sent by queuing a delayed job to a worker (
node-resque
) - setup decent email templates with
mjml
- emails are sent by queuing a delayed job to a worker (
- store user in local storage in case they refresh page before progressing
- show help text on page
- allow user to resend onboarding email
@ahdinosaur
back to the infra side, during breakfast this morning i figured out why buttcloud/butt
was failing!
i had a hunch that it had to do with the address that sbot
was binding to. i configured host
as example_butt-peer-server
, since that's how the Docker service was to be identified within the Docker network. but still, the health checker inside the service couldn't find it. i changed this to 0.0.0.0
and it works!
did the same for the landing service. now the stack comes online, you can curl -H "Host: example.butt.nz" localhost
and get the output from the landing page associated with example.butt.nz
(proxied by traefik
).
next i added a custom plugin to butt-peer-server
that allows you to configure externalHost
, in case it differs from host
. this means we can bind to host
(like 0.0.0.0
) but advertise our public multiserver address as example.butt.nz
(like for invites).
then, on a whim from @mischa, i went back to buttcloud-provider
to swap redux-form
for final-form
, easy as.
made up some issues, want to step back to think about the next steps from here.
also made the ButtCloud logo!
@ahdinosaur
@ahdinosaur
- start to separate pub and hub stacks in swarm setup: https://github.com/buttcloud/butt/commit/426deb39b9880100fe82ba5960da3d43fe74c452
- worked on deploy for web app demo: peachcloud/peachhub-provider#9
- browser code is up at: https://demo.buttcloud.org (using netlify for free)
- api server is up at https://buttcloud-demo.herokuapp.com/ (using heroku for free)
@ahdinosaur
- discovered and documented bug with
tinyify
: browserify/tinyify#10 - add standard style setup to web app: peachcloud/peachhub-provider#10
@ahdinosaur
- demo is now live! demo.buttcloud.org 🐑
- renamed sub-projects to either
buttpub*
orbutthub*
, to standardize language: #7 - setup continuous integration for
butthub-provider
: peachcloud/peachhub-provider#11 - setup ButtCloud account with OVH
- apply for their startup support program (for maybe $1k cloud credit): https://www.ovh.com/world/dlp/
- play with
docker-machine
to create a local swarm across many machines- get the swarm scripts from
buttpub
working, now across multiple virtual machines
- get the swarm scripts from
@ahdinosaur
started docker-up
: opinionated glue to manage our Docker swarm
@ahdinosaur
continued with docker-up
- ended up making a fun little continuable (
cb => {}
) based async flow control library in./util/async.js
, maybe will publish asflowstep
- realized that the Docker API doesn't handle the
docker stack *
functionality, that's implemented in the Docker CLI- i learned that a "stack" is really a set of networks, volumes, and services each with a label "com.docker.stack.namespace" to reference the stack name
- have to decide whether
- a) to continue using the Docker API and implement that functionality ourselves
- b) to move to using the Docker CLI
- for now, will go with option a) !
- reading the Docker CLI code, it's not scary or complex
- this way we have more low-level control of the Docker Swarm
- this way we can focus on exactly what we need for ButtCloud
more docker-up
, getting close to v1
! 🎈
- add executable cli
- clean up the api
- fractal stacks!
- top-level config is a stack, with stacks all the way down
- each stack has services, networks, volumes, AND NESTED STACKS
- each stack may have a name to namespace associated services
- pretty configurable logging
next up (notes to self):
- better cli (take in resource type)
- use explicit docker version in api requests
- add "com.docker.stack.namespace" label to be legit docker stack
gotta work with @Mischa on another contract meow, then Art~Hack!
@ahdinosaur
- reviewed @austin's sweet pull request to
butthub-provider
: peachcloud/peachhub-provider#13 - completed the "next up" features for
docker-up
in the previous entry
@ahdinosaur
- published
docker-up/util/async.js
ascallstep
, wrote up a splash of documentation 🚶♂️
@ahdinosaur
docker-up
: add basic integration and unit tests usingava
, clean up log and config wrappers using composable callsteps: https://github.com/buttcloud/docker-up/commit/29655b561b781331fc4b3a2455ea15e7360bb111- cc @ike
butthub-provider
: look into adding integration tests usingcodecept
- not ButtCloud, but got sponsored by TickTack to improve
ssb-pub
: ahdinosaur/ssb-pub#10
@ahdinosaur
butthub-provider
: end-to-end acceptance testing with codecept: peachcloud/peachhub-provider#14
@ahdinosaur
butthub-provider
: battled some end-to-end testing dragons 🐉 : peachcloud/peachhub-provider#14- integrated the entire web app stack (api server, asset server, worker, and mailer) in the codecept process
- at the end of the tests, the process was hanging, who was still running?
- with some help from
why-is-node-running
and heaps of reading dependency internals, started the journey to find every remaining handle, gotta catch 'em all! 🐎
@ahdinosaur
butthub-provider
: won the end-to-end test war: peachcloud/peachhub-provider#14- cleaned up every last handle, so the test process cleanly exists meow
- which means continuous integration now includes end-to-end server + browser tests! 🙌
- travis gives us a running postgres and redis database, how nice
butthub-provider
: finish a boring dependency upgrade: peachcloud/peachhub-provider#12docker-up
: ahdinosaur/gyne#4- the plan was to add update for services, but along the way i realized many things were broken:
- each resource uses a different identifier!
down
should check if resource exists beforeremove
up
returns output of inspect
- generic resource creator now takes:
name
hasUpdate
: true forservice
, false otherwiseidField
: network usesId, volume only has
Name, service uses
ID`
- the plan was to add update for services, but along the way i realized many things were broken:
docker-up
: add continuous integration tests: ahdinosaur/gyne#5 ✅- travis even gives us running docker to play with!
@ahdinosaur
- am starting to finally understand some advanced fp (functional programming) concepts like monads
docker-up
: investigate usingsanctuary
docker-up
: port code to useramda
,folktale
,folktale-validations
, andfluture
docker-up
: re-architect how everything works- given next config, translate into docker api config
- fetch all current docker api config
- diff docker api current and next configs
- show diff to sysadmin
- if acceptable, translate the diff into docker api commands and run those
- rename
docker-up
togyne
- rename ButtCloud to PeachCloud
- get example swarm working across 3 virtual machines using
docker-machine
andgyne