forked from toolshed/docs.coopcloud.tech
		
	Compare commits
	
		
			131 Commits
		
	
	
		
			r-012-b-06
			...
			backupbot-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 65ac99ca25 | |||
| 3f1f57f4ba | |||
| fa23766aa8 | |||
| 661366e2c0 | |||
| 0cc43b15d3 | |||
| b726ce8837 | |||
| 8e40a141d9 | |||
| 3455295f9f | |||
| 4c778a154f | |||
| 4278b1779c | |||
| dde7d2aeb3 | |||
| a29593b573 | |||
| fd6c41ee91 | |||
| df70cfcaa0 | |||
| 623a0be0b0 | |||
| a1d9cf8940 | |||
| b9c7ebd500 | |||
| ac6cf7b5dc | |||
| ee39912c88 | |||
| 655400877a | |||
| 650735a40b | |||
| 0ddd0bff66 | |||
| c3cc6fc1c6 | |||
| 8c85a7928d | |||
| d4c39ab074 | |||
| 1172da919c | |||
| 3ae0ac10b3 | |||
| 4960b301e0 | |||
| 306639f733 | |||
| 568c27dc9a | |||
| ab5ac034e9 | |||
| 1b3c788722 | |||
| 24b996acb9 | |||
| b926d3d975 | |||
| 75583c32e2 | |||
| 05f12b7555 | |||
| 99a31ac3b7 | |||
| 43211efebd | |||
| 01e65bef1b | |||
| 2221b23144 | |||
| 0187af4e8d | |||
| b5afd99f66 | |||
| 39ab74b9b8 | |||
| f919f0c10b | |||
| d683a7e33e | |||
| 7f50082972 | |||
| 31a502cf6f | |||
| 304143d151 | |||
| 1c09d09eeb | |||
| 72e1c448df | |||
| 259ece5a9f | |||
| dec3335a87 | |||
| 7be11d48a1 | |||
| 02002fcde5 | |||
| 0478269b31 | |||
| d0fd7403d1 | |||
| 861eddaa71 | |||
| 139147d23d | |||
| 2f21edf2b9 | |||
| f5cfe1f92b | |||
| f6798cbe2d | |||
| 47b07ff342 | |||
| 1363a20979 | |||
| cfa79f6581 | |||
| 57bb79d716 | |||
| 89581f5f87 | |||
| 588ee4e9d9 | |||
| 833660e47c | |||
| e21939fcb8 | |||
| 42ee2e15f9 | |||
| cd1d5d7490 | |||
| 5ffed62021 | |||
| 485339ee7f | |||
| 9ca3b9ae5f | |||
| 954dab7e30 | |||
| 3daba2da3a | |||
| b67dab1299 | |||
| 34185e36ce | |||
| a6b7b6fb86 | |||
| fe0525f4ee | |||
| e01863c161 | |||
| 2568322fbd | |||
| 1eda82c490 | |||
| b05b577695 | |||
| 05a949d5cd | |||
| eb21b7844c | |||
| e986eb48da | |||
| 7523339384 | |||
| eb24873db3 | |||
| b38d2328c9 | |||
| 5ae08f5b45 | |||
| dc84e990af | |||
| 5106fe390f | |||
| 460eb75e55 | |||
| d595a74099 | |||
| 3f2ab68ada | |||
| 17bce5a4f3 | |||
| bb47eb0200 | |||
| b45862394d | |||
| 98c58512ba | |||
| c82437da8f | |||
| fa75f96f43 | |||
| b3b46136e6 | |||
| 675779f598 | |||
| 686f57e94a | |||
| 76bfe2d057 | |||
| 42c2bcb46b | |||
| 94ae9f265d | |||
| 5f460553f8 | |||
| ea6e6be5c3 | |||
| b904b08b5c | |||
| 052c951157 | |||
| f064693668 | |||
| d7cdf1b1a9 | |||
| 6b8ebb6459 | |||
| ffed6b426a | |||
| 7a2145a0d3 | |||
| 8b74678c7d | |||
| 58fefdd1d3 | |||
| 7f0c8abceb | |||
| 87b7d403fb | |||
| db63234da9 | |||
| d903d14da5 | |||
| 4cab1901eb | |||
| 2d8f72d179 | |||
| 781817b03a | |||
| dab4bfa0b5 | |||
| 14e9da8d82 | |||
| f2f335d4da | |||
| 054eebd019 | |||
| a253294196 | 
							
								
								
									
										293
									
								
								Backupbottwo.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										293
									
								
								Backupbottwo.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,293 @@ | ||||
| --- | ||||
| title: Backupbot-two | ||||
| --- | ||||
|  | ||||
| # For Operators | ||||
|  | ||||
| ## Deployment | ||||
|  | ||||
| **1. Create a new app:** | ||||
|  | ||||
| ``` | ||||
| abra app new backup-bot-two | ||||
| ``` | ||||
|  | ||||
| **2. Configure :** | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| Run the cronjob that creates a backup, including the push notifications and docker logging: abra app cmd <backupbot_name> app run_cron | ||||
|  | ||||
| ### Create a backup of all apps: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup create | ||||
| ``` | ||||
|  | ||||
|     The apps to backup up need to be deployed | ||||
|  | ||||
| ### Create an individual backup: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup --host <target_app_name> create | ||||
| ``` | ||||
|  | ||||
| ### Create a backup to a local repository: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup create -r /backups/restic | ||||
| ``` | ||||
|  | ||||
| It is recommended to shutdown/undeploy an app before restoring the data | ||||
|  | ||||
| ### Restore the latest snapshot of all including apps: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup restore | ||||
| ``` | ||||
|  | ||||
| ### Restore a specific snapshot of an individual app: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup --host <target_app_name> restore --snapshot <snapshot_id> | ||||
| ``` | ||||
|  | ||||
| ### Show all snapshots: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup snapshots | ||||
| ``` | ||||
|  | ||||
| ### Show all snapshots containing a specific app: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup --host <target_app_name> snapshots | ||||
| ``` | ||||
|  | ||||
| ### Show all files inside the latest snapshot (can be very verbose): | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup ls | ||||
| ``` | ||||
|  | ||||
| ### Show specific files inside a selected snapshot: | ||||
|  | ||||
| ``` | ||||
| abra app run <backupbot_name> app -- backup ls --snapshot <snapshot_id> --path /var/lib/docker/volumes/ | ||||
| ``` | ||||
|  | ||||
| ### Download files from a snapshot: | ||||
|  | ||||
| filename=$(abra app run <backupbot_name> app -- backup download --snapshot <snapshot_id> --path <absolute_path>) | ||||
| abra app cp <backupbot_name> app:$filename . | ||||
|  | ||||
| # For Maintainers | ||||
|  | ||||
| TODO: | ||||
| pre/post hooks | ||||
| - Simple command | ||||
| - accessing secrets | ||||
| - more complex scripts mounted in the container | ||||
|  | ||||
| From the perspective of the recipe maintainer, backup/restore is just more | ||||
| `deploy: ...` labels. Tools can read these labels and then perform the | ||||
| backup/restore logic. | ||||
|  | ||||
| ## Tools | ||||
|  | ||||
| Two of the current "blessed" options are | ||||
| [`backup-bot-two`](https://git.coopcloud.tech/coop-cloud/backup-bot-two) & | ||||
| [`abra`](https://git.coopcloud.tech/coop-cloud/abra). | ||||
|  | ||||
| ### `backup-bot-two` | ||||
|  | ||||
| `backup-bot-two` is a recipe which gets deployed on the server, it can perform automatic backups. | ||||
| Please see the [`README.md`](https://git.coopcloud.tech/coop-cloud/backup-bot-two#backupbot-ii) for the full docs. | ||||
|  | ||||
| ### `abra` | ||||
|  | ||||
| `abra` will read labels and store backups in `~/.abra/backups/...` . | ||||
|  | ||||
| ## Backup | ||||
|  | ||||
| Unless otherwise stated all labels should be added to the main service (which should be named `app`). | ||||
|  | ||||
| 1. Enable backups for the recipe: | ||||
| You need to enable backups for the recipe by adding the following label: | ||||
| ``` | ||||
| backupbot.backup=true | ||||
| ``` | ||||
|  | ||||
| 2. Decide wich volumes should be backed up: | ||||
| By default all volumes will be backed up. To disable a certain volume you can add the following label: | ||||
| ``` | ||||
| backupbot.backup.volumes.{volume_name}=false | ||||
| ``` | ||||
|  | ||||
| 3. Decide which path should be backed up on each volume | ||||
| By default all files get backed up for a volume. To only include certain paths you can add the following label: | ||||
| ``` | ||||
| backupbot.backup.volumes.{volume_name}.path=/mypath1/foo,/mypath2/bar | ||||
| ``` | ||||
|  | ||||
| Note: You cann include multiple paths by providing a comma seperated list | ||||
| Note: All paths are specified relativ to the volume root | ||||
|  | ||||
| 4. Run commands before the backup | ||||
| For certain services like a database it is not reccomend to just backup files, because the backup might end up in a corrupted state. Instead it is reccomended to make a database dump. You can run arbitrary commands in any container before the files are backed up. | ||||
| To do this add the following label to the service on which you want the command being run: | ||||
| ``` | ||||
| backupbot.backup.pre-hook=mysqldump -u root -pghost ghost --tab /var/lib/foo | ||||
| ``` | ||||
|  | ||||
| 5. Run commands after the backup | ||||
| Sometimes you want to clean up after the backup. You can run arbitrary commands in any container after the files were backed up. | ||||
| To do this add the following label to the service on which you want the command being run: | ||||
| ``` | ||||
| backupbot.backup.post-hook=rm -rf /var/lib/mysql-files/* | ||||
| ``` | ||||
|  | ||||
| ### Testing the backup | ||||
| That's it your recipe can now be backed up. But how can you make sure your configuration is correct? | ||||
|  | ||||
| TODO: | ||||
|  | ||||
| ### Examples | ||||
|  | ||||
| ## Restore | ||||
|  | ||||
| Restore, in this context means, "moving a compressed archive back to the | ||||
| container backup paths". So, if you set | ||||
| `backupbot.backup.path=/var/lib/foo,/var/lib/bar` and you have a backed up | ||||
| archive, tooling will unzip files in the archive back to those paths. | ||||
|  | ||||
| In the case of restoring database tables, you can use the `pre-hook` & | ||||
| `post-hook` commands to run the insertion logic. | ||||
|  | ||||
| ## Configuration Examples | ||||
|  | ||||
| ### Mysql | ||||
|  | ||||
| ### Postgres | ||||
|  | ||||
| # Specification | ||||
|  | ||||
| TODO: | ||||
|     - should the post hook be executed when the backup/restore fails? | ||||
|  | ||||
| ## Summary | ||||
|  | ||||
| Creating automated backups of docker swarm services is an often needed task. This specification describes how backups can be configured via [service labels](https://docs.docker.com/compose/compose-file/compose-file-v3/#labels-1) in a standardised way. | ||||
|  | ||||
| ## Requirements | ||||
|  | ||||
| The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this specification are to be interpreted as described in [RFC-2119]. | ||||
|  | ||||
| When backing up a docker stack you MUST first check if the `backupbot.backup`. It MUST be set to true, for the backup to happen. | ||||
|  | ||||
| ## Backup | ||||
|  | ||||
| To enable backups for a docker stack, the `backupbot.backup=true` label MUST be on any of its services. It SHOULD be declared on the first service. | ||||
| A `backupbot.backup.pre-hook` MAY be set on a service. When set the command MUST be executed inside the running container of the service before backup up files. | ||||
| By default all volumes MUST be backed up. A volume MAY be excluded from backing up when `backupbot.backup.volumes.{volume_name}=false` is set, where `{volume_name}` is the name of the volume. | ||||
| By default all files MUST be backed up on a volume. `backupbot.backup.volumes.{volume_name}.path` MAY be set to limit the paths for that volume. The value MUST be a valid path relative to the volume root. It MAY contain multiple paths which get seperated by a comma. | ||||
| A `backupbot.backup.post-hook` MAY be set on a service. When set the command MUST be executed inside the running container of the service after backing up all files. | ||||
| A backup implementation SHOULD provide the backup of one or multiple stacks in a `.tar.gz` format. | ||||
|  | ||||
| ## Restore | ||||
|  | ||||
| A `backupbot.restore.pre-hook` MAY be set on a service. When set the command MUST be executed inside the running container of the service before restoring backup files. | ||||
| By default all files MUST be restored into their volume. A volume or path MAY be excluded from restoring. | ||||
| A `backupbot.restore.post-hook` MAY be set on a service. When set the command MUST be executed inside the running container of the service after restoring backup files. | ||||
|  | ||||
| ## Labels | ||||
|  | ||||
| ### `backupbot.backup` | ||||
|  | ||||
| **Type:** boolean | ||||
| **Default:** false | ||||
| **Description:** | ||||
| Enables backupbot for this compose stack. The labe should be added to the main service of the compose stack. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.backup: true | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.backup.volumes.{volume_name}` | ||||
|  | ||||
| **Type:** boolean | ||||
| **Default:** true | ||||
| **Description:** When set to false the volume is excluded from backups. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.backup.volumes.{volume_name}: false | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.backup.volumes.{volume_name}.path` | ||||
|  | ||||
| **Type:** string | ||||
| **Default:** "" | ||||
| **Description:** | ||||
| A comma seperated list of paths. When one or more paths are set, it only backups up those on the given volume instead of the whole volume. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.backup.volumes.{volume_name}.path: '/var/lib/mariadb/dump.sql.gz' | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.backup.pre-hook` | ||||
|  | ||||
| **Type:** string | ||||
| **Default:** "" | ||||
| **Description:** | ||||
| A command, that gets executed before the files are backed up. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.backup.pre-hook: 'mysqldump -u root -p"$(cat /run/secrets/db_root_password)" -f /volume_path/dump.db' | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.backup.post-hook` | ||||
|  | ||||
| **Type:** string | ||||
| **Default:** "" | ||||
| **Description:** | ||||
| A command, that gets executed after the files are backuped. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.backup.post-hook: "rm -rf /volume_path/dump.db" | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.restore.pre-hook` | ||||
|  | ||||
| **Type:** string | ||||
| **Default:** "" | ||||
| **Description:** | ||||
| A command, that gets executed before the files are restored. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.restore.pre-hook: "lock db" | ||||
| ``` | ||||
|  | ||||
| ### `backupbot.restore.post-hook` | ||||
|  | ||||
| **Type:** string | ||||
| **Default:** "" | ||||
| **Description:** | ||||
| A command, that gets executed after the files are restored. | ||||
|  | ||||
| **Example:** | ||||
|  | ||||
| ``` | ||||
| backupbot.restore.post-hook: "sqldump dump.sql && unlock db && rm dump.sql" | ||||
| ``` | ||||
| @ -1,4 +1,4 @@ | ||||
| FROM squidfunk/mkdocs-material:9.2.8 | ||||
| FROM squidfunk/mkdocs-material:9.5.7 | ||||
|  | ||||
| EXPOSE 8000 | ||||
|  | ||||
| @ -8,6 +8,4 @@ WORKDIR /docs | ||||
|  | ||||
| RUN apk add --no-cache curl | ||||
|  | ||||
| RUN pip install \ | ||||
|   mkdocs-awesome-pages-plugin==2.9.1 \ | ||||
|   mkdocs-material-extensions==1.1.1 | ||||
| RUN pip install -r requirements.txt | ||||
|  | ||||
							
								
								
									
										16
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								README.md
									
									
									
									
									
								
							| @ -1,13 +1,21 @@ | ||||
| # docs.coopcloud.tech | ||||
| # docs.coopcloud.tech :open_book: | ||||
|  | ||||
| [](https://build.coopcloud.tech/coop-cloud/docs.coopcloud.tech) | ||||
|  | ||||
| > https://docs.coopcloud.tech | ||||
| View: [docs.coopcloud.tech](https://docs.coopcloud.tech) | ||||
|  | ||||
| ## hacking | ||||
|  | ||||
| ## Developing / Hacking | ||||
|  | ||||
| Co-op Cloud's docs are created with the [mkdocs-material](https://squidfunk.github.io/mkdocs-material/) framework. | ||||
|  | ||||
| To install dependencies and serve local build of site, simply run: | ||||
|  | ||||
| ``` | ||||
| make | ||||
| ``` | ||||
|  | ||||
| Theme docs are [here](https://squidfunk.github.io/mkdocs-material/setup/changing-the-colors/) and [there](https://squidfunk.github.io/mkdocs-material/reference/). | ||||
| Useful docs for theming and content reference: | ||||
|  | ||||
| - [Changing the colors](https://squidfunk.github.io/mkdocs-material/setup/changing-the-colors/) | ||||
| - [Reference](https://squidfunk.github.io/mkdocs-material/reference/) | ||||
|  | ||||
| @ -10,56 +10,165 @@ Install [direnv](https://direnv.net), run `cp .envrc.sample .envrc`, then run `d | ||||
|  | ||||
| Install [Go >= 1.16](https://golang.org/doc/install) and then: | ||||
|  | ||||
| - `make build` to build | ||||
| - `make build` to build. If this fails, run `go mod tidy`. | ||||
| - `./abra` to run commands | ||||
| - `make test` will run tests | ||||
| - `make install` will install it to `$GOPATH/bin` | ||||
| - `make install-abra` will install abra to `$GOPATH/bin` | ||||
| - `make install-kadabra` will install kadabra to `$GOPATH/bin` | ||||
| - `go get <package>` and `go mod tidy` to add a new dependency | ||||
|  | ||||
| Our [Drone CI configuration](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/.drone.yml) runs a number of checks on each pushed commit. See the [Makefile](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/Makefile) for more handy targets. | ||||
|  | ||||
| Please use the [conventional commit format](https://www.conventionalcommits.org/en/v1.0.0/) for your commits so we can automate our change log. | ||||
|  | ||||
| ## Unit tests | ||||
|  | ||||
| ### Run tests | ||||
|  | ||||
| Run the entire suite. | ||||
|  | ||||
| ``` | ||||
| make test | ||||
| ``` | ||||
|  | ||||
| ### Filter tests | ||||
|  | ||||
| Run a specific test. | ||||
|  | ||||
| ``` | ||||
| go test ./pkg/recipe -v -run TestGetVersionLabelLocalDoesNotUseTimeoutLabel | ||||
| ``` | ||||
|  | ||||
| ## Integration tests | ||||
|  | ||||
| ### Install dependencies | ||||
|  | ||||
| We use [`bats`](https://bats-core.readthedocs.io/en/stable/), you can install | ||||
| the required dependencies with the following. You also need a working | ||||
| installation of Docker and Go. | ||||
| installation of Docker and Go (not covered in this section). | ||||
|  | ||||
| ``` | ||||
| apt install bats bats-file bats-assert bats-support jq make git | ||||
| apt install bats-file bats-assert bats-support jq make git | ||||
| ``` | ||||
|  | ||||
| Then you can run the integration test suite with the following: | ||||
| Unfortunately, the latest `bats` version in Debian stable does not have the | ||||
| "filter tests by tags" feature, which is very handy for running a subset of the | ||||
| tests. For this, we need to install `bats` from source. It's easy. | ||||
|  | ||||
| ``` | ||||
| apt purge -y bats | ||||
| git clone https://github.com/bats-core/bats-core.git | ||||
| cd bats-core | ||||
| sudo ./install.sh /usr/local | ||||
| ``` | ||||
|  | ||||
| ### Setup Test Server | ||||
|  | ||||
| For many tests an actual server is needed, where apps can be deployed. You can | ||||
| either use a local one or a remote test server. | ||||
|  | ||||
| #### With remote test server | ||||
|  | ||||
| ``` | ||||
| export ABRA_TEST_DOMAIN="test.example.com" | ||||
| export ABRA_DIR="$HOME/.abra_test" | ||||
| bats tests/integration | ||||
| ``` | ||||
|  | ||||
| `ABRA_TEST_DOMAIN` should also have a DNS A record for `*.test.example.com` | ||||
| which points to the same server so that the test suite can deploy apps freely. | ||||
| It's advised that you re-use the same server and therefore the same Traefik | ||||
| deployment for running your integration tests. Then you'll have more stable | ||||
| results. | ||||
| deployment for running your integration tests. The test suite does not deploy | ||||
| Traefik for you. Then you'll have more stable results. | ||||
|  | ||||
| If you're hacking on the tests, you can speed things up with the following. | ||||
| You probably don't want to run the entire test suite though, it takes a while. | ||||
| Try the following for starters. | ||||
|  | ||||
| #### With local swarm | ||||
|  | ||||
| When running the test suite localy you need a running docker swarm setup: | ||||
|  | ||||
| ``` | ||||
| export ABRA_SKIP_TEARDOWN=1 | ||||
| docker swarm init | ||||
| docker network create -d overlay proxy | ||||
| ``` | ||||
|  | ||||
| This will avoid nuking `$ABRA_DIR` for each test which avoids the costly `git | ||||
| clone` of the catalogue on each test run. For the actual CI testing, we | ||||
| probably want this clean slate on each test to avoid confusion. | ||||
| To use the local swarm set the foloowing env var: | ||||
|  | ||||
| ``` | ||||
| export TEST_SERVER=default | ||||
| export ABRA_DIR="$HOME/.abra_test" | ||||
| ``` | ||||
|  | ||||
| ### Run tests | ||||
|  | ||||
| Now you can run the whole test suite: | ||||
|  | ||||
| ``` | ||||
| bats -Tp tests/integration | ||||
| ``` | ||||
|  | ||||
| Or you can run a single test file: | ||||
|  | ||||
| ``` | ||||
| bats -Tp tests/integration/autocomplete.bats | ||||
| ``` | ||||
|  | ||||
| ### Tagging tests | ||||
|  | ||||
| When a test actually deploys something to a server, we tag it with the following: | ||||
|  | ||||
| ``` | ||||
| # bats test_tags=slow | ||||
| @test "..." { | ||||
|   ... | ||||
| } | ||||
| ``` | ||||
|  | ||||
| Then we can use [filters](#filter-tests) (see below) to pick out a subset of | ||||
| tests which do/do not use a live server. Feel free to come up with your own | ||||
| tags. See the `bats-core` | ||||
| [docs](https://bats-core.readthedocs.io/en/stable/writing-tests.html#tagging-tests) | ||||
| for more. | ||||
|  | ||||
| ### Filter tests | ||||
|  | ||||
| You can run a specific file. | ||||
|  | ||||
| ``` | ||||
| bats -Tp tests/integration/autocomplete.bats | ||||
| ``` | ||||
|  | ||||
| For example, if you want to check that all `abra recipe ...` tests remain working. | ||||
|  | ||||
| ``` | ||||
| bats -Tp tests/integration/recipe_* | ||||
| ``` | ||||
|  | ||||
| You can filter on test names to run specific kinds of tests. | ||||
|  | ||||
| ``` | ||||
| bats tests/integration --filter "validate app argument" | ||||
| bats -Tp tests/integration --filter "validate app argument" | ||||
| ``` | ||||
|  | ||||
| You can filter on tags. | ||||
|  | ||||
| ``` | ||||
| bats -Tp tests/integration --filter-tags "\!slow" # only fast tests | ||||
| bats -Tp tests/integration --filter-tags "slow"   # only slow tests | ||||
| ``` | ||||
|  | ||||
| You can also only run the previously failed tests. | ||||
|  | ||||
| ``` | ||||
| bats -TP tests/integration --filter-status failed | ||||
| ``` | ||||
|  | ||||
| ### Debug tests | ||||
|  | ||||
| If you're running into issues and want to debug stuff, you can pass `-x` to | ||||
| `bats` to trace all commands run in the test. You can add `echo '...' >&3` | ||||
| debug statements to your test to output stuff also. | ||||
|  | ||||
| ## Using the `abra` public API | ||||
|  | ||||
| Warning, there is currently no stability promise for the `abra` public API! Most of the internals are exposed in order to allow a free hand for developers to try build stuff. If people start to build things then we can start the discussion on what is useful to have open/closed and keep stable etc. Please let us know if you depend on the APIs! | ||||
| @ -131,6 +240,7 @@ For developers, while using this `-beta` format, the `y` part is the "major" ver | ||||
|  | ||||
| ### Making a new release | ||||
|  | ||||
| - Run the [integration test suite](#integration-tests) and the unit tests (`make test`) (takes a while!) | ||||
| - Change `ABRA_VERSION` in [`scripts/installer/installer`](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/scripts/installer/installer) to match the new tag (use [semver](https://semver.org)) | ||||
| - Commit that change (e.g. `git commit -m 'chore: publish next tag x.y.z-beta'`) | ||||
| - Make a new tag (e.g. `git tag -a x.y.z-beta`) | ||||
| @ -143,7 +253,7 @@ For developers, while using this `-beta` format, the `y` part is the "major" ver | ||||
|  | ||||
| ### `godotenv` | ||||
|  | ||||
| We maintain a fork of [godotenv](https://github.com/Autonomic-Cooperative/godotenv) because we need inline comment parsing for environment files. You can upgrade the version here by running `go get github.com/Autonomic-Cooperative/godotenv@<commit>` where `<commit>` is the latest commit you want to pin to. At time of writing, `go get github.com/Autonomic-Cooperative/godotenv@b031ea1211e7fd297af4c7747ffb562ebe00cd33` is the command you want to run to maintain the above functionality. | ||||
| We maintain a fork of [godotenv](https://git.coopcloud.tech/coop-cloud/godotenv) because we need inline comment parsing for environment files. You can upgrade the version here by running `go get git.coopcloud.tech/coop-cloud/godotenv@0<COMMID>` where `<commit>` is the latest commit you want to pin to. See [`abra#391`](https://git.coopcloud.tech/coop-cloud/abra/pulls/391) for more. | ||||
|  | ||||
| ### `docker/client` | ||||
|  | ||||
|  | ||||
| @ -2,10 +2,6 @@ | ||||
| title: Install | ||||
| --- | ||||
|  | ||||
| !!! warning | ||||
|  | ||||
|     We've seen reports that `abra` under [WSL](https://learn.microsoft.com/en-us/windows/wsl/about) doesn't work due to an underlying bug in Docker context handling. See [`coop-cloud/organising#406`](https://git.coopcloud.tech/coop-cloud/organising/issues/406) and [`docker/for-win#13180`](https://github.com/docker/for-win/issues/13180) for more. | ||||
|  | ||||
| ## Stable release | ||||
|  | ||||
| ``` | ||||
| @ -18,6 +14,28 @@ curl https://install.abra.coopcloud.tech | bash | ||||
| curl https://install.abra.coopcloud.tech | bash -s -- --rc | ||||
| ``` | ||||
|  | ||||
| ## Manual verification  | ||||
|  | ||||
| You can download the `abra` binary yourself from the [releases | ||||
| page](https://git.coopcloud.tech/coop-cloud/abra/releases) along with the | ||||
| `checksums.txt` file and verify it's integrity with the following command. | ||||
|  | ||||
| ```bash | ||||
| sha256sum -c checksums.txt --ignore-missing | ||||
| ``` | ||||
|  | ||||
| If you see a line starting with `abra_...` which matches the filename you downloaded and it ends with `OK` - you're good to go! | ||||
|  | ||||
| ``` | ||||
| abra_X.X.X-beta_linux_x86_64: OK | ||||
| ``` | ||||
|  | ||||
| Otherwise, you downloaded a corrupted file and you should re-download it. | ||||
|  | ||||
| ## Compile from source | ||||
|  | ||||
| Follow the guide [here](https://docs.coopcloud.tech/abra/hack/) | ||||
|  | ||||
| ## Installer script source | ||||
|  | ||||
| You can view that [here](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/scripts/installer/installer). | ||||
|  | ||||
| @ -4,8 +4,16 @@ title: Quick start | ||||
|  | ||||
| There are a few ways to get started, here are some entrypoints listed below: | ||||
|  | ||||
| - If you're new around here and you'd like to learn how to deploy apps with `abra`, then a good place to start is the [new operators tutorial](/operators/tutorial). If you've already deployed some apps and would like to learn how to maintain them, then the [operators handbook](/operators/handbook) is the right place. | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - If you're installing `abra` so you can do recipe packaging, take a look at the [new maintainers tutorial](/maintainers/tutorial). `abra` can help you check the quality of the recipe you've packaged and help you publish it to the public recipe catalogue. Then others can deploy your configuration :rocket: | ||||
| - __Operators__ | ||||
|  | ||||
|     If you're new around here and you'd like to learn how to deploy apps with `abra`, then a good place to start is the [new operators tutorial](/operators/tutorial). If you've already deployed some apps and would like to learn how to maintain them, then the [operators handbook](/operators/handbook) is the right place. | ||||
|  | ||||
| - __Maintainers__ | ||||
|  | ||||
|     If you're installing `abra` so you can do recipe packaging, take a look at the [new maintainers tutorial](/maintainers/tutorial). `abra` can help you check the quality of the recipe you've packaged and help you publish it to the public recipe catalogue. Then others can deploy your configuration :rocket: | ||||
|  | ||||
| </div> | ||||
|  | ||||
| If you run into any issues, please see the [troubleshooting page](/abra/trouble) :bomb: | ||||
|  | ||||
							
								
								
									
										107
									
								
								docs/abra/recipes.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								docs/abra/recipes.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,107 @@ | ||||
| --- | ||||
| title: Recipes | ||||
| --- | ||||
|  | ||||
| _Recipes_ are what we call the configuration file used to deploy apps with our `abra` CLI tool. A longer explanation is in the [glossary](/glossary#recipe). Our _Catalogue_ is a web interface for exploring the currently available configurations, therefore which apps can be deployed.  | ||||
|  | ||||
| ### Catalogue | ||||
|  | ||||
| Our catalogue is located at [recipes.coopcloud.tech](https://recipes.coopcloud.tech/) and regularly updated :cooking: | ||||
|  | ||||
| [Browse Our Recipes](https://recipes.coopcloud.tech/){ .md-button .md-button--primary } | ||||
|  | ||||
| The catalogue is a helpful place to easily understand the status of app recipes and the link to the source-code of the recipe. To understand the various scores on recipes, read further. | ||||
|  | ||||
| ## Status, Features, Score | ||||
|  | ||||
| Each recipe `README.md` has a "metadata" section, to help communicate the overall status of the recipe, and which features are supported. Here's an example, from [the Wordpress recipe](https://git.coopcloud.tech/coop-cloud/wordpress/): | ||||
|  | ||||
| ``` | ||||
| <!-- metadata --> | ||||
|  | ||||
| * **Category**: Apps | ||||
| * **Status**: 3, stable | ||||
| * **Image**: [`wordpress`](https://hub.docker.com/_/wordpress), 4, upstream | ||||
| * **Healthcheck**: Yes | ||||
| * **Backups**: Yes | ||||
| * **Email**: 3 | ||||
| * **Tests**: 2 | ||||
| * **SSO**: No | ||||
|  | ||||
| <!-- endmetadata --> | ||||
| ``` | ||||
|  | ||||
| Currently, recipe maintainers need to update the scores in this section manually. The specific meanings of the scores are: | ||||
|  | ||||
| ### Status (overall score) | ||||
|  | ||||
| | Score | Description                          | | ||||
| | ----- | ------------------------------------ | | ||||
| | [5](#){ .md-score .md-score-5 } | Everything in 4 + Single-Sign-On | | ||||
| | [4](#){ .md-score .md-score-4 } | Upstream image, backups, email, healthcheck, integration testing | | ||||
| | [3](#){ .md-score .md-score-3 } | Upstream image, missing 1-2 items from 4 | | ||||
| | [2](#){ .md-score .md-score-2 } | Missing 3-4 items from 4 or no upstream image | | ||||
| | [1](#){ .md-score .md-score-1 } | Alpha | | ||||
|  | ||||
| ### Image | ||||
|  | ||||
| | Score | Description                          | | ||||
| | ----- | ------------------------------------ | | ||||
| | 4 | Official upstream image | | ||||
| | 3 | Semi-official / actively-maintained image | | ||||
| | 2 | 3rd-party image | | ||||
| | 1 | Our own custom image | | ||||
|  | ||||
| ### Email | ||||
|  | ||||
| | Score | Description                          | | ||||
| | ----- | ------------------------------------ | | ||||
| | 3 | Automatic (using environment variables) | | ||||
| | 2 | Mostly automatic | | ||||
| | 1 | Manual | | ||||
| | 0 | None | | ||||
| | N/A | App doesn't send email | | ||||
|  | ||||
| ### CI (Continuous Integration) | ||||
|  | ||||
| | Score | Description                          | | ||||
| | ----- | ------------------------------------ | | ||||
| | 3 | As 2, plus healthcheck | | ||||
| | 2 | Auto secrets + networks | | ||||
| | 1 | Basic deployment using `stack-ssh-deploy`, manual secrets + networks | | ||||
| | 0 | None | | ||||
|  | ||||
| ### Single-Sign-On | ||||
|  | ||||
| | Score | Description                          | | ||||
| | ----- | ------------------------------------ | | ||||
| | 3 | Automatic (using environment variables) | | ||||
| | 2 | Mostly automatic | | ||||
| | 1 | Manual | | ||||
| | 0 | None | | ||||
| | N/A | App doesn't support SSO | | ||||
|  | ||||
| ## Requesting Recipes | ||||
|  | ||||
| If you'd like to see a new recipe packaged there are two options for you. First is to contribte one as a _Maintainer_  | ||||
| The second option is to make a request on the [`recipes-wishlist`](https://git.coopcloud.tech/coop-cloud/recipes-wishlist) repository issue tracker. | ||||
|  | ||||
| If no one is around to help, you can always take a run at it yourself, go to the [Maintainers](/maintainers/) section to help you on your way. | ||||
|  | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __Contribute Recipes__ | ||||
|  | ||||
|     Do you not see the recipe for the app you use or make? We especially love recipe maintainers :heart: | ||||
|  | ||||
|     [Create a Recipe](/maintainers/){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Request A Recipe__ | ||||
|  | ||||
|     Don't feel up to the task? Open an issue in the `recipes-wishlist` repository | ||||
|  | ||||
|     [Request Recipe](https://git.coopcloud.tech/coop-cloud/recipes-wishlist){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| We've seen nice things happen when the requesters are also willing to take an active role in testing the new recipe. Teaming up with whoever volunteers to help do the packaging is best. | ||||
| @ -20,6 +20,12 @@ Host example.com | ||||
|   IdentityFile ~/.ssh/example@somewhere | ||||
| ``` | ||||
|  | ||||
| and your IdentityFile should be added to the authentication agent: | ||||
|  | ||||
| ``` | ||||
| ssh-add ~/.ssh/example@somewhere | ||||
| ``` | ||||
|  | ||||
| ## "abra server ls" shows the wrong details? | ||||
|  | ||||
| You can use `abra server rm` to remove the incorrect details. Make sure to take a backup of your `~/.abra/servers/<domain>` first. You can then try to re-create by using `abra server add ...` again. | ||||
|  | ||||
| @ -22,14 +22,20 @@ abra upgrade --rc | ||||
|  | ||||
| ### `0.7.x-beta` -> `0.8.x-beta` | ||||
|  | ||||
| > Currently still a release candidate! Please help test 😌 | ||||
|  | ||||
| - We now have an `--offline` flag instead of relying on internal logic to try | ||||
|   to decide when offline/online works best. It's up to you! A lot of `abra` | ||||
|   operations require network access, so it is not really truly "offline". The | ||||
|   logic prefers local filesystem access when this flag is passed. E.g. if there | ||||
|   is a local copy of the catalogue, then don't `git pull`. | ||||
|  | ||||
| - There is more `--chaos`! There is more consistent flag handling for manually | ||||
|   overriding when to update the local recipe or leave it alone when hacking on | ||||
|   changes. | ||||
|  | ||||
| - Secrets are now only generated by reading the recipe config, not the env | ||||
|   vars. This should hopefully not affect you. If you're seeing weird behaviour, | ||||
|   please see [`#464`](https://git.coopcloud.tech/coop-cloud/organising/issues/464). | ||||
|  | ||||
| - There is a new linting rule for catching invalid tags in recipe versions. | ||||
|   This is an seemingly unavoidable issue that requires some maintenance work. | ||||
|   If you run into the error, here's some | ||||
| @ -40,6 +46,11 @@ abra upgrade --rc | ||||
|   `cd ~/.abra/catalogue && git checkout .` to get `abra` to stop complaining about | ||||
|   unstaged changes. | ||||
|  | ||||
| - `abra record ...` & `abra server new` have been removed! Following a usage poll, these | ||||
|   features were not being relied on. They were also alpha prototypes which we | ||||
|   feel can be reconsidered once other more critical parts of Abra are more | ||||
|   stable. | ||||
|  | ||||
| ### `0.6.x-beta` -> `0.7.x-beta` | ||||
|  | ||||
| - **ALERTA, ALERTA**, security related issue: all `$domain.env` env vars are now exposed to the deployment via the `app` service container. Each `FOO=BAR` is exported within the context of the container. If you have any privately committed secrets in your `.env` files, please migrate them to the `secrets: ...` configuration in the recipe. This change was made to facilitate tooling which can support auto-upgrading of apps in a deployment. | ||||
|  | ||||
| @ -1,7 +1,10 @@ | ||||
| --- | ||||
| title: FAQ | ||||
| title: Bylaws | ||||
| --- | ||||
| 
 | ||||
| The following are the bylaws which the _Co-op Cloud: Federation_ has decided | ||||
| democratically and layout our governance processes :classical_building: :fist: | ||||
| 
 | ||||
| ## What is the Co-op Cloud Federation? | ||||
| 
 | ||||
| > We're still working things out, here's what know so far! | ||||
| @ -6,9 +6,36 @@ Welcome to the Co-op Cloud Federation documentation! | ||||
|  | ||||
| This is the public facing page where we publish all things federation in the open. | ||||
|  | ||||
| - [FAQ](/federation/faq): Take a look if you're curious about the Federation is about 🤓 | ||||
| - [Resolutions](/federation/resolutions): All draft, in-progress and passed resolutions ✊ | ||||
| - [Finance](/federation/finance): How we deal with money 💸 | ||||
| - [Membership](/federation/membership): See who's already joined in 🥰 | ||||
| - [Minutes](/federation/minutes): All minutes from our meetings 📒 | ||||
| - [Digital tools](/federation/tools): Tools we use to organise online 🔌 | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __Resolutions__ | ||||
|  | ||||
|     Our drafts, in-progress and passed resolutions ✊ | ||||
|  | ||||
|     [Read More](/federation/resolutions){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Finance__ | ||||
|  | ||||
|     Learn about how we deal with money and how to get paid 💸 | ||||
|  | ||||
|     [Read More](/federation/finance){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Membership__ | ||||
|  | ||||
|     See who's already joined us 🥰 | ||||
|  | ||||
|     [Our Members](/federation/membership){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Minutes__ | ||||
|  | ||||
|     All minutes from our meetings 📒 | ||||
|  | ||||
|     [Past Meetings](/federation/minutes){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Digital Tools__ | ||||
|  | ||||
|     Tools we use to organise online 🔌 | ||||
|  | ||||
|     [Tools We Use](/federation/tools){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| @ -15,3 +15,4 @@ title: Membership | ||||
| | ruangrupa | - | - | Henry `@babystepper:matrix.org` | | ||||
| | UTAW | - | - | `@javielico:matrix.org` | | ||||
| | ??? | - | - | `@mirsal:1312.media` | | ||||
| | Klasse & Methode | - | - | `@p4u1_f4u1:matrix.org` | | ||||
|  | ||||
							
								
								
									
										82
									
								
								docs/federation/minutes/2023-05-03.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								docs/federation/minutes/2023-05-03.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,82 @@ | ||||
| --- | ||||
| title: 2023-05-03 | ||||
| --- | ||||
|  | ||||
| # Co-op Cloud Federation Meeting 2023-05-03 | ||||
|  | ||||
| Notes from last meeting: https://docs.coopcloud.tech/federation/minutes/2022-03-03/ | ||||
|  | ||||
| Metadata | ||||
|  | ||||
| * Time / date: May 3 @ 1500-1630 UTC https://time.is/0330PM_3_May_2023_in_UTC | ||||
| * Location: https://meet.jit.si/coop-cloud-federation-meeting | ||||
| * Attending: Autonomic (trav, 3wc), Local-IT (yksflip, Moritz), decentral1se (🐺 /free agent) | ||||
| * Facilitation: Calix | ||||
| * Notes: trav | ||||
|  | ||||
| Agenda | ||||
|  | ||||
| _(All times UTC, as sharp as possible)_ | ||||
|  | ||||
| * Introductions / checkins (5m) | ||||
|   * How you're doing | ||||
|   * Which organisation are you attached to? (if applicable) | ||||
|   * a fun (or terrible) Co-op Cloud experience you've had recently | ||||
|     * Packaging Rustdesk server 🥳 | ||||
|     * Realising backupbot labels didn't work 😱 | ||||
|     * Upgrading with missing backups 😅 Deployed 18-20 apps at once, wrote a script 🤯 | ||||
|     * Immovable force meets unstoppable bug, no deployments ⛔ | ||||
| * Decisions - what passed, any new proposals? (10m) https://docs.coopcloud.tech/federation/resolutions/ | ||||
|   * we review the existing resolutions | ||||
|   * Resolution 005 / process  | ||||
|     * trav: sticking to 2 week deadline for proposals? | ||||
|     * d1: there was a meeting where we talked about it being a small decision but then it became medium. G | ||||
|     * trav: ahh mixups happen, I don't feel strongly ultimately. | ||||
|     * yksflip: maybe check-in with cas but call it passed (?). 2 weeks is a good amount of time but can understand you'd want to move on more quickly. | ||||
|     * 3wc: 2 week default good. Very async coordination, espeically if folks have to go back to their co-op to check-in. Fewer people will see it the shorter it is. | ||||
|     * Moritz: how to know size of the decision? | ||||
|       * 3wc: smallest decision size that seems fair.  | ||||
|       * d1 in chat: 'who is affected by the decision' | ||||
|     * d1: 2 weeks seems good, simpler to stick to that going forward. Super duper emergency budget | ||||
|   * What does the second point of Resolution 004 mean | ||||
|     * 3wc: first Budget is a budget for these meetings.  | ||||
|   * Superduperemergencybudget | ||||
|     * Trav: For emergency work? | ||||
|     * d1: yes, but the part that's missing is to know what is super duper emergency. There are a lot of P1 bugs but they're not all show-stoppers. There are a number of things that need to be fixed quicker than 2 weeks | ||||
|     * 3wc: emergency firefighter. Up to whoever proposes the budget as to what the structure would look like. | ||||
| * abra fixes Budget / proposal thingy | ||||
|   * https://pad.autonomic.zone/Fp6Zi846TNqATulYFqcJqw | ||||
|   * d1: if this was proposed today, wait 2 weeks and then I'd fix them. Or standing budget? | ||||
|   * trav: suggestion is wait 2 weeks then implement? or agree standing budget? | ||||
|   * 3wc: yes, but also passing emergency budget would also take 2 weeks, no? | ||||
|   * d1: propose this and do 10 hours or do a "10 hours" proposal and fit this into it. Not show-stopping bugs but 2 weeks wont kill us. | ||||
|   * trav: might be worth passing 10h/mo, something/month for fixes, maintenance / emergency. non-binding poll / gitea voting → what to work on. vs having to package bug work together. less bureaucracy. | ||||
|   * d1: can re-work decision 6 into a maintenance budget. Curious how we want to bubble-up the bugs. Board? Label? | ||||
|   * yksflip: standing maintenance makes sense to me.  | ||||
| * federation bootstrap funds 🤑 | ||||
|   * trav: there's money leftover from donor | ||||
|   * d1: 6k in the pot, get the work funded. | ||||
|   * trav: buffer tho? | ||||
|   * Moritz: I'm paid from Local IT. How to decide who is doing which fixes? | ||||
|   * d1: people tend to do stuff they want to see done. Some way to share would be good....? | ||||
|   * 3wc: tags. Tickets labeled as part of maintenance budget. If assigned to someone, they are point person. Plot twist: time expectation. Someone takes something on and it's unclear when that's going to happen. Claim things for up to a week or 2 but don't claim it until you're ready to work on it. | ||||
|   * ** we love it ** | ||||
|   * **d1 to roll into maintenance proposal** | ||||
| * doop coop dues waiver https://pad.autonomic.zone/xgd7lLxzT520O4KRXuWyuQ# | ||||
|   * 3wc: yusef posted, side project, low income, would like to participate. 1 year waiver of dues. They seem enthusiastic and helpful person to be around. | ||||
|   *  trav: can decide now? " Individuals/groups wanting to join Co-op Cloud who aren’t able to make a financial contribution may request a solidarity free membership." doesn't say how to make decision | ||||
|   *  d1: medium seems fine | ||||
|   *  Moritz: instead of dues perhaps doing some abra fixes | ||||
|   *  Philip: agree on waiving fees for them. How to define time to spend on project. Alternative membership fee, donate time? | ||||
|   *  3wc: part of inspiration for fedration is Co-op Cycle: too complicated to track work and money. Have to track money so wont track work. Like the simplicity. Wage is €20/h, in-kind work contribution would be 30 minutes of work contribution per month.  | ||||
|   *  d1: reflecting on unions etc, pay dues and also contribute. Something to think about. | ||||
|  | ||||
| * Checkouts | ||||
|  | ||||
| didn't get to: | ||||
| * Breakout groups? | ||||
|   * Software tools | ||||
|   * Finances | ||||
|   * Outreach | ||||
|   * Development | ||||
| * next meeting? Is it monthly? I forget. | ||||
							
								
								
									
										79
									
								
								docs/federation/minutes/2024-02-01.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								docs/federation/minutes/2024-02-01.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,79 @@ | ||||
| --- | ||||
| title: 2024-02-01 | ||||
| --- | ||||
|  | ||||
| # Co-op Cloud Federation meeting 2024-02 | ||||
|  | ||||
| Date poll: https://crab.fit/coop-cloud-federation-february-2024-576238 | ||||
|  | ||||
| Previous notes: https://docs.coopcloud.tech/federation/minutes/2023-05-03/ | ||||
|  | ||||
| ## Agenda | ||||
|  | ||||
| - check-in | ||||
|   - name | ||||
|   - pronouns | ||||
|   - organisation | ||||
|   - how we're feeling | ||||
|   - anything we want to get out of today | ||||
| - emotional support for abra bugs | ||||
| - missed october 2023 membership dues review ([R002](https://docs.coopcloud.tech/federation/resolutions/passed/002/)), what now? | ||||
| - [backup restore / testing update](https://pad.riseup.net/p/UEC2JUPGb6tmRCZ7RX9X-keep) | ||||
| - collective abra next release planning | ||||
| - ✅ bonfire co-op network hosting proposal | ||||
| - ✅ next meeting | ||||
| - check-out | ||||
|   - how was the meeting? | ||||
|   - recommendations for next meeting | ||||
|   - what are you doing for the rest of the day? | ||||
|  | ||||
| ## Notes | ||||
|  | ||||
| Here: Calix, Mayel, Moritz, p4u1, d1 | ||||
| Facilitating: Calix | ||||
| Notes: Mayel | ||||
|  | ||||
| - local-it has test framework with Playwright to test deployment, eg. testing customised configs or modified recipes - not testing app functionality but rather customisation or integrations between apps, eg. SSO - so can check if an upgrade would break - would be nice to integrate the tests into the recipes to they can be linked to the version (ie. update recipe when updating a recipe/app) - in future want to automate into CI (eg drone runner) to auto-update recipes and check for failure - will publish test framework next week on coopcloud gitea - run them first on test deployments to check in advance if update works but also then run in prod to make sure thing runs correctly in prod (eg. if email notifs are working in each app) - this does require extra thinking (eg. deleting data created by tests) | ||||
|     - sounds really cool! going to look into playwright. could be handy for federated apps | ||||
|     - sounds like something that orgs like nlnet may fund, maybe can merge these into a proposal to fund this + the more boring coopcloud maintainance | ||||
|  | ||||
| ## organise meeting schedule | ||||
| - would be nice to find a regular rythm for federation meetings instead of needing date polls | ||||
| - same time? once a month? | ||||
| - in social.coop TWG they've been getting 2-3 people showing up, maybe just because haven't polled for new regular meeting time for a while | ||||
| - need someone with capacity to organise (coordination role), whether it's setting up poll or prompting people to join, to get us all in the room | ||||
| - will someone set up a date poll for march? or re. meeting frequency / how we decide  -> Moritz volunteered | ||||
|  | ||||
| ### bonfire co-op network hosting proposal | ||||
| - https://bonfirenetworks.org/hosting/ | ||||
|  | ||||
| what co-op cloud combined with servers.coop would do. idea comes from a need from bonfire team, people who are looking to adopt bonfire, individuals, small collectives, large organisations who might not have tech savvy to set up and maintain own hosting / instances, would rather have as a service .. but we decided early on we didn't want to offer hosting ourselves. and we don't want to host any flagship instances (because centralisation). calls for easy way for people to set up and maintain instances. not just infrastructure, labour, savvy, mnaintenance and support, backups. like community-supported agriculture, "community-supported software" = community gets a say in software, have a say in prioritising. large part of funds goes into infra and labour of maintaining / operating. split among participants. | ||||
|  | ||||
| last funding from NLNet, included milestone. prototype instance setup wizard and management dashboard. €3k to start. small tech component, organisational and infra. | ||||
|  | ||||
| what would m like from CC at this stage? | ||||
|  | ||||
| participants help with prototyping | ||||
| start small - organisational & infrastructural side is  | ||||
| communities already want instances! | ||||
| not setup wizard required, just send us an email etc. do it by hand | ||||
|  | ||||
| budget avail now | ||||
|  | ||||
| one group focused on open science, one on digital radios, online communities around music. possibilities of them finding grants, other sources of income. donations from community members? assume = there would be funds eventually. might have to be a bit of upfront freebie service, especially as we're prototyping. closed beta as we're trying things out. | ||||
|  | ||||
| ### missed october 2023 membership dues | ||||
| - we were going to review who's paying, how's the amount. we didn't! what to do. | ||||
|  | ||||
| ### backup restore / testing update | ||||
| - after meeting about backup bot in januarry, need to document what already exists and what has been decided, there was a proposal - will followup async | ||||
|  | ||||
| ### collective abra next release planning | ||||
| - some are in process of improving backup/restore (still WIP) and some bugs were also found, so now it's difficult to make a release - many are self-building abra so not an issue for them, but would be good to make a plan first (next time) to avoid large refactors that block releases | ||||
| - also plan around how long features take to implement, maybe during federation meetings | ||||
| - proposal for next abra release: some bugs are fixed in main branch but release blocked by backup stuff, so could create a new branch from point where backup stuff was not merged and create release from there, so don't need to worry about incomplete backup stuff, should be pretty easy, that way can finish backup with no rush | ||||
| - if we do so, need 1 or 2 people to run integration tests + fix any bugs that appear and then do the release - ideally 1 person who has released before (d1 volunteers) + another who hasn't (p4u1 volunteers) | ||||
|  | ||||
|  | ||||
| ## check out | ||||
| - in future need to talk about how long meeting can go before starting + agenda prioritisation | ||||
| @ -1,3 +0,0 @@ | ||||
| --- | ||||
| title: Drafts | ||||
| --- | ||||
							
								
								
									
										75
									
								
								docs/federation/resolutions/in-progress/013.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								docs/federation/resolutions/in-progress/013.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,75 @@ | ||||
| --- | ||||
| title: "Resolution 013"  | ||||
| --- | ||||
|  | ||||
| !!! note | ||||
|  | ||||
|       This resolution has been amended! The main change was to remove automatic | ||||
|       git synchronisation; please see [the file | ||||
|       history](https://git.coopcloud.tech/coop-cloud/docs.coopcloud.tech/commits/branch/main/docs/federation/resolutions/in-progress/013.md) for a full run-down. | ||||
|  | ||||
| - Budget 007: Operator sync | ||||
| - Date: 2024-01-?? | ||||
| - Deadline: 2024-01-XX | ||||
| - Size: Large | ||||
|  | ||||
| ### Summary | ||||
|  | ||||
| As highlighted in several tickets (e.g. [`#434`](https://git.coopcloud.tech/coop-cloud/organising/issues/434), [`#467`](https://git.coopcloud.tech/coop-cloud/organising/issues/467)), several operators working together on the same server routinely run into deployment instability. This is due to the fact that we do not store the deployment version of the apps. | ||||
|  | ||||
| With this proposal, we would like to address the synchronisation of app deployment versions. This is being called "Operator sync". What follows is the design proposal which has already received feedback from operators on [this pad](https://pad.riseup.net/p/IebZQkpe3OOpYyVT8f1j-keep). | ||||
|  | ||||
| ### Details (Budget 007) | ||||
|  | ||||
| We add support a config file (`$ABRA_DIR/config.yml`) which has these defaults: | ||||
|  | ||||
| We also add a `abra config` command which has the following shape: | ||||
|  | ||||
| ``` | ||||
| 🌻 ./abra config -h | ||||
| NAME: | ||||
|    abra config - Manage system-wide Abra configuration | ||||
|  | ||||
| USAGE: | ||||
|    abra config command [command options] | ||||
|  | ||||
| COMMANDS: | ||||
|    generate, g  Generate default configuration | ||||
|  | ||||
| OPTIONS: | ||||
|    --help, -h  show help | ||||
| ``` | ||||
|  | ||||
| If there is no `$ABRA_DIR/config.yml` or `sync: false`, nothing changes. When `sync: true`, *only* the `abra app deploy / upgrade / rollback` commands have new behaviour. | ||||
|  | ||||
| There is also a new command `abra app sync <domain>` which triggers a synchronisation. | ||||
|  | ||||
| When `abra app deploy/upgrade/rollback/sync` is run, here's what we do: | ||||
|  | ||||
| * Read the `OPERATOR_SYNC_VERSION` env var as the version to deploy / upgrade from / rollback from | ||||
|     * upgrade: if deployed version does not match `OPERATOR_SYNC_VERSION`, warn before overview | ||||
|     * rollback: same as above! | ||||
|  | ||||
| * Run the deployment | ||||
|     * if successful, record a new `OPERATOR_SYNC_VERSION` | ||||
|     * if unsuccessful, do not record a `OPERATOR_SYNC_VERSION` and ask operator to resolve | ||||
|  | ||||
| If `--chaos` is passed, we use the short commit hash instead of the version label. | ||||
|  | ||||
| Here's an example of the `OPERATOR_SYNC_VERSION` env var: | ||||
|  | ||||
| ``` | ||||
| # in ~/.abra/servers/example.com/matrix.example.com.env | ||||
| TYPE=matrix-synapse | ||||
| OPERATOR_SYNC_VERSION=4.0.0+v1.93.0 # managed by Abra | ||||
| ``` | ||||
|  | ||||
| Operator documentation will also be provided. | ||||
|  | ||||
| **Budget amount**: 200 EUR (10 hrs * 20 EUR/hr) | ||||
|  | ||||
| **Who will implement this**: (someone?) | ||||
|  | ||||
| **When will the money be spent**: Before mid-February 2024 | ||||
|  | ||||
| **What is the money for**: Implementing the first steps of operator sync. | ||||
							
								
								
									
										48
									
								
								docs/federation/resolutions/in-progress/016.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								docs/federation/resolutions/in-progress/016.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | ||||
| --- | ||||
| title: "Resolution 016" | ||||
| --- | ||||
|  | ||||
| - Topic: Budget 008: Backup-bot-two Documentation and Specification | ||||
| - Date: 27-01-2024 | ||||
| - Deadline: 10th February 2024 | ||||
| - Size: Large | ||||
|  | ||||
| ### Summary | ||||
|  | ||||
| > (Co-written by p4u1 & d1) | ||||
|  | ||||
| The new backup-bot-two implementation is nearly finished. The only remaining step is to implement restore functionality. In a recently meeting with Moritz, p4u1 & d1, we discussed how to design and implement it. The mintues are [here](https://pad.riseup.net/p/UEC2JUPGb6tmRCZ7RX9X-keep). | ||||
|  | ||||
| In this meeting, we realised that there is already a lot of implicit, undocumented knowledge about how backup-bot-two & abra work together. How the restore interface will work is more or less designed in the meeting, with general agreement. | ||||
|  | ||||
| In order to communicate that design, we feel we need to have clear documentation and a specification on how things work. This will make sure we have consensus before commiting more budget to implementing the final step. It will also help operators pick up, use & extend backup-bot-two in the future. | ||||
|  | ||||
| In this resolution, we want to propose to write the initial documentation and specification for the new [backup-bot-two](https://git.coopcloud.tech/coop-cloud/backup-bot-two/). | ||||
|  | ||||
| The existing documentation for the old backupbot should be taken into account wherever possible. | ||||
|  | ||||
| ### Details (Budget 008) | ||||
|  | ||||
| Documentation should be for: | ||||
|  | ||||
| - Operators using the backup-bot-two | ||||
| - Maintainers of recipes | ||||
|  | ||||
| The documentation should have: | ||||
|  | ||||
| - Examples on using Abra with the backupbot | ||||
| - Examples of recipe configurations | ||||
| - Detailed explanation of features and their limitations | ||||
|  | ||||
| The Specification should include: | ||||
|  | ||||
| - Detailed specification on how annotations work | ||||
| - With the specification it should be possible to implement backup and restore | ||||
|   without looking at the backupbot-two code | ||||
|  | ||||
| --- | ||||
|  | ||||
| - Budget amount: 200 EUR (10 hrs * 20 EUR/hr) | ||||
| - Who will implement this: p4u1 | ||||
| - When will the money be spent: Before the end of February | ||||
| - What is the money for: Writing documentation and specification for backup-bot-two | ||||
							
								
								
									
										21
									
								
								docs/federation/resolutions/in-progress/017.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								docs/federation/resolutions/in-progress/017.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| --- | ||||
| title: "Resolution 017" | ||||
| --- | ||||
|  | ||||
| - Topic: BeWater joins the Co-op Cloud Federation | ||||
| - Date: 30-01-2024 | ||||
| - Deadline: 21-02-2024 | ||||
| - Size: Large | ||||
|  | ||||
| ### Summary | ||||
|  | ||||
| [BeWater Co-op](https://bewater.contact). | ||||
|  | ||||
| `@decentral1se` is a member and has been active in Abra hacking & coordination | ||||
| on several issues. BeWater maintains several small-scale Co-op Cloud | ||||
| deployments. | ||||
|  | ||||
| ### Details | ||||
|  | ||||
| BeWater is just starting and we're currently unable to pay the membership fees | ||||
| at this time and ask for a waiver for 1 year. To be revisited on 30-01-2025. | ||||
| @ -1,3 +0,0 @@ | ||||
| --- | ||||
| title: In progress | ||||
| --- | ||||
| @ -4,15 +4,21 @@ title: Resolutions | ||||
|  | ||||
| ### Resolution Template | ||||
|  | ||||
| ```javascript | ||||
| ## Resolution <number>: <title> - <date> | ||||
| ``` yaml | ||||
| --- | ||||
| title: Resolution <number> | ||||
| --- | ||||
|  | ||||
| - Topic: <title> | ||||
| - Date: 13-12-2023 | ||||
| - Deadline: Date | ||||
| - Size: large or medium | ||||
|  | ||||
| ### Summary | ||||
| Who this affects, and what it does | ||||
|  | ||||
| Who this affects, and what it does... | ||||
|  | ||||
| ### Details | ||||
| A narrative with details | ||||
|  | ||||
| A narrative with details... | ||||
| ``` | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Proposal 001: Decision Making Process - 2023-03-03" | ||||
| title: "Resolution 001" | ||||
| --- | ||||
|  | ||||
| - Topic: Decision Making Process | ||||
| - Date: 2023-03-03 | ||||
| - Deadline: 2023-03-03 (live voting) | ||||
| - Size: large | ||||
|  | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 002: Membership/Dues - 2023-03-22" | ||||
| title: "Resolution 002" | ||||
| --- | ||||
|  | ||||
| * Topic: Membership/Dues | ||||
| * Date: 2023-03-22 | ||||
| * Deadline: 2023-04-11 | ||||
| * Passed on 2023-04-13 | ||||
| * Size: Large | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 003: Paid work - 2023-03-22" | ||||
| title: "Resolution 003" | ||||
| --- | ||||
|  | ||||
| * Topic: Paid work | ||||
| * Date: 2023-03-22 | ||||
| * Deadline: 2023-04-11 | ||||
| * Passed on 2023-04-13 | ||||
| * Size: Large | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 004: Budgeting - 2023-03-22" | ||||
| title: "Resolution 004" | ||||
| --- | ||||
|  | ||||
| * Topic: Budget 001: Budgeting | ||||
| * Date: 2023-03-22 | ||||
| * Deadline: 2023-04-11 | ||||
| * Passed on 2023-04-13 | ||||
| * Size: Large | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 005: Public federation membership, notes and decisions - 2023-04-14" | ||||
| title: "Resolution 005" | ||||
| --- | ||||
|  | ||||
| * Topic: Public federation membership, notes and decisions | ||||
| * Date: 2023-04-14 | ||||
| * Deadline: 2023-04-17 | ||||
| * Passed: 2023-04-18 | ||||
| * Size: medium | ||||
|  | ||||
| @ -1,9 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 006: Budget 002: Resolution Writing-up - 2023-05-29" | ||||
| title: "Resolution 006" | ||||
| --- | ||||
|  | ||||
| # Resolution 006: Budget 002: Resolution Writing-up - 2023-05-29 | ||||
|  | ||||
| - Budget 002: Resolution Writing-up | ||||
| - Date: 2023-05-29 | ||||
| - Deadline: 2022-06-12 | ||||
| - Size: Large | ||||
|  | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 007: 1 year dues waiver for Doop.coop - 2023-06-19" | ||||
| title: "Resolution 007" | ||||
| --- | ||||
|  | ||||
| - Topic: 1 year dues waiver for Doop.coop | ||||
| - Date: 2023-06-19 | ||||
| - Deadline: 2023-07-03 | ||||
| - Size: Medium | ||||
|  | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 008: Budget 003: Paying invoices - 2023-06-19" | ||||
| title: "Resolution 008" | ||||
| --- | ||||
|  | ||||
| - Topic: Budget 003 Paying invoices | ||||
| - Date: 2023-06-19 | ||||
| - Deadline: 2022-07-03 | ||||
| - Size: Large | ||||
|  | ||||
|  | ||||
| @ -1,9 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 009: Federation common fund buffer - 2023-07-03" | ||||
| title: "Resolution 009"  | ||||
| --- | ||||
|  | ||||
| ## Resolution 009: Federation common fund buffer - 2023-07-03 | ||||
|  | ||||
| - Topic: Federation common fund buffer | ||||
| - Date: 2023-07-03 | ||||
| - Deadline: 2023-07-17 | ||||
| - Size: Large | ||||
|  | ||||
|  | ||||
| @ -1,9 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 010: Budget 004: Critical fixes - 2023-07-03" | ||||
| title: "Resolution 010" | ||||
| --- | ||||
|  | ||||
| ## Resolution 010: Budget 004: Critical fixes - 2023-07-03 | ||||
|  | ||||
| - Topic: Budget 004: Critical fixes | ||||
| - Date: 2023-07-03 | ||||
| - Deadline: 2023-07-17 | ||||
| - Size: Large | ||||
|  | ||||
|  | ||||
| @ -1,7 +1,9 @@ | ||||
| --- | ||||
| title: "Resolution 011: Budget 005: Backup improvements - 2023-07-23" | ||||
| title: "Resolution 011"  | ||||
| --- | ||||
|  | ||||
| - Topic: Budget 005: Backup improvements | ||||
| - Date: 2023-07-23 | ||||
| - Deadline: 2022-08-06 | ||||
| - Size: Large | ||||
|  | ||||
|  | ||||
| @ -1,8 +1,10 @@ | ||||
| --- | ||||
| title: "Resolution 012: Budget 006: Abra integration test suite - 2023-09-08" | ||||
| title: "Resolution 012" | ||||
| --- | ||||
| 
 | ||||
| - Deadline: 2023-09-22 | ||||
| - Budget 006: Abra integration test suite | ||||
| - Date: 2023-09-09 | ||||
| - Deadline: 2023-09-23 | ||||
| - Size: Large | ||||
| 
 | ||||
| ### Summary | ||||
							
								
								
									
										45
									
								
								docs/federation/resolutions/passed/014.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								docs/federation/resolutions/passed/014.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| --- | ||||
| title: "Resolution 014" | ||||
| --- | ||||
|  | ||||
| - Topic: Budget 008: Critical Fixes | ||||
| - Date: 2023-12-06 | ||||
| - Deadline: 2023-12-24 | ||||
| - Size: Large | ||||
|  | ||||
| ## Summary | ||||
|  | ||||
| We (decentral1se, wykwit, moritz, knoflook) have identified bugs and lacking features that are a big obstacle to using abra. | ||||
|  | ||||
| We have roughly estimated the work to fix the bugs to take between 27 and 75 hours. We would also like to request onboarding budget for two new developers to smoothly get started on the bug fixes (10 hours per person). | ||||
|  | ||||
| We'd like to request no more than 1900€ of budget to cover the labor and onboarding. If less than 95 hours is spent, the remaining budget will not be paid out. | ||||
|  | ||||
| ## Details | ||||
|  | ||||
| estimating: small (1-3 hours), medium (3-8 hours), large (8-15 hours) & order is priority. | ||||
|  | ||||
|  | ||||
| | NAME | estimation | | ||||
| | ---- | ----- | | ||||
| | [#535 Comment parsing and modifiers](https://git.coopcloud.tech/coop-cloud/organising/issues/535) | Large | | ||||
| | [#519 abra app new `[<recipe>]` `[<version>]`](https://git.coopcloud.tech/coop-cloud/organising/issues/519) | Medium | | ||||
| | [#518 Abra fails silently if required image doesn't exist](https://git.coopcloud.tech/coop-cloud/organising/issues/518) | Medium | | ||||
| | [#527 abra catalogue generate `<recipe name>` ignores the specified recipe](https://git.coopcloud.tech/coop-cloud/organising/issues/527) | Small | | ||||
| | [#509 abra app remove could wait until volume is not in use](https://git.coopcloud.tech/coop-cloud/organising/issues/509) | Medium | | ||||
| | [#530 abra recipe fetch can only fetch a single recipe](https://git.coopcloud.tech/coop-cloud/organising/issues/530) | Medium | | ||||
| | [#525 prevent abra app cp from applying file permissions.](https://git.coopcloud.tech/coop-cloud/organising/issues/525) | Medium | | ||||
| | [#537 Fix the operators tutorial](https://git.coopcloud.tech/coop-cloud/organising/issues/537) | Medium | | ||||
|  | ||||
| Estimation: best case: (8 * 1) + (3 * 6) + (1 * 1) = 27 hours | ||||
| Estimation: worst case: (15 * 1) + (8 * 6) + (1 * 3) = 73 hours | ||||
| + 10 hours for onboarding * 2 people = 47-93 hours | ||||
|  | ||||
|  | ||||
| **Budget amount**: 1900€/95 hours at maximum | ||||
|  | ||||
| **Who will implement this:** p4u1, wykwit, moritz, knoflook | ||||
|  | ||||
| **When will the money be spent:** Before the end of February 2024. | ||||
|  | ||||
| **What is the money for:** Fixing bugs and improving operator docs. | ||||
							
								
								
									
										21
									
								
								docs/federation/resolutions/passed/015.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								docs/federation/resolutions/passed/015.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | ||||
| --- | ||||
| title: "Resolution 015" | ||||
| --- | ||||
|  | ||||
| - Topic: Klasse & Methode joins the Co-op Cloud Federation | ||||
| - Date: 25-01-2024 | ||||
| - Deadline: 08-02-2024 | ||||
| - Size: Large | ||||
|  | ||||
| ### Summary | ||||
|  | ||||
| [Klasse & Methode - IT Kollektiv Stuttgart](https://codeberg.org/Klasse-Methode). | ||||
|  | ||||
| `@p4u1` has been active in Abra hacking & coordination on several issues. K & M | ||||
| manage a Co-op Cloud deployment with 9 apps running at the time of the | ||||
| proposal. | ||||
|  | ||||
| ### Details | ||||
|  | ||||
| K & M is volunteer based and are unable to pay the membership fees at this time | ||||
| and ask for a waiver for 1 year. To be revisited on 25-01-2025. | ||||
							
								
								
									
										25
									
								
								docs/get-involved/support.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								docs/get-involved/support.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,25 @@ | ||||
| --- | ||||
| title: "Support Us" | ||||
| --- | ||||
|  | ||||
| If you like what you see whilst browsing Co-op Cloud and would like to | ||||
| contribute financially, as opposed to with code, we currently receive donations | ||||
| via an [Open Collective account](https://opencollective.com/coop-cloud). | ||||
|  | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __Infrastructure Support__ | ||||
|  | ||||
|     If you make use of our digital infrastructure and want to help out with | ||||
|     maintenance costs, we wold be grateful :heart: | ||||
|  | ||||
|     [Donate Now](https://opencollective.com/coop-cloud/contribute/infrastructure-sustainability-29878/checkout){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Join The Federation__ | ||||
|  | ||||
|     If you want to be more actively involved as a supporter, consider joining | ||||
|     our Federation :handshake_tone2: | ||||
|  | ||||
|     [Learn More](/federation/){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
							
								
								
									
										180
									
								
								docs/intro/comparisons.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								docs/intro/comparisons.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,180 @@ | ||||
| --- | ||||
| title: Comparisons | ||||
| --- | ||||
|  | ||||
| We think it's important to understand that *Co-op Cloud* is more than just | ||||
| software and technical configurations. It is also a novel organization of *how* | ||||
| to [create technology socially](https://docs.coopcloud.tech/federation). | ||||
| However, strictly technically speaking you may be wondering: | ||||
|  | ||||
| ### What about `$alternative`? | ||||
|  | ||||
| We have various technical critiques of other similar projects which are already up-and-running in the ecosystem, as they don't necessarily meet our needs as a small tech co-op. However, Co-op Cloud isn't meant to be a replacement for these other projects. | ||||
|  | ||||
| Here is a short overview of the pros/cons we see, in relation to our goals and needs. | ||||
|  | ||||
| ### Cloudron | ||||
|  | ||||
| [Cloudron](https://www.cloudron.io) is complete solution for running apps on your own server | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Decent web interface for app, domain & user management. | ||||
| - 👍 Large library of apps. | ||||
| - 👍 Built-in SSO using LDAP, which is compatible with more apps and often has a better user interface than OAuth. | ||||
| - 👍 Apps are actively maintained by the Cloudron team. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Moving away from open source. The core is now proprietary software. | ||||
| - 👎 Libre tier has a single app limit. | ||||
| - 👎 Based on Docker images, not stacks, so multi-process apps (e.g. parsoid visual editor for Mediawiki) are a non-starter. | ||||
| - 👎 Difficult to extend apps. | ||||
| - 👎 Only supported on Ubuntu LTS. | ||||
| - 👎 Upstream libre software communities aren't involved in packaging. | ||||
| - 👎 Limited to vertical scaling. | ||||
| - 👎 Tension between needs of hosting provider and non-technical user. | ||||
| - 👎 LDAP introduces security problems - one vulnerable app can expose a user's password for all apps. | ||||
| - 👎 Bit of a [black box](https://en.wikipedia.org/wiki/Black_box). | ||||
|  | ||||
| ### YunoHost | ||||
|  | ||||
| [YunoHost](https://yunohost.org) is an operating system aiming for the simplest administration of a server | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Lovely web interface for app, domain & user management. | ||||
| - 👍 Bigger library of apps. | ||||
| - 👍 Awesome backup / deploy / restore continuous integration testing. | ||||
| - 👍 Supports hosting apps in subdirectories as well as subdomains. | ||||
| - 👍 Doesn't require a public-facing IP. | ||||
| - 👍 Supports system-wide mutualisation of resources for apps (e.g. sharing databases by default) | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't involved in packaging. | ||||
| - 👎 Uninstalling apps leaves growing cruft. | ||||
| - 👎 Limited to vertical scaling. | ||||
| - 👎 Not intended for use by hosting providers. | ||||
|  | ||||
| ### Caprover | ||||
|  | ||||
| [CapRover](https://caprover.com) is an easy to use app/database deployment & web server manager for applications | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Bigger library of apps. | ||||
| - 👍 Easy set-up using a DigitalOcean one-click app. | ||||
| - 👍 Works without a domain name or a public IP, in non-HTTPS mode (good for homeservers). | ||||
| - 👍 Deploy any app with a `docker-compose.yml` file as a "One Click App" via the web interface. | ||||
| - 👍 Multi-node (multi-server) set-up works by default. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Single-file app definition format, difficult to tweak using entrypoint scripts. | ||||
| - 👎 Nginx instead of Traefik for load-balancing. | ||||
| - 👎 Command-line client requires NodeJS / `npm`. | ||||
| - 👎 [Requires 512MB RAM for a single app](https://github.com/caprover/caprover/issues/28). | ||||
| - 👎 [Backup/restore is "experimental"](https://caprover.com/docs/backup-and-restore.html), and doesn't currently help with backing up Docker volumes. | ||||
| - 👎 Exposes its bespoke management interface to the internet via HTTPS by default. | ||||
|  | ||||
| ### Ansible | ||||
|  | ||||
| [Ansible](https://www.ansible.com) mature automation and deployment tool. | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Includes server creation and bootstrapping. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't publishing Ansible roles. | ||||
| - 👎 Lots of manual work involved in things like app isolation, backups, updates. | ||||
|  | ||||
| ### Kubernetes | ||||
|  | ||||
| [Kubernetes](https://kubernetes.io) (or K8s) is a system for automating deployment, scaling, and | ||||
| management of containerized applications. | ||||
|  | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Helm charts are available for some key apps already. | ||||
| - 👍 Scale all the things. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Too big -- requires 3rd party tools to run a single-node instance. | ||||
| - 👎 Not suitable for a small to mid size hosting provider. | ||||
|  | ||||
| ### Docker-compose | ||||
|  | ||||
| [Docker Compose](https://docs.docker.com/compose/) is a tool for defining and running multi-container applications. | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Quick to set up and familiar for many developers. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Manual work required for process monitoring. | ||||
| - 👎 Secret storage not available yet. | ||||
| - 👎 Swarm is the new best practice. | ||||
|  | ||||
| ### Doing it Manually (Old School) | ||||
|  | ||||
| If you are an absolute Shaman in a Shell and learning new gadgets just slows you down, | ||||
| have it, but maybe ask how old [is old enough](https://en.wikipedia.org/wiki/Printing_press)? | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Simple - just follow upstream instructions to install and update. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Loads of manual work required for app isolation and backups. | ||||
| - 👎 Array of sysadmin skills required to install and maintain apps. | ||||
| - 👎 Hard to share configurations into the commons. | ||||
| - 👎 No idea who has done what change when. | ||||
|  | ||||
|  | ||||
| ### Stackspin | ||||
|  | ||||
| [Stackspin](https://www.stackspin.net) deployment and management stack for a | ||||
| handful of popular team collaboration apps. | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Easy instructions to install & upgrade multiple tightly integrated apps. | ||||
| - 👍 Offers a unified SSO user experience. | ||||
| - 👍 Offers tightly integrated logging, monitoring, and maintenance. | ||||
| - 👍 Has a strong focus and attention to security. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't involved in packaging. | ||||
| - 👎 It is not designed to be a general specification. | ||||
| - 👎 Hard to share configurations into the commons. | ||||
| - 👎 Significantly limited library of eight apps. | ||||
| - 👎 Additional apps are treated as "External Apps" with only OAuth2/OpenID integration. | ||||
| - 👎 Requires a Kubernetes cluster. | ||||
|  | ||||
|  | ||||
| ### Maadix | ||||
|  | ||||
| [Maadix](https://maadix.net) managed hosting and deployment of popular privacy preserving applications. | ||||
|  | ||||
| **Pros** | ||||
|  | ||||
| - 👍 Nice looking web interface for app, domain & user management. | ||||
| - 👍 Offers a paid hosting service to get up and running easily. | ||||
|  | ||||
| **Cons** | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't involved in packaging. | ||||
| - 👎 It is not designed to be a general specification. | ||||
| - 👎 Hard to share configurations into the commons. | ||||
| - 👎 Limited library of apps. | ||||
| - 👎 Uses *OpenNebula*, *Ansible*, and *Puppet* as underlying technologies. | ||||
| - 👎 Appears to be only a team of two people. | ||||
| - 👎 Appears to be inactive on Mastodon and limited GitLab activity.  | ||||
| @ -2,16 +2,33 @@ | ||||
| title: Get in touch | ||||
| --- | ||||
|  | ||||
| ## Email | ||||
| We welcome developers, sys-admins, designers, UX folks, Q&A testers, and passionate users to join us. | ||||
| Pick the right medium for your interests. | ||||
|  | ||||
| [`helo@coopcloud.tech`](mailto:helo@coopcloud.tech) | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| ## Chat | ||||
| - __Chat__ | ||||
|  | ||||
| ### Matrix | ||||
|     [Matrix](https://matrix.org) is our chat platform of choice, we are happy to hear from you there :speech_left: | ||||
|  | ||||
| Here is a link to the [Matrix space](https://matrix.to/#/!xSMwGbdVehScXcIFwS:autonomic.zone?via=autonomic.zone&via=matrix.org&via=1312.media) to see all channels. | ||||
|     [Join Chats](https://matrix.to/#/!xSMwGbdVehScXcIFwS:autonomic.zone?via=autonomic.zone&via=matrix.org&via=1312.media){ .md-button .md-button--primary } | ||||
|  | ||||
| ## Forum | ||||
| - __Codebases__ | ||||
|  | ||||
| [`community.coops.tech`](https://community.coops.tech/) | ||||
|     Get straight to looking at our code or filing issues, hop to our Gitea instance :sunglasses: | ||||
|  | ||||
|     [Browse Code](https://git.coopcloud.tech/coop-cloud){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Forum__ | ||||
|  | ||||
|     If you prefer communicating asynchronously with topical categories :tropical_drink: | ||||
|  | ||||
|     [Our Forum](https://community.coops.tech/){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Email__ | ||||
|  | ||||
|     If you like it old school, feel free to fire up port 25 and send us a `HELO` message :email: | ||||
|  | ||||
|     [Email Us](mailto:helo@coopcloud.tech){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| @ -8,146 +8,43 @@ Co-op Cloud aims to make hosting libre software apps simple for small service pr | ||||
|  | ||||
| ## Who is behind the project? | ||||
|  | ||||
| The project was started by workers at [Autonomic](https://autonomic.zone/) which is a [worker-owned co-operative](https://en.wikipedia.org/wiki/Worker_cooperative). We provide technologies and infrastructure to empower users to make a positive impact on the world. We're using Co-op Cloud in production, amongst other systems. | ||||
| The project was started by workers at [Autonomic](https://autonomic.zone/) which | ||||
| is a [worker-owned co-operative](https://en.wikipedia.org/wiki/Worker_cooperative) who provides | ||||
| technologies and infrastructure to empower users to make a positive impact on | ||||
| the world. Numerous other like minded co-ops have since joined our | ||||
| [Federation](/federation/) and rely *Co-op Cloud* in production. | ||||
|  | ||||
|  | ||||
| ## Why Co-op Cloud? | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Thin "ease of use" layer on top of already standardised tooling | ||||
| - 👍 Extremely modular | ||||
| - 👍 Collective commons based configuration via public git repos | ||||
| - 👍 Focussed on hosting providers | ||||
| - 👍 Uses upstream published containers (no duplication on packaging) | ||||
| - 👍 Now and always libre software | ||||
| - 👍 Command line focussed | ||||
| - 👍 Horizontal and vertical scaling | ||||
| - 👍 Thin "ease of use" layer on top of already standardised tooling. | ||||
| - 👍 Extremely modular. | ||||
| - 👍 Collective commons based configuration via public git repos. | ||||
| - 👍 Focussed on hosting providers. | ||||
| - 👍 Uses upstream published containers (no duplication on packaging). | ||||
| - 👍 Now and always libre software. | ||||
| - 👍 Command line focussed. | ||||
| - 👍 Horizontal and vertical scaling. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Still a very young project | ||||
| - 👎 Limited availability of well tested apps | ||||
| - 👎 Requires command line knowledge to use | ||||
| - 👎 Currently x86 only (see [this FAQ question](#why-only-x86-support) for more) | ||||
| - 👎 Still a very young project. | ||||
| - 👎 Limited availability of well tested apps. | ||||
| - 👎 Requires command line knowledge to use. | ||||
| - 👎 Currently x86 only (see [this FAQ question](#why-only-x86-support) for more). | ||||
|  | ||||
| ## Why start another project? | ||||
|  | ||||
| We think our carefully chosen blend of technologies and our [social approach](/federation/) is quite unique in today's technology landscape. | ||||
| Please read our [initial project announcement post](https://autonomic.zone/blog/co-op-cloud/) for more on this. | ||||
|  | ||||
| Also see our [strategy page](../strategy/). | ||||
|  | ||||
| ## How do I make a recipe for (package) an app? | ||||
|  | ||||
| See ["Package your first recipe"](/maintainers/tutorial/#package-your-first-recipe) for more. | ||||
| Head on over to **Maintainers** section and see ["Package your first recipe"](/maintainers/tutorial/#package-your-first-recipe) for more. | ||||
|  | ||||
| ## What about `$alternative`? | ||||
|  | ||||
| We have various technical critiques of other similar projects which are already up-and-running in the ecosystem, as they don't necessarily meet our needs as a small tech co-op. However, Co-op Cloud isn't meant to be a replacement for these other projects. | ||||
|  | ||||
| Here is a short overview of the pros/cons we see, in relation to our goals and needs. | ||||
|  | ||||
| ### Cloudron | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Decent web interface for app, domain & user management. | ||||
| - 👍 Large library of apps. | ||||
| - 👍 Built-in SSO using LDAP, which is compatible with more apps and often has a better user interface than OAuth. | ||||
| - 👍 apps are actively maintained by the Cloudron team. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Moving away from open source. The core is now proprietary software. | ||||
| - 👎 libre tier has a single app limit. | ||||
| - 👎 Based on Docker images, not stacks, so multi-process apps (e.g. parsoid visual editor for Mediawiki) are a non-starter. | ||||
| - 👎 Difficult to extend apps. | ||||
| - 👎 Only supported on Ubuntu LTS. | ||||
| - 👎 Upstreams libre software communities aren't involved in packaging. | ||||
| - 👎 Limited to vertical scaling. | ||||
| - 👎 Tension between needs of hosting provider and non-technical user. | ||||
| - 👎 LDAP introduces security problems - one vulnerable app can expose a user's password for all apps. | ||||
| - 👎 Bit of a [black box](https://en.wikipedia.org/wiki/Black_box). | ||||
|  | ||||
| ### YunoHost | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Lovely web interface for app, domain & user management. | ||||
| - 👍 Bigger library of apps. | ||||
| - 👍 Awesome backup / deploy / restore continuous integration testing. | ||||
| - 👍 Supports hosting apps in subdirectories as well as subdomains. | ||||
| - 👍 Doesn't require a public-facing IP. | ||||
| - 👍 Supports system-wide mutualisation of resources for apps (e.g. sharing databases by default) | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't involved in packaging. | ||||
| - 👎 Uninstalling apps leaves growing cruft. | ||||
| - 👎 Limited to vertical scaling. | ||||
| - 👎 Not intended for use by hosting providers. | ||||
|  | ||||
| ### Caprover | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Bigger library of apps. | ||||
| - 👍 Easy set-up using a DigitalOcean one-click app. | ||||
| - 👍 Works without a domain name or a public IP, in non-HTTPS mode (good for homeservers). | ||||
| - 👍 Deploy any app with a `docker-compose.yml` file as a "One Click App" via the web interface. | ||||
| - 👍 Multi-node (multi-server) set-up works by default. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Single-file app definition format, difficult to tweak using entrypoint scripts. | ||||
| - 👎 Nginx instead of Traefik for load-balancing. | ||||
| - 👎 Command-line client requires NodeJS / `npm`. | ||||
| - 👎 [Requires 512MB RAM for a single app](https://github.com/caprover/caprover/issues/28). | ||||
| - 👎 [Backup/restore is "experimental"](https://caprover.com/docs/backup-and-restore.html), and doesn't currently help with backing up Docker volumes. | ||||
| - 👎 Exposes its bespoke management interface to the internet via HTTPS by default. | ||||
|  | ||||
| ### Ansible | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Includes server creation and bootstrapping. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Upstream libre software communities aren't publishing Ansible roles | ||||
| - 👎 Lots of manual work involved in things like app isolation, backups, updates | ||||
|  | ||||
| ### Kubernetes | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Helm charts are available for some key apps already. | ||||
| - 👍 Scale all the things. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Too big -- requires 3rd party tools to run a single-node instance. | ||||
| - 👎 Not suitable for a small to mid size hosting provider. | ||||
|  | ||||
| ### Docker-compose | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👎 Manual work required for process monitoring. | ||||
| - 👎 Secret storage not available yet. | ||||
| - 👎 [Swarm is the new best practice](https://github.com/BretFisher/ama/issues/8#issuecomment-367575011). | ||||
|  | ||||
| ### Doing it Manually (Old School) | ||||
|  | ||||
| #### Pros | ||||
|  | ||||
| - 👍 Simple - just follow upstream instructions to install and update. | ||||
|  | ||||
| #### Cons | ||||
|  | ||||
| - 👎 Loads of manual work required for app isolation and backups. | ||||
| - 👎 Array of sysadmin skills required to install and maintain apps. | ||||
| - 👎 Hard to share configurations into the commons. | ||||
| - 👎 No idea who has done what change when. | ||||
|  | ||||
| ## Which technologies are used? | ||||
|  | ||||
| @ -210,13 +107,28 @@ We are happy to see the compose specification emerging as a new open standard be | ||||
|  | ||||
| ## Why Docker Swarm? | ||||
|  | ||||
| While many have noted that "swarm is dead" it is in fact [not dead](https://www.mirantis.com/blog/mirantis-will-continue-to-support-and-develop-docker-swarm/). As detailed in the [architecture overview](/operators/tutorial/#container-orchestrator), swarm offers an appropriate feature set which allows us to support zero-down time upgrades, seamless app rollbacks, automatic deploy failure handling, scaling, hybrid cloud setups and maintain a decentralised design. | ||||
| While many have noted that "swarm is dead" it is in fact [not dead](https://www.mirantis.com/blog/mirantis-will-continue-to-support-and-develop-docker-swarm/) (2020). As detailed in the [architecture overview](/intro/strategy/#container-orchestrator), *Swarm* offers an appropriate feature set which allows us to support zero-down time upgrades, seamless app rollbacks, automatic deploy failure handling, scaling, hybrid cloud setups and maintain a decentralised design. | ||||
|  | ||||
| While the industry is bordering on a [k8s](https://kubernetes.io/) obsession and the need to [scale down](https://microk8s.io/) a tool that was fundamentally built for massive scale, we are going with swarm because it is the tool most suitable for [small technology](https://small-tech.org/). | ||||
| While the industry is bordering on a [k8s](https://kubernetes.io/) obsession and the need to [scale down](https://microk8s.io/) a tool that was fundamentally built for massive scale, we are going with *Swarm* because it is the tool most suitable for [small technology](https://small-tech.org/). | ||||
|  | ||||
| The _Co-op Cloud Community’s_ forecast at the start of 2024 for the future of *Docker Swarm* is positive after five years after *Mirantis’s* acquisition of Docker Enterprise | ||||
| in 2018. Since then, their strategy has developed towards using *Docker Swarm* as an intermediary step between Docker/Docker-Compose, and *Kubernetes* – where | ||||
| previously it seemed like their aim was to migrate all their customers’ [deployments to Kubernetes](https://www.mirantis.com/blog/kubernetes-vs-swarm-these-companies-use-both) (Oct, 2022). | ||||
| *Mirantis* acquired Docker Enterprise in 2019 and today delivers enterprise-grade Swarm—either as a managed service or with enterprise support through Mirantis Kubernetes Engine. | ||||
|  | ||||
| There is reasonably healthy activity in their issue tracker with label [`area/swarm`](https://github.com/moby/moby/issues?q=+label%3Aarea%2Fswarm+). | ||||
| Additionally, we see it as reassuring that *Mirantis* has a growing number of pages relating to *Docker Swarm*: | ||||
|  | ||||
| - [Mirantis' Product Page](https://www.mirantis.com/software/swarm/) | ||||
| - [What's next for Swarm: New features, the same world-class support](https://www.mirantis.com/blog/what-s-next-for-swarm) (Oct, 2022) | ||||
| - [Docker Swarm Still Thriving Three Years after Mirantis Acquisition](https://www.mirantis.com/company/press-center/company-news/docker-swarm-still-thriving-three-years-after-mirantis-acquisition-often-running-side-by-side-with-kubernetes/) (Nov, 2022) | ||||
|  | ||||
| Lastly, it’s worth mentioning that much of the configuration involved in setting up *Docker Swarm*, particularly in terms of preparing images, and in managing the conceptual side, are transferable to other orchestration engines. | ||||
| We hope to see a container orchestrator tool that is not directly linked to a for-profit company emerge soon but for now, this is what we have. | ||||
|  | ||||
| If you want to learn more, see [dockerswarm.rocks](https://dockerswarm.rocks/) for a nice guide. See also [`BretFisher/awesome-swarm`](https://github.com/BretFisher/awesome-swarm). | ||||
| If you want to learn more, see [dockerswarm.rocks](https://dockerswarm.rocks/) for a nice guide. | ||||
| See also this list of [`awesome-swarm`](https://github.com/BretFisher/awesome-swarm) by Bret Fisher. | ||||
|  | ||||
|  | ||||
| ## What licensing model do you use? | ||||
|  | ||||
|  | ||||
| @ -1,19 +1,105 @@ | ||||
| --- | ||||
| title: Project strategy | ||||
| title: Project Strategy | ||||
| --- | ||||
|  | ||||
| !!! note "Yes, we are blog" | ||||
| From our experiences working and organising as Autonomic, the tech co-op who [initiated Co-op Cloud](https://autonomic.zone/blog/co-op-cloud/), we know that the progressive tech movement lack reliable and cost-effective technical means for providing a sustainable alternative to _Big Tech_© services which are marketed as "[cloud computing](https://en.wikipedia.org/wiki/Cloud_computing)". | ||||
|  | ||||
|     Some leading thoughts are outlined in the [project launch blog post](https://autonomic.zone/blog/co-op-cloud/) also. | ||||
|  | ||||
| From our experiences working and organising as Autonomic, the tech co-op who initiated Co-op Cloud, we know that the progressive tech movement lack reliable and cost-effective technical means for providing an alternative to “Big Tech” cloud services. | ||||
| ## Technological Saviors? | ||||
|  | ||||
| The urgency for providing an alternative comes out of the understanding that the concentration of our digital lives within the private sphere of corporate providers (e.g. [GAFAM](https://degooglisons-internet.org/en/)) represents a loss of freedom due to the threat to our privacy and self-determination through surveillance and monopolisation. | ||||
|  | ||||
| As a movement, we cannot compete with corporate providers in terms of cost and scale. Their network effects and available capital means that no one project, product or organisation can create the required shift to a more widespread public interest technology. | ||||
|  | ||||
| Technology alone will not save us. Simply deploying libre software is not enough.  | ||||
| > Technology alone will not save us | ||||
| > | ||||
| > Simply deploying libre software is not enough.  | ||||
|  | ||||
| Our strategy is to mutualise our resources to facilitate this shift. Co-op Cloud is an attempt to create a new shared resource - an open and democratically managed, open standards based, copyleft licensed, libre software infrastructure project. | ||||
| Our strategy is to mutualise our resources to facilitate this shift. _Co-op Cloud_ is an attempt to create a new shared resource - an open and democratically managed, open standards based, copyleft licensed, libre software infrastructure project. | ||||
|  | ||||
| From this base, we can focus on the urgent and necessary social organising work that goes beyond the technical question. | ||||
|  | ||||
| ## The Moving Parts | ||||
|  | ||||
| _Co-op Cloud_ is made up of a few simple, composable pieces. The system does not rely on any one specific implementation: each part may be replaced and/or extended as needed. We want to build a resilient and long-term sustainable project and that means allowing for different implementations, open formats and a diverse project organisation. Here are the main technical concepts listed below,  | ||||
|  | ||||
| ``` mermaid | ||||
| graph LR | ||||
|   A[Libre Software\n Apps] --> B{Recipe Packaging}; | ||||
|   B --> C[CLI Tool]; | ||||
|   C --> D[Container\n Orchestrator]; | ||||
| ``` | ||||
|  | ||||
| Once you [grok](https://en.wikipedia.org/wiki/Grok) this, you grok the moving parts of the entire project. You can then move on to [deploying your first app](/operators/tutorial/#deploy-your-first-app). | ||||
|  | ||||
| ### Libre Software Apps | ||||
|  | ||||
| Libre software apps are tools- they take the shape of websites, mobile apps, and software clients that you may already use in your daily life, for example... | ||||
|  | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - :simple-nextcloud: __Nextcloud__ | ||||
| - :simple-jitsi: __Jitsi__ | ||||
| - :simple-wikimediacommons: __Mediawiki__ | ||||
| - :fontawesome-solid-rocket: __Rocket.chat__ | ||||
|  | ||||
| </div> | ||||
|  | ||||
| ...and many more. These apps are also often referred to as _open-Source_ or _Free-Software_. These are tools that are created by volunteer communities who use [free software licenses] in order to build up the public software commons and offer more digital alternatives to [proprietary systems]. | ||||
|  | ||||
| The communities who develop these softwares also publish them using [containers]. For example, here is the [Nextcloud hub.docker.com account] which allows end-users to quickly deploy a new Nextcloud instance. | ||||
|  | ||||
| There is a growing consensus in the free software community that containers are a useful and time saving format for distribution. | ||||
|  | ||||
| !!! question "Why did you choose to use containers?" | ||||
|  | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-containers). | ||||
|  | ||||
| [free software licenses]: https://www.gnu.org/philosophy/free-sw.html | ||||
| [nextcloud hub.docker.com account]: https://hub.docker.com/_/nextcloud | ||||
| [proprietary systems]: https://en.wikipedia.org/wiki/Proprietary_software | ||||
| [containers]: https://www.docker.com/resources/what-container | ||||
|  | ||||
| ### Recipe Packaging Format | ||||
|  | ||||
| However, just having a container of an app is often not enough. The work required to deploy that app in a "production ready" setup is still too time intensive and often involves a duplication of effort. | ||||
|  | ||||
| Each service provider needs to deal with the same problems: stable versioning, backup plan, secret management, upgrade plan, monitoring and the list goes on. | ||||
|  | ||||
| Individual free software projects can't take on all this responsibility. They provide the containers as is, in a secure and ready-to-go manner but it is up to service providers to worry about how the app is deployed. | ||||
|  | ||||
| Therefore, Co-op Cloud proposes a packaging format, which we refer to as a recipe, that describes the entire production state of the app in a single place. This format uses the existing [standards based compose specification]. | ||||
|  | ||||
| This is a file format which is most commonly used by the [Docker compose] tool but Co-op Cloud **does not** require the use of Docker compose itself. Furthermore, as described below, we also don't rely on the actual Docker CLI itself either. We do however use a lot of the underlying libraries. | ||||
|  | ||||
| !!! question "Why did you choose to use the compose specificiation?" | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-use-the-compose-specification). | ||||
|  | ||||
| [Each recipe] that Co-op cloud provides is described using the compose specification and makes use of the upstream project published container when possible (sometimes they don't publish one!). | ||||
|  | ||||
| This is the core of our approach to working with the ecosystem of free software communities. We want to maximise the chances of sharing work, knowledge and build solidarity through concrete co-operation. | ||||
|  | ||||
| [standards based compose specification]: https://compose-spec.io | ||||
| [docker compose]: https://docs.docker.com/compose/ | ||||
| [each recipe]: /recipes/ | ||||
|  | ||||
| ### Container Orchestrator | ||||
|  | ||||
| Once we have our app packaged as a recipe, we need a deployment environment (e.g. a server & something to keep the containers running). Production deployments are typically expected to support a number of features which give hosters and end-users guarantees for stability. | ||||
|  | ||||
| The Co-op cloud makes use of [Docker swarm] as a deployment environment. It offers an approriate feature set which allows us to support zero-down time upgrades, seamless app rollbacks, automatic deploy failure handling, scaling, hybrid cloud setups and maintain a decentralised design. | ||||
|  | ||||
| !!! question "Why did you choose to use Docker Swarm?" | ||||
|  | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-docker-swarm). | ||||
|  | ||||
| [docker swarm]: https://docs.docker.com/engine/swarm/ | ||||
|  | ||||
| ### Command-line tool | ||||
|  | ||||
| Finally, we need a tool to read the recipe package format and actually deploy the app. For this, we have developed and published the [abra] command-line tool. | ||||
|  | ||||
| `abra` aims at providing a simple command-line interface for managing your own Co-op Cloud. You can bootstrap machines with the required tools, create new apps and deploy them. `abra` is written in [Go](https://go.dev/) and uses a lot of the libraries that the `docker` and `docker-compose` CLIs use but does not rely on those interfaces directly. | ||||
|  | ||||
| `abra` is our flagship command-line client but it does not need to be the only client. `abra` was designed in such a way that it complements a workflow which can still be done completely manually. If Co-op Cloud goes away tomorrow, our configuration commons would still be useful and usable. | ||||
|  | ||||
| [abra]: /abra/ | ||||
|  | ||||
| @ -17,7 +17,7 @@ You can run `abra recipe new <recipe>` to generate a new `~/.abra/recipes/<recip | ||||
|     "unconfigured" healthcheck behaviour is much less strict and it's faster to | ||||
|     get something up and running. | ||||
|  | ||||
| If you want to make changes to an existing recipe then you can simply edit the files in `~/.abra/recipes/<recipe-name>` and run pass `--chaos` to the `deploy` command when deploying those changes. `abra` will not deploy unstaged changes to avoid instability but you can tell it to do so with `--chaos`. This means ou can simple hack away on the existing recipe files on your local file system and then when something is working, submit a change request to the recipe upstream. | ||||
| If you want to make changes to an existing recipe then you can simply edit the files in `~/.abra/recipes/<recipe-name>` and run pass `--chaos` to the `deploy` command when deploying those changes. `abra` will not deploy unstaged changes to avoid instability but you can tell it to do so with `--chaos`. This means you can simply hack away on the existing recipe files on your local file system and then when something is working, submit a change request to the recipe upstream. | ||||
|  | ||||
| ## How is a recipe structured? | ||||
|  | ||||
| @ -27,7 +27,7 @@ This is a [compose specification](https://compose-spec.io/) compliant file that | ||||
|  | ||||
| ### `.env.sample` | ||||
|  | ||||
| This file is a skeleton for environmental variables that should be adjusted by the user. Examples include: domain or php extention list. Whenever you create a new app with `abra app new` this file gets copied to the `~/.abra/servers/<server-domain>/<app-domain>.env` and when you run `abra app config <app-domain>` you're editing this file. | ||||
| This file is a skeleton for environmental variables that should be adjusted by the user. Examples include: domain or PHP extension list. Whenever you create a new app with `abra app new` this file gets copied to the `~/.abra/servers/<server-domain>/<app-domain>.env` and when you run `abra app config <app-domain>` you're editing this file. | ||||
|  | ||||
| ### `abra.sh` | ||||
|  | ||||
| @ -88,13 +88,26 @@ export NGINX_CONFIG_VERSION=v1 | ||||
|  | ||||
| ## Manage environment variables | ||||
|  | ||||
| When you define an environment variable in a `.env.sample` for a recipe, such as: | ||||
| !!! warning | ||||
|  | ||||
|     Please read this section carefully to avoid deployment footguns for the | ||||
|     operators who deploy your recipe configuration. It's important to | ||||
|     understand how to add new env vars into the recipe configuration in a | ||||
|     non-breaking manner. Thanks for reading! | ||||
|  | ||||
| When you define an environment variable in an `.env.sample` for a recipe, such as: | ||||
|  | ||||
| ```bash | ||||
| FOO=123 | ||||
| ``` | ||||
|  | ||||
| And you pass this via the `environment` stanza of a service config in the recipe like so: | ||||
| This defines an env var which then needs to be added by an operator to their app env file. If you would like to add an env var which is optional, you can do: | ||||
|  | ||||
| ```bash | ||||
| #FOO=123 | ||||
| ``` | ||||
|  | ||||
| In order to expose this env var to recipe configuration, you pass this via the `environment` stanza of a service config in the recipe like so: | ||||
|  | ||||
| ```yaml | ||||
| service: | ||||
| @ -383,6 +396,8 @@ mkdir -p releases | ||||
|  | ||||
| And then create a text file which corresponds to the version release, e.g. `1.1.0+5.9.0` and write some notes. `abra` will show these when another operator runs `abra app deploy` / `abra app upgrade`. | ||||
|  | ||||
| You can also add release notes for the next release into a special file `releases/next`. This file will be used when running `abra recipe release`. | ||||
|  | ||||
| ## How do I generate the recipe catalogue | ||||
|  | ||||
| To generate an entire new copy of the catalogue: | ||||
| @ -412,6 +427,34 @@ You can pass `--publish` to have `abra` automatically publish those changes. | ||||
|  | ||||
|     In order to have `abra` publish changes for you automatically, you'll have to have write permissons to the git.coopcloud.tech repository and your account must have a working SSH key configuration. `abra` will use the SSH based URL connection details for Git by automagically creating an `origin-ssh` remote in the repository and pushing to it. | ||||
|  | ||||
| ## How is I make the catalogue automatically regenerate after new versions are published?  | ||||
|  | ||||
| "I'd like to make it so that whenever I push a new git tag to the | ||||
| [`coop-cloud/rallly` repository](https://git.coopcloud.tech/coop-cloud/rallly) | ||||
| (probably [using `abra recipe | ||||
| release`](#how-do-i-release-a-new-recipe-version)), it automatically does the | ||||
| [recipe catalogue generation steps](#how-do-i-generate-the-recipe-catalogue)" | ||||
|  | ||||
| 1. Check whether tag builds are already trying to run: go to | ||||
|    https://build.coopcloud.tech, search for the recipe name (in this case taking | ||||
|    you to https://build.coopcloud.tech/coop-cloud/rallly/settings). If there are | ||||
|    failing builds, or if you see builds succeeding but catalogue regeneration | ||||
|    doesn't seem to be happening, then either dive in and try and fix it, or ask | ||||
|    for help in [`#coopcloud-tech`](https://matrix.to/#/#coopcloud-tech:autonomic.zone) | ||||
| 2. Otherwise, click "activate repository". You probably want to set the "disable pull | ||||
|    requests" and "disable forks" options; they won't work anyway, but the | ||||
|    failures might be confusing. | ||||
| 3. Make sure there is a `generate recipe catalogue` step in the recipe's | ||||
|    `.drone.yml` -- if there isn't, you can copy [the one from | ||||
|    `coop-cloud/rallly`](https://git.coopcloud.tech/coop-cloud/rallly/src/branch/main/.drone.yml#L24-L38) unchanged. | ||||
| 4. That's it! Now, when you push a new tag, the recipe catalogue will regenerate | ||||
|    automatically. You can test this by re-pushing a tag (e.g. `git push origin | ||||
|    :0.5.0+3.5.1 && git push 0.5.0+3.5.1`) | ||||
|  | ||||
| ## How does automatic catalogue regeneration work? | ||||
|  | ||||
| TODO | ||||
|  | ||||
| ## How do I enable healthchecks | ||||
|  | ||||
| A healthcheck is an important and often overlooked part of the recipe configuration. It is part of the configuration that the runtime uses to figure out if a container is really up-and-running. You can tweak what command to run, how often and how many times to try until you assume the container is not up. | ||||
|  | ||||
| @ -1,8 +1,23 @@ | ||||
| --- | ||||
| title: Maintainers guide | ||||
| title: Maintainers | ||||
| --- | ||||
|  | ||||
| Welcome to the maintainers guide! Maintainers are typically individuals who have a stake in building up and maintaining our digital configuration commons, the recipe configurations. Maintainers help keep recipes configurations up to date, respond to issues in a timely manner, help new users within the community and recruit new maintainers when possible. | ||||
|  | ||||
| - [New maintainers tutorial](/maintainers/tutorial): If you want to package a recipe and/or become a maintainer, start here :rocket: | ||||
| - [Packaging handbook](/maintainers/handbook): One-stop shop for all you need to know to package recipes :package: | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __New Maintainers Tutorial__ | ||||
|  | ||||
|     If you want to package a recipe and/or become a maintainer, start here :rocket: | ||||
|  | ||||
|     [Get Started](/maintainers/tutorial){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Packaging Handbook__ | ||||
|  | ||||
|     One-stop shop for all you need to know to package recipes :package: | ||||
|  | ||||
|     [Read Handbook](/maintainers/handbook){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Maintainers are encouraged to submit documentation patches! Sharing is caring :sparkling_heart: | ||||
|  | ||||
| @ -14,12 +14,12 @@ Depending on your familiarity with recipes, it might be worth reading [how a rec | ||||
|  | ||||
| ### Making a plan | ||||
|  | ||||
| The idea scenario is when the upstream project provides both the packaged image and a compose configuration which we can build from. If you're in luck, you'll typically find a `Dockerfile` and a `docker-compose.yml` file in the root of the upstream Git repository for the app. | ||||
| The ideal scenario is when the upstream project provides both the packaged image and a compose configuration which we can build from. If you're in luck, you'll typically find a `Dockerfile` and a `docker-compose.yml` file in the root of the upstream Git repository for the app. | ||||
|  | ||||
| - **Tired**: Write your own image and compose file from scratch | ||||
| - **Wired**: Use someone else's image (& maybe compose file) | ||||
| - **Inspired**: Upstream image, someone else's compose file | ||||
| - **On fire**: Upstream image, upstream compose file | ||||
| - **Tired**: Write your own image and compose file from scratch :sleeping: | ||||
| - **Wired**: Use someone else's image (& maybe compose file) :smirk_cat: | ||||
| - **Inspired**: Upstream image, someone else's compose file :exploding_head: | ||||
| - **On fire**: Upstream image, upstream compose file :fire: | ||||
|  | ||||
| ### Writing / adapting the `compose.yml` | ||||
|  | ||||
| @ -43,9 +43,9 @@ wget https://raw.githubusercontent.com/matomo-org/docker/master/.examples/apache | ||||
|  | ||||
| Open the `compose.yml` in your favourite editor and have a gander 🦢. There are a few things we're looking for, but some immediate changes could be: | ||||
|  | ||||
| 1. Let's bump the version to `3.8`, to make sure we can use all the latest swarm coolness | ||||
| 2. We load environment variables separately via [`abra`](/abra/), so we'll strip out `env_file` | ||||
| 3. The `/var/www/html` volume definition on L21 is a bit overzealous; it means a copy of Matomo will be stored separately per app instance, which is a waste of space in most cases. We'll narrow it down according to the documentation. The developers have been nice enough to suggest `logs` and `config` volumes instead, which is a decent start | ||||
| 1. Let's bump the version to `3.8`, to make sure we can use all the latest swarm coolness. | ||||
| 2. We load environment variables separately via [`abra`](/abra/), so we'll strip out `env_file`. | ||||
| 3. The `/var/www/html` volume definition on L21 is a bit overzealous; it means a copy of Matomo will be stored separately per app instance, which is a waste of space in most cases. We'll narrow it down according to the documentation. The developers have been nice enough to suggest `logs` and `config` volumes instead, which is a decent start. | ||||
| 4. The MySQL passwords are sent as variables which is fine for basic use, but if we replace them with Docker secrets we can keep them out of our env files if we want to publish those more widely. | ||||
| 5. The MariaDB service doesn't need to be exposed to the internet, so we can define an `internal` network for it to communicate with Matomo. | ||||
| 6. Lastly, we want to use `deploy.labels` and remove the `ports:` definition, to tell Traefik to forward requests to Matomo based on hostname and generate an SSL certificate. | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| --- | ||||
| title: Operations handbook | ||||
| title: Operators Handbook | ||||
| --- | ||||
|  | ||||
| ## Understanding `~/.abra` | ||||
| @ -163,11 +163,11 @@ So, given how [secret versions](/operators/handbook/#secret-versions) work, here | ||||
| 1. Find out the current version number of the secret, e.g. by running `abra app config <domain>`, and choose a new one. Let's assume it's currently `v1`, so by convention the new secret will be `v2` | ||||
| 2. Generate or insert the new secret: `abra app secret generate <domain> db_password v2` or `abra app secret insert <domain> db_password v2 "foobar"` | ||||
| 3. Edit the app configuration to change which secret version the app will use: `abra app config <domain>` | ||||
| 4. Re-reploy the app with the new secret version: `abra app deploy <domain>` | ||||
| 4. Re-deploy the app with the new secret version: `abra app deploy <domain>` | ||||
|  | ||||
| ### Storing secrets in `pass` | ||||
|  | ||||
| The Co-op Cloud authors use the [UNIX `pass` tool][pass] to share sensitive data, including Co-op Cloud secrets, and `abra app secret ...` commands include a `--pass` option to automatically manage generated / inserted secrets: | ||||
| The Co-op Cloud authors use the [UNIX `pass` tool](https://www.passwordstore.org) to share sensitive data, including Co-op Cloud secrets, and `abra app secret ...` commands include a `--pass` option to automatically manage generated / inserted secrets: | ||||
|  | ||||
| ``` | ||||
| # Store generated secrets in `pass`: | ||||
| @ -191,31 +191,19 @@ This functionality currently relies on our specific `pass` storage conventions; | ||||
|  | ||||
| ### Traefik networking | ||||
|  | ||||
| [Traefik](https://doc.traefik.io/traefik/) is our core web proxy, all traffic on a Co-op Cloud deployment goes through a running Traefik container. When setting up a new Co-op Cloud delpyment, `abra` creates a "global" [overlay network](https://docs.docker.com/network/overlay/) which traefik is hooked up to. This is the network that other apps use to speak to traefik and get traffic routed to them. Not every service in every app is also included in this network and hence not internet-facing (by convention, we name this network `internal`, see more below). | ||||
| [Traefik](https://doc.traefik.io/traefik/) is our core web proxy, all traffic on a Co-op Cloud deployment goes through a running Traefik container. When setting up a new Co-op Cloud deployment, `abra` creates a "global" [overlay network](https://docs.docker.com/network/overlay/) which traefik is hooked up to. This is the network that other apps use to speak to traefik and get traffic routed to them. Not every service in every app is also included in this network and hence not internet-facing (by convention, we name this network `internal`, see more below). | ||||
|  | ||||
| ### App networking | ||||
|  | ||||
| By convention, the main `app` service is wired up to the "global" traefik overlay network. This container is the one that should be publicy reachable on the internet. The other services in the app such as the database and caches should be not be publicly reachable or visible to other apps on the same instance. | ||||
| By convention, the main `app` service is wired up to the "global" traefik overlay network. This container is the one that should be publicy reachable on the internet. The other services in the app such as the database and caches should not be publicly reachable or visible to other apps on the same instance. | ||||
|  | ||||
| To deal with this, we make an additional "internal" network for each app which is namespaced to that app. So, if you deploy a Wordpress instance called `my_wordpress_blog` then there will be a network called `my_wordpress_blog_internal` created. This allows all the services in an app to speak to each other but not be reachable on the public internet. | ||||
|  | ||||
| ## Multiple apps on the same domain? | ||||
|  | ||||
| At time of writing (Jan 2022), we think there is a limitation in our design which doesn't support multiple apps sharing the same domain (e.g. `example.com/app1/` & `example.com/app2/`). `abra` treats each domain as unique and as the singler reference for a single app. | ||||
| At time of writing (Jan 2022), we think there is a limitation in our design which doesn't support multiple apps sharing the same domain (e.g. `example.com/app1/` & `example.com/app2/`). `abra` treats each domain as unique and as the single reference for a single app. | ||||
|  | ||||
| This may be possible to overcome if someone really needs it, we encourage people to investigate. We've found that often, there are limitations in the actual software which don't support this anyway and several of the current operators simply use a new domain per app. | ||||
|  | ||||
| ## Validating `abra` binary checksums | ||||
|  | ||||
|  You can download `abra` yourself from the [releases page](https://git.coopcloud.tech/coop-cloud/abra/releases) along with the `checksums.txt` file. | ||||
|  | ||||
| ```bash | ||||
| grep $(sha256sum abra_[version]_[platform]) checksums.txt > /dev/null && echo "checksum OK" | ||||
| ``` | ||||
|  | ||||
| If "checksum OK" appears in your terminal - you're good to go! | ||||
|  | ||||
| Otherwise, you have downloaded a corrupted file. | ||||
| This may be possible to overcome if someone really needs it, we encourage people to investigate. We've found that often there are limitations in the actual software which don't support this anyway and several of the current operators simply use a new domain per app. | ||||
|  | ||||
| ## Creating a new server | ||||
|  | ||||
| @ -264,7 +252,7 @@ systemctl restart docker containerd | ||||
|  | ||||
| `abra` supports creating, listing and removing DNS entries if the 3rd party integration supports it. | ||||
|  | ||||
| If you want to teach `abra` how to support your favourite server hosting provider, we'd glady accept patches. | ||||
| If you want to teach `abra` how to support your favourite DNS service provider, we'd glady accept patches. | ||||
|  | ||||
| ## How do I persist container logs after they go away? | ||||
|  | ||||
| @ -314,7 +302,7 @@ Also, for more system wide analysis stuff: | ||||
|  | ||||
| `abra` uses plain 'ol SSH under the hood and aims to make use of your existing SSH configurations in `~/.ssh/config` and interfaces with your running `ssh-agent` for password protected secret key files. | ||||
|  | ||||
| The `server add` command listed above assumes that that you make SSH connections on port 22 using your current username. If that is not he case, pass the new values as positional arguments. See `abra server add -h` for more on this. | ||||
| The `server add` command listed above assumes that that you make SSH connections on port 22 using your current username. If that is not the case, pass the new values as positional arguments. See `abra server add -h` for more on this. | ||||
|  | ||||
| ```bash | ||||
| abra server add <domain> <user> <port> -p | ||||
|  | ||||
| @ -1,8 +1,23 @@ | ||||
| --- | ||||
| title: Operators Guide | ||||
| title: Operators | ||||
| --- | ||||
|  | ||||
| Welcome to the operators guide! Operators are typically individuals, members of tech co-ops or collectives who provide services powered by Co-op Cloud. This documentation is meant to help new & experienced operators manage their deployments as well as provide a space for sharing tricks & tips for keeping things running smoothly. Operators are encouraged to submit documentation patches! Sharing is caring :sparkling_heart: | ||||
| Welcome to the operators guide! Operators are typically individuals, members of tech co-ops or collectives who provide services powered by Co-op Cloud. This documentation is meant to help new & experienced operators manage their deployments as well as provide a space for sharing tricks & tips for keeping things running smoothly. | ||||
|  | ||||
| - [New operators tutorial](/operators/tutorial): If you want to become an operator, start here :rocket: | ||||
| - [Operations handbook](/operators/handbook): One-stop shop for all you need to know to manage a deployment :ribbon: | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __New Operators Tutorial__ | ||||
|  | ||||
|     If you want to become an operator, start your journey here :rocket: | ||||
|  | ||||
|     [Get started](tutorial.md){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Operators Handbook__ | ||||
|  | ||||
|     One-stop shop for all you need to know to manage a deployment :ribbon: | ||||
|  | ||||
|     [Read Handbook](handbook.md){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| Operators are encouraged to submit documentation patches! Sharing is caring :sparkling_heart: | ||||
|  | ||||
| @ -1,83 +1,8 @@ | ||||
| --- | ||||
| title: New operators tutorial | ||||
| title: New Operators Tutorial | ||||
| --- | ||||
|  | ||||
| ## The moving parts | ||||
|  | ||||
| Co-op Cloud is made up of a few simple, composable pieces. The system does not rely on any one specific implementation: each part may be replaced and/or extended as needed. | ||||
|  | ||||
| We want to build a resilient and long-term sustainable project and that means allowing for different implementations, open formats and a diverse project organisation. | ||||
|  | ||||
| Here are the main technical concepts listed below, once you [grok](https://en.wikipedia.org/wiki/Grok) this, you grok the moving parts of the entire project. You can then move on to [deploying your first app](/operators/tutorial/#deploy-your-first-app). | ||||
|  | ||||
| ### Libre software apps | ||||
|  | ||||
| Libre software apps are tools, websites & software clients that you may already use in your daily life: [Nextcloud], [Jitsi], [Mediawiki], [Rocket.chat] and [many more]! | ||||
|  | ||||
| These are tools that are created by volunteer communities who use [free software licenses] in order to build up the public software commons and offer more digital alternatives to [proprietary systems]. | ||||
|  | ||||
| The communities who develop these softwares also publish them using [containers]. For example, here is the [Nextcloud hub.docker.com account] which allows end-users to quickly deploy a new Nextcloud instance. | ||||
|  | ||||
| There is a growing consensus in the free software community that containers are a useful and time saving format for distribution. | ||||
|  | ||||
| !!! question "Why did you choose to use containers?" | ||||
|  | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-containers). | ||||
|  | ||||
| [nextcloud]: https://nextcloud.com | ||||
| [jitsi]: https://jitsi.org | ||||
| [mediawiki]: https://mediawiki.org | ||||
| [rocket.chat]: https://rocket.chat | ||||
| [many more]: /recipes/ | ||||
| [free software licenses]: https://www.gnu.org/philosophy/free-sw.html | ||||
| [nextcloud hub.docker.com account]: https://hub.docker.com/_/nextcloud | ||||
| [proprietary systems]: https://en.wikipedia.org/wiki/Proprietary_software | ||||
| [containers]: https://www.docker.com/resources/what-container | ||||
|  | ||||
| ### The recipe packaging format | ||||
|  | ||||
| However, just having a container of an app is often not enough. The work required to deploy that app in a "production ready" setup is still too time intensive and often involves a duplication of effort. | ||||
|  | ||||
| Each service provider needs to deal with the same problems: stable versioning, backup plan, secret management, upgrade plan, monitoring and the list goes on. | ||||
|  | ||||
| Individual free software projects can't take on all this responsibility. They provide the containers as is, in a secure and ready-to-go manner but it is up to service providers to worry about how the app is deployed. | ||||
|  | ||||
| Therefore, Co-op Cloud proposes a packaging format, which we refer to as a recipe, that describes the entire production state of the app in a single place. This format uses the existing [standards based compose specification]. | ||||
|  | ||||
| This is a file format which is most commonly used by the [Docker compose] tool but Co-op Cloud **does not** require the use of Docker compose itself. Furthermore, as described below, we also don't rely on the actual Docker CLI itself either. We do however use a lot of the underlying libraries. | ||||
|  | ||||
| !!! question "Why did you choose to use the compose specificiation?" | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-use-the-compose-specification). | ||||
|  | ||||
| [Each recipe] that Co-op cloud provides is described using the compose specification and makes use of the upstream project published container when possible (sometimes they don't publish one!). | ||||
|  | ||||
| This is the core of our approach to working with the ecosystem of free software communities. We want to maximise the chances of sharing work, knowledge and build solidarity through concrete co-operation. | ||||
|  | ||||
| [standards based compose specification]: https://compose-spec.io | ||||
| [docker compose]: https://docs.docker.com/compose/ | ||||
| [each recipe]: /recipes/ | ||||
|  | ||||
| ### Container orchestrator | ||||
|  | ||||
| Once we have our app packaged as a recipe, we need a deployment environment (e.g. a server & something to keep the containers running). Production deployments are typically expected to support a number of features which give hosters and end-users guarantees for stability. | ||||
|  | ||||
| The Co-op cloud makes use of [Docker swarm] as a deployment environment. It offers an approriate feature set which allows us to support zero-down time upgrades, seamless app rollbacks, automatic deploy failure handling, scaling, hybrid cloud setups and maintain a decentralised design. | ||||
|  | ||||
| !!! question "Why did you choose to use Docker Swarm?" | ||||
|  | ||||
|     Learn more [in the FAQ section](/intro/faq/#why-docker-swarm). | ||||
|  | ||||
| [docker swarm]: https://docs.docker.com/engine/swarm/ | ||||
|  | ||||
| ### Command-line tool | ||||
|  | ||||
| Finally, we need a tool to read the recipe package format and actually deploy the app. For this, we have developed and published the [abra] command-line tool. | ||||
|  | ||||
| `abra` aims at providing a simple command-line interface for managing your own Co-op Cloud. You can bootstrap machines with the required tools, create new apps and deploy them. `abra` is written in [Go](https://go.dev/) and uses a lot of the libraries that the `docker` and `docker-compose` CLIs use but does not rely on those interfaces directly. | ||||
|  | ||||
| `abra` is our flagship command-line client but it does not need to be the only client. `abra` was designed in such a way that it complements a workflow which can still be done completely manually. If Co-op Cloud goes away tomorrow, our configuration commons would still be useful and usable. | ||||
|  | ||||
| [abra]: /abra/ | ||||
| This tutorial assumes you understand the [frequently asked questions](/intro/faq/) as well as [the moving parts](/intro/strategy/) of the technical problems _Co-op Cloud_ solves. If yes, proceed :smile: | ||||
|  | ||||
| ## Deploy your first app | ||||
|  | ||||
| @ -86,11 +11,14 @@ In order to deploy an app you need two things: | ||||
| 1. a server with SSH access and a public IP address | ||||
| 2. a domain name pointing to that server | ||||
|  | ||||
| The tutorial tries to help you make choices about which server and which DNS setup you need to run a Co-op Cloud deployment but it does not go into great depth about how to set up a new server. | ||||
| This tutorial tries to help you make choices about which server and which DNS setup you need to run a _Co-op Cloud_ deployment but it does not go into great depth about how to set up a new server. | ||||
|  | ||||
| !!! question "Can `abra` help automate this?" | ||||
| ??? question "Can `abra` help automate this?" | ||||
|  | ||||
|     `abra` can help bootstrap new servers & configure DNS records for you. We'll skip that for now since we're just getting started. See the [operators handbook](/operators/handbook) for more on these topics after you finish the tutorial. | ||||
|     Our `abra` tool can help bootstrap new servers & configure DNS records for | ||||
|     you. We'll skip that for now since we're just getting started. For more on | ||||
|     these topics after you finish the tutorial see the [operators | ||||
|     handbook](/operators/handbook). | ||||
|  | ||||
| ### Server setup | ||||
|  | ||||
| @ -116,7 +44,7 @@ docker swarm init | ||||
| docker network create -d overlay proxy | ||||
| ``` | ||||
|  | ||||
| !!! question "Do you support multiple web proxies?" | ||||
| ??? question "Do you support multiple web proxies?" | ||||
|  | ||||
|     We do not know if it is feasible and convenient to set things up on an existing server with another web proxy which uses ports `:80` & `:443`. We'd happily receive reports and documentation on how to do this if you manage to set it up! | ||||
|  | ||||
| @ -131,36 +59,43 @@ Your entries in your DNS provider setup might look like the following. | ||||
|  | ||||
| Where `116.203.211.204` can be replaced with the IP address of your server. | ||||
|  | ||||
| !!! question "How do I know my DNS is working?" | ||||
| ??? question "How do I know my DNS is working?" | ||||
|  | ||||
|     You can use a tool like `dig` on the command-line to check if your server has the necessary DNS records set up. Something like `dig +short <domain>` should show the IP address of your server if things are working. | ||||
|  | ||||
| ### Command-line setup | ||||
| ### Install `abra` | ||||
|  | ||||
| #### Install `abra` | ||||
|  | ||||
| Now we can install [`abra`](/abra) locally on your machine and hook it up to your server. | ||||
|  | ||||
| We support a script-based installation method (script source [here](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/scripts/installer/installer)): | ||||
| Now we can install [`abra`](/abra) locally on your machine and hook it up to | ||||
| your server. We support a script-based installation method ([script source](https://git.coopcloud.tech/coop-cloud/abra/src/branch/main/scripts/installer/installer)): | ||||
|  | ||||
| ```bash | ||||
| curl https://install.abra.coopcloud.tech | bash | ||||
| ``` | ||||
|  | ||||
| The installer will verify the downloaded binary checksum. You may need to add the `~/.local/bin/` directory with your `$PATH` in order to run the executable. You can validate that everything is in working order by listing the default help output: | ||||
| The installer will verify the downloaded binary checksum. If you prefer, you can | ||||
| [manually verify](/abra/install/#manual-verification) the binary, and then | ||||
| manally place it in one the directories in your `$PATH` variable. To validate | ||||
| that everything is working try listing the `--help` command or `-h` to view | ||||
| output: | ||||
|  | ||||
| ```bash | ||||
| abra -h  | ||||
| ``` | ||||
|  | ||||
| You may need to add the `~/.local/bin/` directory to your `$PATH` variable, in | ||||
| order to run the executable. | ||||
|  | ||||
| ```bash | ||||
| export PATH=$PATH:$HOME/.local/bin | ||||
| abra -h # check it works | ||||
| ``` | ||||
|  | ||||
| If you run into issues during installation, [please report a ticket](https://git.coopcloud.tech/coop-cloud/abra/issues/new) :pray: Once you're all set up, we **highly** recommend configuring command-line auto-completion for `abra`. See `abra autocomplete -h` for more on how to do this. | ||||
| If you run into issues during installation, [please report a ticket](https://git.coopcloud.tech/coop-cloud/organising/issues/new) :pray: Once you're all set up, we **highly** recommend configuring command-line auto-completion for `abra`. See `abra autocomplete -h` for more on how to do this. | ||||
|  | ||||
| !!! question "Can I install `abra` on my server?" | ||||
| ??? question "Can I install `abra` on my server?" | ||||
|  | ||||
|     Yes, this is possible, see [this handbook entry](/operators/handbook/#running-abra-server-side) for more. The instructions for setup are a little different however. | ||||
|     Yes, this is possible. However, the instructions for this setup are different. For more info see [this handbook entry](/operators/handbook/#running-abra-server-side). | ||||
|  | ||||
| #### Add your server | ||||
| ### Add your server | ||||
|  | ||||
| Now you can connect `abra` with your server. You should have a working SSH configuration before you can do this (e.g. a matching `Host <server-domain>` entry in `~/.ssh/config` with the correct SSH connection details). That means you can run `ssh <server-domain>` on your command-line and everything Works :tm:. | ||||
|  | ||||
| @ -173,21 +108,26 @@ It is important to note that `<domain>` here is a publicy accessible domain name | ||||
|  | ||||
| You will now have a new `~/.abra/` folder on your local file system which stores all the configuration of your Co-op Cloud instance. | ||||
|  | ||||
| `abra` should now register this server as managed in your server listing: | ||||
| By now `abra` should have registered this server as managed. To confirm this run: | ||||
|  | ||||
| ``` | ||||
| abra server ls | ||||
| ``` | ||||
|  | ||||
| !!! warning "Beware of SSH dragons" | ||||
| ??? warning "Beware of SSH dragons :dragon_face:" | ||||
|  | ||||
|     `abra` uses plain 'ol SSH under the hood and aims to make use of your existing SSH configurations in `~/.ssh/config` and interfaces with your running `ssh-agent` for password protected secret key files. | ||||
|     Under the hood `abra` uses plain 'ol `ssh` and aims to make use of your | ||||
|     existing SSH configurations in `~/.ssh/config` and interfaces with your | ||||
|     running `ssh-agent` for password protected secret key files. | ||||
|  | ||||
|     Running `server add` with `-d/--debug` should help you debug what is going on under the hood. It's best to take a moment to read [this troubleshooting entry](/abra/trouble/#ssh-connection-issues) if you're running into SSH connection issues with `abra`. | ||||
|     Running `server add` with `-d` or `--debug` should help you debug what is going | ||||
|     on under the hood. If you're running into SSH connection issues with `abra` | ||||
|     take a moment to read [this troubleshooting | ||||
|     entry](/abra/trouble/#ssh-connection-issues). | ||||
|  | ||||
| !!! question "How do I share my configs in `~/.abra`?" | ||||
| ??? question "How do I share my configs in `~/.abra`?" | ||||
|  | ||||
|     It's possible and quite easy, see [this handbook entry](/operators/handbook/#understanding-app-and-server-configuration) for more. | ||||
|     It's possible and quite easy, for more see [this handbook entry](/operators/handbook/#understanding-app-and-server-configuration). | ||||
|  | ||||
| ### Web proxy setup | ||||
|  | ||||
| @ -227,7 +167,7 @@ abra app new nextcloud -S | ||||
|  | ||||
| The `-S` or `--secrets` flag is used to generate secrets for the app: database connection password, root password and admin password. | ||||
|  | ||||
| !!! warning "Beware of password dragons" | ||||
| ??? warning "Beware of password dragons :dragon:" | ||||
|  | ||||
|     Take care, these secrets are only shown once on the terminal so make sure to take note of them! `abra` makes use of the [Docker secrets](/operators/handbook/#managing-secret-data) mechanism to ship these secrets securely to the server and store them as encrypted data. Only the apps themselves have access to the values from here on, they're placed in `/run/secrets` on the container file system. | ||||
|  | ||||
|  | ||||
| @ -0,0 +1,5 @@ | ||||
| --- | ||||
| title: Culture of Solidarity (ECF) | ||||
| --- | ||||
|  | ||||
| > **TODO** | ||||
							
								
								
									
										535
									
								
								docs/organisers/funding-applications/ford-foundation.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										535
									
								
								docs/organisers/funding-applications/ford-foundation.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,535 @@ | ||||
| --- | ||||
| title: Ford foundation | ||||
| --- | ||||
|  | ||||
| # Ford foundation | ||||
|  | ||||
| > Status: **pending** | ||||
|  | ||||
| * [Previous material](https://notes.bonfire.cafe/nlnet-bonfire-coopcloud-hosting) | ||||
| * [Application](https://fordfoundation.forms.fm/2023-digital-infrastructure-insights-fund-rfp/forms/9724) | ||||
|  | ||||
| ## Is this concept note primarily focused on research or implementation? | ||||
|  | ||||
| - Implementation | ||||
|  | ||||
| ## What is your research question? (30 words) | ||||
|  | ||||
| How can an open co-operative ecosystem foster a sustainable, resilient | ||||
| infrastructure for FLOSS (Free/Libre Open Source software) development, | ||||
| hosting, and tech support, while enhancing data ownnership, transparency and | ||||
| co-operation? | ||||
|  | ||||
| ## Why is this question important to answer and how does it relate to our fund? (500 words) | ||||
|  | ||||
| This is a challenge of paramount importance as it aims to design and test a | ||||
| model for a sustainable, resilient open co-operative ecosystem amidst a digital | ||||
| landscape overshadowed by large centralized profit-driven entities. | ||||
|  | ||||
| The hegemony of a few colossal platforms has led to myriad challenges | ||||
| including, but not limited to, data privacy infringements, misinformation | ||||
| dissemination, and a significant digital divide. Such challenges thwart the | ||||
| internet's potential to act as a public commons and hinder the growth of a | ||||
| democratic, open, and inclusive digital infrastructure. | ||||
|  | ||||
| The envisioned open co-operative ecosystem is a step towards remedying the | ||||
| prevalent issues of centralization and lack of inclusivity in the digital | ||||
| domain. It proposes a holistic approach encompassing technical innovation, | ||||
| co-operative economics, and community-centric governance - where software, | ||||
| infrastructure and communities are not isolated entities, but are part of a | ||||
| common ecosystem. | ||||
|  | ||||
| This aligns profoundly with this fund's objective of exploring and remedying | ||||
| the issues of under-maintenance and occasional undermining of FLOSS. The | ||||
| proposed self-sustaining economic model is aimed at ensuring the longevity and | ||||
| resilience of both the open co-operative ecosystem and all the actors involved: | ||||
| FLOSS developers and designers, sysadmins and hosting providers, and all the | ||||
| other figures that struggle to reach sustainability by working in and for the | ||||
| FLOSS sector. | ||||
|  | ||||
| Furthermore, the proposed project is not merely a technical endeavor but a | ||||
| multi-dimensional initiative aimed at fostering a digital infrastructure that | ||||
| is equitable, sustainable, secure, and entrenched in the public interest. | ||||
|  | ||||
| Our proposed integration aims to simplify the setup, hosting and operating of | ||||
| FLOSS software, through an open dashboard that automates the whole software | ||||
| life cycle. This dashboard will act as a gateway to an ecosystem of developers | ||||
| and hosting providers, which will work together to provide users and | ||||
| communities with: | ||||
|  | ||||
| - Openness: Designers, developers, and sysadmins can join the ecosystem to | ||||
|   provide services and receive compensation; | ||||
|  | ||||
| - Mutualism: Projects and communities that meet specific criteria may exchange | ||||
|   services in-kind, or benefit from special rates; | ||||
|  | ||||
| - Flexibility: From a personal instance to a large community, the open | ||||
|   ecosystem will guide the user based on their specific needs and budget; | ||||
|  | ||||
| - Inclusivity: Users and communities can collectively shape the ecosystem's | ||||
|   roadmaps, by co-designing and funding desired features. | ||||
|  | ||||
| From the other side, the dashboard will also operate as an economic network to | ||||
| track each contribution and distribute the available funds according to value | ||||
| equation formulas as democratically defined by the ecosystem stakeholders. | ||||
|  | ||||
| ## What research methods will you use to answer this question? (Please describe the methodologies and scope of your proposed research (500 words)) | ||||
|  | ||||
| To comprehensively address the research question, a blend of interdisciplinary | ||||
| methods will be employed to ensure a thorough analysis, development, and | ||||
| evaluation of the proposed integrated Bonfire and Co-op Cloud ecosystem. The | ||||
| methodologies are outlined as follows: | ||||
|  | ||||
| - Literature Review: | ||||
|  | ||||
| An extensive literature review will be conducted to gather insights on existing | ||||
| models of open co-operative ecosystems, challenges and best practices in FLOSS | ||||
| development, hosting, and funding, and the impact of decentralized digital | ||||
| infrastructures on promoting inclusivity and co-operation. | ||||
|  | ||||
| - Surveys & Interviews: | ||||
|  | ||||
| By using mixed methods we aim to gather insights from relevant parties such as | ||||
| instance administrators, app maintainers, and FOSS contributors. | ||||
|  | ||||
| - User-Centered Design (UCD): | ||||
|  | ||||
| Utilizing UCD principles, we will engage potential users and stakeholders in | ||||
| the design and development process. This will include conducting surveys, | ||||
| interviews, and usability testing to gather user requirements, preferences, and | ||||
| feedback on prototype iterations. | ||||
|  | ||||
| - Technical Development and Prototyping: | ||||
|  | ||||
| The core of the research involves the technical development and prototyping of | ||||
| the integrated dashboard that facilitates the setup, hosting, and operation of | ||||
| custom Bonfire instances (the first FOSS application to be integrated in the | ||||
| open dashboard). Agile development methodologies, including iterative design | ||||
| and development cycles, will be employed to ensure a user-centric approach and | ||||
| to allow for continuous feedback and improvement. | ||||
|  | ||||
| - Case Studies: | ||||
|  | ||||
| Detailed case studies of relevant initiatives will be conducted to glean | ||||
| insights into best practices, challenges, and success factors. Comparative | ||||
| analysis will help in understanding the potential impact and sustainability of | ||||
| the proposed ecosystem. We already have communities willing to participate in | ||||
| these case studies, that span from citizen science projects | ||||
| (https://niboe.info), hacker spaces (https://www.facebook.com/Zer081), | ||||
| bioregional communities (driftless area), and more... | ||||
|  | ||||
| - Economic Modeling: | ||||
|  | ||||
| Economic modeling will be employed to devise a transparent value equation for | ||||
| revenue distribution among stakeholders. This will also involve exploring | ||||
| sustainable funding models that ensure the longevity and resilience of the | ||||
| proposed ecosystem. We will make use of the ValueFlows protocol to test several | ||||
| value equations: https://www.valueflo.ws/algorithms/equations/ | ||||
|  | ||||
| - Policy and Legal Analysis: | ||||
|  | ||||
| An examination of the policy and legal frameworks that could impact, or be | ||||
| impacted by, the proposed ecosystem will be conducted. This includes analyzing | ||||
| data privacy laws, open-source licensing, and cooperative economic regulations. | ||||
|  | ||||
| - Dissemination and Feedback: | ||||
|  | ||||
| Sharing the findings and prototypes with the broader community through various | ||||
| channels including conferences, blog posts, social media, and project websites | ||||
| for feedback and further refinement. | ||||
|  | ||||
| ## What data or other resources will you use to answer the question? (500 words) | ||||
|  | ||||
| - Domain Experts and Stakeholder Interviews: | ||||
|  | ||||
| Insights from domain experts in FLOSS development, digital co-operatives, | ||||
| hosting solutions, and decentralized digital infrastructures. Interviews with | ||||
| stakeholders including developers, hosting providers, and potential users of | ||||
| the proposed ecosystem. | ||||
|  | ||||
| - Economic Models and Financial Data: | ||||
|  | ||||
| Economic models pertinent to revenue distribution, funding, and sustainability | ||||
| of open cooperative ecosystems. Financial data of similar initiatives to | ||||
| understand their economic sustainability and impact. | ||||
|  | ||||
| - Legal and Policy Documents: | ||||
|  | ||||
| Legal documents, open-source licenses, and policy frameworks relevant to data | ||||
| privacy, digital rights, and co-operative economic structures. | ||||
|  | ||||
| - Technical Documentation: | ||||
|  | ||||
| Technical documentation of Bonfire, Co-op Cloud, and other open-source projects | ||||
| pertinent to the research. Documentation on protocols, standards, and best | ||||
| practices in FLOSS development, hosting, and support. | ||||
|  | ||||
| - Open Source Software Repositories: | ||||
|  | ||||
| Access to open-source software repositories to study existing solutions, | ||||
| libraries, and frameworks that could be leveraged for the technical development | ||||
| of the proposed ecosystem. | ||||
|  | ||||
| - Prototyping Tools and Development Platforms: | ||||
|  | ||||
| Utilization of prototyping tools and development platforms for designing, | ||||
| developing, and testing the integrated dashboard and associated features. | ||||
|  | ||||
| ## If applicable: What is the research finding that you are moving into practice? (500 words) | ||||
|  | ||||
| The findings we are acting upon highlight the pressing necessity for a digital | ||||
| ecosystem that prioritizes sustainability, decentralization, and cooperation | ||||
| while advancing open-source software development, hosting, support, and | ||||
| funding. | ||||
|  | ||||
| Existing research and case studies have highlighted the challenges posed by the | ||||
| large centralized and profit-driven digital platforms, which often compromise | ||||
| data privacy, inclusivity, and the democratic ethos of the digital realm. | ||||
|  | ||||
| Noteworthy findings from prior researches that underpin our project include: | ||||
|  | ||||
| - Co-operative Ecosystems: | ||||
|  | ||||
| Research on co-operative models -- notably "Proposal for a Cooperative Model | ||||
| for Digital Infrastructure and Recommendations to Adopt It" by Tierra Comun in | ||||
| 2022 -- has revealed the potential for fostering sustainable and equitable | ||||
| digital ecosystems. Co-operative structures, grounded in principles of | ||||
| mutualism and collective governance, have shown promise in promoting economic | ||||
| sustainability and community-centric development. | ||||
|  | ||||
| - Need for Decentralization: | ||||
|  | ||||
| Studies have underscored the benefits of decentralized digital infrastructures | ||||
| in promoting data sovereignty, reducing censorship, and fostering innovation | ||||
| through open standards and interoperability as well as ("Accounting and Billing | ||||
| for Federated Cloud Infrastructures", Elmroth et al., 2009 Eighth International | ||||
| Conference on Grid and Cooperative Computing) the specific challenges in | ||||
| tracking and distributing financial costs across these decentralized networks. | ||||
|  | ||||
| - Open Source as a Public Good: | ||||
|  | ||||
| The literature has extensively documented the value of FLOSS as a public good, | ||||
| which can drive down costs, promote technical innovation, and foster a shared | ||||
| digital commons. | ||||
|  | ||||
| - Challenges in FLOSS Sustainability: | ||||
|  | ||||
| Several reports (e.g. "Roads and Bridges: The Unseen Labor Behind Our Digital | ||||
| Infrastructure", Nadia Eghbal, "The labor of maintaining and scaling free and | ||||
| open-source software projects", Geiger et al, Proceedings of the ACM on | ||||
| human-computer interaction 5.CSCW1, and "The coproduction of open source | ||||
| software by volunteers and big tech firms", O'Neil et al., News and Media | ||||
| Research Centre, 2021) have highlighted the challenges in sustaining open | ||||
| source projects, often due to lack of funding, technical support, and a viable | ||||
| economic model. | ||||
|  | ||||
| - User-Centric Design: | ||||
|  | ||||
| The importance of user-centric design in the development of digital platforms | ||||
| to ensure accessibility, usability, and adoption has been well-documented. | ||||
|  | ||||
| - Community Engagement: | ||||
|  | ||||
| Engaging communities in design, development, and governance of platforms has | ||||
| been found to promote inclusivity, trust, and long-term sustainability. | ||||
|  | ||||
| Moving these findings into practice, our proposal outlines a collaborative | ||||
| endeavor between Bonfire and Co-op Cloud to develop an integrated open | ||||
| dashboard that automates the setup, hosting, and operation of custom Bonfire | ||||
| instances. | ||||
|  | ||||
| Practical implementations include: | ||||
|  | ||||
| - Developing a technical infrastructure that facilitates decentralized hosting | ||||
|   and operation of digital platforms, reducing reliance on centralized | ||||
|   entities. | ||||
|  | ||||
| - Establishing a co-operative economic model to ensure the financial | ||||
|   sustainability of the ecosystem, based on a transparent value equation for | ||||
|   revenue distribution among stakeholders. | ||||
|  | ||||
| - Engaging the community and potential users in the design and development | ||||
|   process to ensure the ecosystem meets their needs and preferences. | ||||
|  | ||||
| - Fostering a collaborative environment where developers, hosting providers, | ||||
|   and users can mutually benefit from the shared digital infrastructure. | ||||
|  | ||||
| - Implementing user-centric design principles to ensure the accessibility and | ||||
|   usability of the open dashboard, thus promoting broader adoption. | ||||
|  | ||||
| - Disseminating the developed prototypes and findings to the broader community | ||||
|   for feedback, further refinement, and adoption. | ||||
|  | ||||
| ## What is the specific context / project / community that will be targeted with your research or its implementation - and why is it needed? (600 words) | ||||
|  | ||||
| RESEARCH (Phase 1): | ||||
|  | ||||
| A study on "Understanding the Open Infrastructure Ecosystem, with a Focus on | ||||
| Federation," will set about comprehensively exploring practices and challenges | ||||
| within the Federated ("Fediverse") and FOSS communities, It will investigate | ||||
| co-design and development, documentation and onboarding, hosting, | ||||
| configuration, maintenance, tech support, continuous integration, deployment | ||||
| and upgrades, backups, community feedback and bug reporting, and governance. | ||||
|  | ||||
| This vital research addresses the centralization and monopolization of | ||||
| platforms, barriers to entry, sustainability challenges, community empowerment, | ||||
| knowledge sharing, and resilience and longevity of FOSS projects, to provide a | ||||
| holistic understanding of the open infrastructure ecosystem. | ||||
|  | ||||
| We hope to identify common challenges faced by these communities, exploring | ||||
| motivations for contributing or maintaining infrastructure, uncovering best | ||||
| practices and potential solutions. | ||||
|  | ||||
| IMPLEMENTATION (Phase 2): | ||||
|  | ||||
| This above study will inform the development of a federated and cooperative | ||||
| hosting ecosystem, helping to better align with the specific needs of instance | ||||
| administrators, app maintainers and FOSS contributors. By initially focusing on | ||||
| federated platforms and progresstively expanding to the broader ecosystem of | ||||
| open infrastructure, the ecosystem can foster collaboration, enhance community | ||||
| support, and contribute to the overall growth and sustainability of the | ||||
| Fediverse and FOSS communities. | ||||
|  | ||||
| The implementation will start with Co-op Cloud, a software stack that | ||||
| simplifies the hosting of FOSS applications, and Bonfire, a federated social | ||||
| networking toolkit. These projects represent a microcosm of the broader open | ||||
| source and cooperative ecosystem, and can serve as the initial building blocks | ||||
| for user-friendly solutions and transparent, cooperative economic models, | ||||
| ensuring accessibility and autonomy for all users. | ||||
|  | ||||
| This phase serves as a pragmatic step towards addressing identified needs, like | ||||
| reducing technical barriers, fostering sustainability, and empowering | ||||
| communities. It embodies a proactive shift towards a more decentralized, | ||||
| cooperative, and equitable digital landscape, in response to the pressing | ||||
| challenges and unmet needs within the FLOSS community and the broader digital | ||||
| realm, and actively combats the issues of centralization, data control, and | ||||
| sustainable revenue models, benefiting open source projects and communities | ||||
| alike. | ||||
|  | ||||
| The integration of Bonfire and Co-op Cloud via a user-friendly dashboard will | ||||
| significantly lower the technical barrier to entry, allowing a broader spectrum | ||||
| of users to set up, host, and operate their own instances. Engaging their | ||||
| communities, as well as the broader FLOSS community, in the design, | ||||
| development, and governance of the proposed ecosystem to ensure it meets the | ||||
| diverse needs and preferences of its stakeholders. | ||||
|  | ||||
| We'll also craft transparent value equations and economic models to foster a | ||||
| sustainable, co-operative economic ecosystem where revenues are fairly | ||||
| distributed among developers, hosting providers, and others. | ||||
|  | ||||
| DISSEMINATION (Phase 3): | ||||
|  | ||||
| Research findings will be compiled into a comprehensive report, offering | ||||
| valuable insights to guide the evolution of the hosting ecosystem and | ||||
| contribute to the knowledge base of open infrastructure practices and | ||||
| challenges. This knowledge will be shared with the FOSS community and beyond, | ||||
| promoting wider dialogue, feedback, and collaboration. This approach aligns | ||||
| with the need for alternative economic models, transparency, and equitable | ||||
| value distribution, and addresses the challenges of the current digital | ||||
| landscape by advocating for decentralized, cooperative, and equitable | ||||
| alternatives. | ||||
|  | ||||
| ## Please summarize your proposed work and the key activities that you will undertake (500 words) | ||||
|  | ||||
| - Resarch study: | ||||
|  | ||||
| A study "Understanding the Open Infrastructure Ecosystem, with a Focus on | ||||
| Federation" will be conducted as detailed above. | ||||
|  | ||||
| - Federation design & development: | ||||
|  | ||||
| We'll write an ecosystem federation proposal and resources to help others build | ||||
| their own. A "start your federation cookbook" with analysis from a technical, | ||||
| economic, legal, and governance perspective. | ||||
|  | ||||
| - Pilots: | ||||
|  | ||||
| We will work with several pilot users and organisations to provide feedback and | ||||
| test our designs and solutions at every stage of the process. The various | ||||
| pilots will help co-designing and test the open dashboard, by setupping custom | ||||
| bonfire instances | ||||
|  | ||||
| - Capacity building and Architecture of Participation: | ||||
|  | ||||
| The capacity building activity will discover together with pilots and | ||||
| participants how to draft a good governance and economic model to make all of | ||||
| this work nicely. | ||||
|  | ||||
| - Protocol and platform integration: | ||||
|  | ||||
| Defining libre, reusable methods and systems for automatic DNS (across various | ||||
| domain name registrars / DNS hosts) and server hosting provisioning (using e.g. | ||||
| https://capsul.org), automated software installation and updates (using Co-op | ||||
| Cloud's command-line tool Abra: https://docs.coopcloud.tech/abra/), backup and | ||||
| data migrations (e.g. using http://tahoe-lafs.org/), user resource usage | ||||
| measurement, payment integration, and dashboard UIs. | ||||
|  | ||||
| - Dissemination and communication: | ||||
|  | ||||
| This activity will focus on communicating with the world about our work, and | ||||
| disseminate project outcomes and results through various channels, including | ||||
| articles, conferences, social media, and project websites. | ||||
|  | ||||
| All the code produced will be documented, and publicly available with an open | ||||
| source license. We will continue our outreach through our respective activity | ||||
| on federated social media platforms including Bonfire itself, Mastodon, | ||||
| Scuttlebutt, and Matrix. | ||||
|  | ||||
| ## What partnerships and programs are critical to this work and how do you envision outreach activities? (400 words) | ||||
|  | ||||
| The proposed integration of Bonfire and Co-op Cloud is significantly enriched | ||||
| by forming strategic partnerships with key entities in the open-source and | ||||
| cooperative digital ecosystem. Here's how these partnerships are critical and | ||||
| the envisioned outreach activities: | ||||
|  | ||||
| - Co-op Cloud Federation: partnership significance: Co-op Cloud Federation is | ||||
|   crucial for implementing the hosting and management of FOSS apps. This | ||||
|   partnership brings in vital technical expertise, hosting solutions, and the | ||||
|   potential for scaling the initiative across a federated network of service | ||||
|   providers. Outreach: Promoting the integrated solution through Co-op Cloud's | ||||
|   federated network, collaborating on joint marketing campaigns, and leveraging | ||||
|   the federation's channels to spread awareness and drive adoption. | ||||
|  | ||||
| - Bonfire Networks: partnership significance: Bonfire Networks provides the | ||||
|   foundational social networking toolkit that will be integrated with Co-op | ||||
|   Cloud. This partnership ensures technical synergy and collaborative | ||||
|   development, fostering an environment conducive to innovation and | ||||
|   user-centric design. Outreach: Engaging the existing community around Bonfire | ||||
|   Networks in workshops, webinars, and forums to introduce the integrated | ||||
|   solution, gather feedback, and foster active participation in its development | ||||
|   and utilization. | ||||
|  | ||||
| - Servers Co-op: partnership Significance: Servers.coop can play a key role as | ||||
|   a hosting provider within the ecosystem, offering reliable and cooperative | ||||
|   hosting solutions to users. Their involvement can help establish a network of | ||||
|   trustworthy hosting providers committed to cooperative principles. Outreach: | ||||
|   Joint campaigns promoting the benefits of cooperative hosting, showcasing | ||||
|   success stories, and educating communities on the advantages of | ||||
|   decentralized, cooperative digital infrastructures. | ||||
|  | ||||
| - Co-operative Computer: partnership Significance: Cooperative Computer can | ||||
|   provide valuable insights, technical expertise, and support in promoting | ||||
|   cooperative digital practices. This partnership can foster a shared learning | ||||
|   environment and potentially lead to collaborative projects enhancing the | ||||
|   integrated solution and actively participating in the open coop ecosystem. | ||||
|   Outreach: Hosting joint educational events, technical workshops, and online | ||||
|   discussions to explore cooperative computing models and their application in | ||||
|   the proposed ecosystem. | ||||
|  | ||||
| ## What is your vision of success and what impact might it have? (400 words) | ||||
|  | ||||
| The vision of success for this initiative revolves around the establishment of | ||||
| a self-sustaining, decentralized, and co-operative digital ecosystem that | ||||
| significantly enhances the accessibility, usability, and economic | ||||
| sustainability of FLOSS for all stakeholders. | ||||
|  | ||||
| The following are the key indicators of success and the potential impact of | ||||
| this initiative: | ||||
|  | ||||
| - Ease of Access and Usability: | ||||
|  | ||||
| A successful implementation of the integrated dashboard that simplifies the | ||||
| setup, hosting, and management of Bonfire instances, enabling a broader | ||||
| spectrum of users, including those with limited technical skills, to leverage | ||||
| FLOSS solutions effortlessly and in a trusted ecosystem. | ||||
|  | ||||
| - Economic Sustainability: | ||||
|  | ||||
| Establishment of a transparent and equitable economic model that ensures fair | ||||
| revenue distribution among developers, hosting providers, and other | ||||
| stakeholders, fostering financial sustainability and continued growth of the | ||||
| Bonfire and Co-op Cloud ecosystems. | ||||
|  | ||||
| - Community Engagement and Governance: | ||||
|  | ||||
| Active engagement of the community in the decision-making processes, | ||||
| development, and governance of the ecosystem, reflecting a vibrant, | ||||
| participatory, and democratic digital co-operative environment. | ||||
|  | ||||
| - Increased Adoption and Experimentation: | ||||
|  | ||||
| A noticeable increase in the adoption of Bonfire and Co-op Cloud solutions, | ||||
| alongside a proliferation of innovative projects and experiments emanating from | ||||
| the co-operative ecosystem, contributing to a richer and more diverse digital | ||||
| commons. | ||||
|  | ||||
| - Knowledge Sharing and Collaboration: | ||||
|  | ||||
| A thriving culture of knowledge sharing, collaborative development, and mutual | ||||
| support within the ecosystem, facilitating continuous learning, innovation, and | ||||
| problem-solving. | ||||
|  | ||||
| - Resilience and Longevity: | ||||
|  | ||||
| Demonstrated resilience of the co-operative digital ecosystem to evolving | ||||
| economic, technical, and social challenges, ensuring its longevity and ongoing | ||||
| relevance. | ||||
|  | ||||
| - Dissemination and Replication: | ||||
|  | ||||
| Effective dissemination of the insights, learnings, and models developed | ||||
| through this initiative to the broader FLOSS community, encouraging replication | ||||
| and adaptation of the co-operative model in other contexts. | ||||
|  | ||||
| In a broader sense, the success of this initiative could significantly | ||||
| contribute to the reimagining and reshaping of the digital landscape in | ||||
| alignment with the principles of openness, co-operation, and community-centric | ||||
| development, echoing the core values and aspirations of the FLOSS community. | ||||
|  | ||||
| ## Tell us more about the project team and collaborators (500 words) | ||||
|  | ||||
| The project is a multi-team effort between different stakeholders in the FLOSS | ||||
| ecosystem. The project will be developed by a collaboration between two | ||||
| projects: Bonfire and Co-op Cloud. | ||||
|  | ||||
| * Bonfire (https://bonfirenetworks.org) is an extensible open source federated | ||||
|   social networking toolkit, that empowers communities easily configure their | ||||
|   spaces from the ground up, according to a variety of needs and visions. | ||||
|   Bonfire envisions a web of independent but interconnected social networks | ||||
|   (using a wide definition, since we consider the social compoments of | ||||
|   activities in the economic, educational, and political spheres as well) - | ||||
|   able to speak and transfer information among each other, according to their | ||||
|   own boundaries and preferences. | ||||
|  | ||||
| * Co-op Cloud (https://coopcloud.tech/) is federation of democratic collectives | ||||
|   (including worker-owned co-operatives, an international radical art | ||||
|   collective, a labor union, and representatives from FLOSS software projects). | ||||
|   The federation is centred around a software stack that aims to make hosting | ||||
|   libre software applications simpler, aimed at organisations wanting to manage | ||||
|   their own infrastracture, as well as small service providers such as tech | ||||
|   co-operatives who are looking to standardise around an open, transparent and | ||||
|   scalable infrastructure -- but is also developing as community of practice | ||||
|   around these themes, beyond the specific technology stack. | ||||
|  | ||||
| ## In which cost tier do you expect this work to sit? | ||||
|  | ||||
| - [ ] Between 50 and 75 | ||||
| - [ ] Between 75 and 100 | ||||
| - [x] Between 100 and 125 | ||||
|  | ||||
| ## How many months do you expect this work to take? | ||||
|  | ||||
| - 12 months | ||||
| - more than 12 months (exception goes up to 18 months for part-time projects) | ||||
|  | ||||
| ## Extras | ||||
|  | ||||
| ### Research links | ||||
|  | ||||
| * https://apo.org.au/node/312607 - O’Neil, Mathieu, et al. The coproduction of open source software by volunteers and big tech firms. News and Media Research Centre, 2021. | ||||
|  | ||||
| * https://dl.acm.org/doi/10.1145/3449249 - Geiger, R. Stuart, Dorothy Howard, and Lilly Irani. "The labor of maintaining and scaling free and open-source software projects." Proceedings of the ACM on human-computer interaction 5.CSCW1 (2021): 1-28. | ||||
|  | ||||
| * https://www.fordfoundation.org/wp-content/uploads/2020/12/regional-foss-communities_final-report_ahossain-1.pdf - Hossain, Anushah. "Regional Open Source Software Communities: The View From Dhaka, Bangladesh." (2021). | ||||
|  | ||||
| * https://digitalinfrastructure.fund/projects/cooperative-model-for-digital-infrastructure/ - Tierra Comun, Mexico, 2022 | ||||
|  | ||||
| * https://ieeexplore.ieee.org/abstract/document/5279594 - E. Elmroth, F. G. Marquez, D. Henriksson and D. P. Ferrera, "Accounting and Billing for Federated Cloud Infrastructures," 2009 Eighth International Conference on Grid and Cooperative Computing, Lanzhou, China, 2009 | ||||
|  | ||||
| * https://ieeexplore.ieee.org/abstract/document/7523331 - K. Chard and K. Bubendorfer, "Co-Operative Resource Allocation: Building an Open Cloud Market Using Shared Infrastructure," in IEEE Transactions on Cloud Computing, 2019 | ||||
|  | ||||
| * https://ieeexplore.ieee.org/abstract/document/6253530 - F. Paraiso, N. Haderer, P. Merle, R. Rouvoy and L. Seinturier, "A Federated Multi-cloud PaaS Infrastructure," 2012 IEEE Fifth International Conference on Cloud Computing, Honolulu, HI, USA, 2012 | ||||
|  | ||||
| * https://www.proquest.com/openview/d0bb1812450db201b4b67c84eca8cc50/1?pq-origsite=gscholar&cbl=18750&diss=y - Amini, Lisa D. "Models and algorithms for resource management in distributed computing cooperatives," Columbia University, 2004 | ||||
|  | ||||
| * https://hal.science/hal-03177060/document - Sébastien Broca, Laura Aufrère, Philippe Eynaud, Cynthia Srnec et Corinne Vercher-Chaptal, "Framasoft : de la plateforme à l’archipel", 2021 | ||||
							
								
								
									
										3
									
								
								docs/organisers/funding-applications/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								docs/organisers/funding-applications/index.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| --- | ||||
| title: Funding applications | ||||
| --- | ||||
							
								
								
									
										80
									
								
								docs/organisers/funding-applications/private-funder.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								docs/organisers/funding-applications/private-funder.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,80 @@ | ||||
| --- | ||||
| title: Private funder | ||||
| --- | ||||
|  | ||||
| # Private funder | ||||
|  | ||||
| > Status: **accepted** | ||||
|  | ||||
| ## Project Title | ||||
|  | ||||
| Co-op Cloud Federation & abra critical bug fixes | ||||
|  | ||||
| ## Explain the project and its expected outcome(s). | ||||
|  | ||||
| We are requesting support to tackle two important tasks in Co-op Cloud, to improve the project’s long-term sustainability: | ||||
|  | ||||
| * Formalising, and publicly launching the “Co-op Cloud Federation”, | ||||
| * Fixing critical usability issues in abra which are hindering further adoption. | ||||
|  | ||||
| ### The Federation | ||||
| In April 2022, we announced our proposal for how the Co-op Cloud federation could function: | ||||
|  | ||||
| * [Public announcement blogpost](https://coopcloud.tech/blog/federation-proposal/) | ||||
| * [Actual proposal text](https://pad.autonomic.zone/s/MLafJE2jC#) | ||||
|  | ||||
| We’ve gathered feedback from community members and are ready to take the proposal forward. This period of feedback gathering went beyond our [ECF Culture of Solidarity funding timeline](https://culturalfoundation.eu/stories/culture-of-solidarity-fund/), so we are happy to receive support to finalise it now. | ||||
|  | ||||
| This will mean formalising our decision-making structure, clarifying membership in the federation and helping lay the foundations for economic self-sufficiency through agreed membership and user group fees. | ||||
|  | ||||
| We propose a series of meetings with active community members to achieve this. | ||||
|  | ||||
| ### Critical abra bug fixes | ||||
| We have identified a few bugs in theabra commandline tool that, once sorted, will greatly improve adoption of Co-op Cloud. This support will help us fix these bugs which takes us one step closer to a stable 1.0 release. | ||||
|  | ||||
| * Making  abra resilient to outages in git.coopcloud.tech and the machine-readable `recipes.coopcloud.tech/recipes.json` (issue `#292`) | ||||
|  | ||||
| * Supporting language translations for the Co-op Cloud website and documentation (issue `coop-cloud/organising#74`) | ||||
|  | ||||
| * Bringing per-recipe documentation up-to-date with the latest abra syntax (issue `coop-cloud/organising#356`) | ||||
|  | ||||
| * Solidifying the machine-readable `recipes.coopcloud.tech/recipes.json` deployment (issue `coop-cloud/recipes-catalogue-json#3`) | ||||
|  | ||||
| * Making some usability tweaks to abra’s interface (issue `coop-cloud/organising#335` and issue `coop-cloud/organising#308)` | ||||
|  | ||||
| * Stabilising how abra interacts with SSH (issue `coop-cloud/organising#345`) | ||||
|  | ||||
| ## Requested Amount | ||||
|  | ||||
| * 9,240 GBP | ||||
|  | ||||
| ## Explain what the requested budget will be used for? | ||||
|  | ||||
| * Participation of all members at a series of meetings to discuss the proposal | ||||
|     * 60 GBP * 1 member from 8 member collectives * 6 hrs (3 meetings, 2 hr a meet) = 2880GBP | ||||
|  | ||||
| * Paying wages for 5 Autonomic members to collect feedback, amend the proposal & publish it | ||||
|     * 60 GBP * 5 members * 6 hrs = 1800GBP (collective meets) | ||||
|     * 60 GBP * 5 members * 4 hrs  = 1200GBP (internal meets) | ||||
|     * 60 GBP * 1 member * 5 hrs = 300GBP (finance admin) | ||||
|  | ||||
| * Paying wages for 3 external contributors helping in the process (bug fix, writing, etc) | ||||
|     * 60 GBP * 3 members * 5 hrs = 900GBP | ||||
|  | ||||
| * Implementing the proposal: 3 months of admin time until which point we have enough members to support ongoing admin costs | ||||
|     * 60 GBP * 1 member * 2 hrs * 3 months = 360 GBP | ||||
|  | ||||
| * abra critical usability fixes | ||||
|     * 60 GBP * 2 members * 15 hrs = 1800 GBP | ||||
|  | ||||
| ## What are significant challenges you expect to face? | ||||
|  | ||||
| Designing and settling on a format for the federation will be our main challenge. We expect that working together within a diversity of co-operatives and group members will present a spectrum of opinions on how the federation ought to function. Finding common ground amongst ourselves may pose a challenge. Finding a sufficient number of members for a functioning federation may be difficult. | ||||
|  | ||||
| While we all have a lot of experience with group decision-making through our involvement in Autonomic and other multi-stakeholder co-operatives, it could be a challenge to settle on a decision making system. | ||||
|  | ||||
| # Describe the ecosystem of the project, and how you will engage with relevant actors and promote the outcomes? | ||||
|  | ||||
| Several collectives are using Co-op Cloud as their preferred hosting method for example [Bonfire](https://bonfirenetworks.org/) and [Local-IT](https://local-it.org/) (see "Co-op Cloud “The Organisation”" on [The Co-op Cloud Public Beta](https://coopcloud.tech/blog/beta-release/) for the full list of participants). | ||||
|  | ||||
| We have over 500 followers on [Mastodon](https://social.coop/@coopcloud/), but our primary communication and recruitment relies on word of mouth, and people inviting each other to our Matrix channel. The community members have already [written](https://cgalo.dev/pages/from-coop-cloud-to-plain-docker-swarm/) [articles](https://gnulinux.ch/selfhosting-mit-co-op-cloud-und-abra) about Co-op Cloud and we expect this to happen again. | ||||
							
								
								
									
										105
									
								
								docs/organisers/funding-applications/sovereign-tech-fund.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								docs/organisers/funding-applications/sovereign-tech-fund.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,105 @@ | ||||
| --- | ||||
| title: Sovereign Tech Fund | ||||
| --- | ||||
|  | ||||
| # Sovereign Tech Fund | ||||
|  | ||||
| > Status: **rejected** | ||||
|  | ||||
| ## Project title | ||||
|  | ||||
| Critical fixes & enhancements for Abra, the Co-op Cloud command-line interface | ||||
|  | ||||
| ## Describe your project in a sentence. | ||||
|  | ||||
| Abra is the flagship command-line interface for Co-op Cloud, built to support the day-to-day workflow of deployment operators and recipe (app configuration) maintainers. | ||||
|  | ||||
| ## Describe your project more in-depth. Why is it critical? | ||||
|  | ||||
| The core technical work of the Co-op Cloud project involves democratic tech collectives hosting open source apps on self-managed servers. These apps empower digital sovereignty for members of our own collectives, and the wider community of partners, allies and clients for whom we operate these privacy-preserving, commons-based services. This is vital at a time of increasing surveillance predation and centralisation by "Big Tech" firms – including widespread regulatory capture – but also as public awareness of these issues grows, to facilitate concrete and meaningful action. | ||||
|  | ||||
| Day-to-day operation of Co-op Cloud uses the "Abra"command-line interface to interact with the app packaging & maintenance ecosystem, run app deployments and support long-term app maintenance (backup, restore, monitoring, etc.). | ||||
|  | ||||
| Since the Beta launch of Co-op Cloud in May 2022, we've formed a federation with 10 founding members, 2 of which run large-scale deployments (100+ apps in production) managed using Abra. Each open source app requires maintaining a shared app configuration ("recipe") using Abra, collectivising the federation members' experience into the digital commons. | ||||
|  | ||||
| Abra is a critical infrastructural resource because operators and recipe maintainers rely on it to do their work, share their work and operate and maintain their Co-op Cloud deployments and recipes. Abra is increasingly being relied upon for daily operations by more democratic tech collectives as the Co-op Cloud project scales up membership. | ||||
|  | ||||
| ## Link to project repository | ||||
|  | ||||
| [`git.coopcloud.tech/coop-cloud/abra`](https://git.coopcloud.tech/coop-cloud/abra) | ||||
|  | ||||
| ## Link to project website | ||||
|  | ||||
| [`coopcloud.tech`](https://coopcloud.tech) | ||||
|  | ||||
| ## Please provide a brief overview over your project’s own dependencies. | ||||
|  | ||||
| The design of Abra is based on the idea of wrapping existing APIs and interfaces to provide a more convenient and efficient workflow for operators and maintainers. In this way, Abra relies directly on integrations with core Linux tooling such as Docker, Git and SSH. | ||||
|  | ||||
| Abra relies primarily on interacting with the Docker Engine APIs using the Go programming language, in order to interact and control container runtimes on the self-managed servers. Abra speaks directly to the Docker daemon on the server using those APIs. Abra also relies on several non-public APIs from Docker and Mobdy related packages. | ||||
|  | ||||
| Abra provides [library APIs for clients](https://pkg.go.dev/coopcloud.tech/abra) which are currently available for experimental use. Tools such as [Kadabra](https://docs.coopcloud.tech/operators/tutorial/#automatic-upgrades) consume the Abra API in order to provide server-side automation, e.g. automatic upgrades. Furthermore, [cctuip](https://git.coopcloud.tech/decentral1se/cctuip), a prototype text-based user interface for operators also consumes the Abra APIs. | ||||
|  | ||||
| Both Kadabra and cctuip are being developed by members of the Co-op Cloud federation. Both tools are actively being used, tested and developed within the context of production deployments. | ||||
|  | ||||
| Abra relies on self-hosted Gitea (code hosting) & Drone (continuous integration / continuous deployment) systems to provide binary builds and release automation. | ||||
|  | ||||
| Operators and maintainers who rely on Abra for daily operations are as follows: | ||||
|  | ||||
| - [Autonomic co-operative](https://autonomic.zone) | ||||
| - [Local-IT](https://local-it.org/) | ||||
| - [Solisoft](https://solisoft.top) | ||||
| - [Flancia](https://flancia.org/) | ||||
| - [Social.coop](https://social.coop) | ||||
| - [Bonfire](https://bonfirenetworks.org/) | ||||
| - [ruangrupa](https://documenta-fifteen.de/en/lumbung-space/) | ||||
| - [UTAW](https://utaw.tech/about/) | ||||
| - [Kotec co-operative](https://kotec.space/) | ||||
|  | ||||
| ## Which target groups does your project address (who are its users?) and how do they benefit from the funding (directly and indirectly)? | ||||
|  | ||||
| The intended public of the Co-op Cloud project are established democratic tech collectives, such as technology co-operatives, who are already involved in public service providing. This focus allows us to situate our work within the specific requirements of this community, of which we are also a member. | ||||
|  | ||||
| Collectives would immediately benefit from the funding of critical fixes and enhancements in Abra: the fixes and enhancements listed in this proposal are generated through our bug reports, discussions and proposals for change. Receiving funding to proceed with this work will bring the exact changes required to improve the day-to-day operations and maintenance of the Co-op Cloud technical community. | ||||
|  | ||||
| Collectives face issues of scale when trying to achieve financial sustainability. As a consequence of Big Tech, end-users are accustomed to receive services for free or at very little charge. Small service providers need to scale out usership to make ends meet, which brings the risk of becoming overwhelmed with maintenance tasks, e.g. responsibility to backup data correctly across several apps/servers/groups. | ||||
|  | ||||
| Tools such as Abra play a key role in reducing the maintenance burden and expanding collaboration within the responsible collectives, because it is designed to do so by the community itself. In this sense, an improved and stable Abra increases the chances that end-users receive a stable and reliable service, which in turn helps with further outreach to grow the number of users benefiting from privacy-preserving, user-friendly, and community-directed software systems. | ||||
|  | ||||
| ## How was the work on the project made possible so far (structurally, financially, including volunteer work)? If applicable, list others sources of funding that you applied for and/or received. | ||||
|  | ||||
| Co-op Cloud, including Abra, was initiated by members of [Autonomic Co-operative](https://autonomic.zone/blog/2021/03/the-co-operative-cloud/) – initially on a volunteer basis, and then financially compensated from Autonomic's revenue once Abra reached an initial alpha release, including nominal back-pay for the volunteer work. | ||||
|  | ||||
| Shortly afterwards, Co-op Cloud received 32,986 EUR in funding from the [European Cultural Foundation](https://culturalfoundation.eu/stories/cosround4-autonomic-co-operative) to bring the project to public beta, and more widespread adoption by tech collectives. Autonomic Co-operative, who applied for the funding and continued to manage Co-op Cloud & Abra development during this period, helped distribute this funding to community members, to help avoid the frequent reliance of commons technology projects on volunteer labour. | ||||
|  | ||||
| Following the public beta launch, the project received 10,000 GBP in funding from a private donor to support the launch of the Co-op Cloud Federation, a nascent multi-stakeholder co-operative modelled after the [CoopCycle model](https://coopcycle.org/en/federation/). | ||||
|  | ||||
| We also applied for the [NLNet User-Operated Internet Fund](https://nlnet.nl/useroperated/) for funding to work on an web-based operator interface but were unsuccesful. | ||||
|  | ||||
| Currently, the project's main sources of funding is the membership dues of 10 federation members who pay 10 GBP / month to the federation common fund, and the ~5000 EUR left over from the private donation. | ||||
|  | ||||
| ## What do you plan to implement with the support from STF? | ||||
|  | ||||
| The Co-op Cloud project is reaching a point where a significant number of democratic tech collectives rely on Abra for daily operations of their large scale production deployments. | ||||
|  | ||||
| This brings new technical challenges in two directions. | ||||
|  | ||||
| The first is handling the increase in bug reports. The challenge here is the increasing scale, diversity and collective triage and discussion required to fix the bugs. We're seeing that these new fixes must be nuanced in their implementation and aware of diverse needs of operators/maintainers. This can often result in democratic decision-making to achieve consensus on a fix that is agreeable to those involved. | ||||
|  | ||||
| The second is a new challenge in which we must implement larger scale enhancements in Abra. We're seeing changing workflows, new approaches to deployments and discussion which result in proposals for significant changes in Abra. These changes often risk major disruption in workflows, e.g. for the app maintainer ecosystem and require a period of consensus building and democratic decision making around a proposal. Furthermore, the deployment of these changes typically require a pre-release and early adopter testing phase before rolling them out fully in a new release of Abra. | ||||
|  | ||||
| We currently categorise these two development trajectories under the following project boards: | ||||
|  | ||||
| * [Critical fixes (15 tickets at time of writing)](https://git.coopcloud.tech/coop-cloud/organising/projects/24) | ||||
|  | ||||
| * [Medium/large enhancements (15 tickets at time of writing)](https://git.coopcloud.tech/coop-cloud/organising/projects/25) | ||||
|  | ||||
| Abra has proven itself as a resilient toolset over 3 years of development and adoption. However, with the increase in scope of fixes and proposals for large scale changes, is at risk of falling behind and at worst, becoming an obstacle to day-to-day operations as the ecosystem of open source infrastructure management continues to change. | ||||
|  | ||||
| With the support of STF we can ensure the continued resilience of the project by implementing the fixes and changes generated by the Co-op Cloud community of operators and maintainers. | ||||
|  | ||||
| ## Who (maintainer, contributor, organization) would be most qualified to implement this work/receive the support and why? | ||||
|  | ||||
| Abra currently has 7 maintainers who work infrequently on Abra alongside their existing responsibilities in their own tech collectives. 2 of these developers have been involved in the first implementation of Abra, including the original Bash implementation. 4 tech collectives are represented in this development team. | ||||
|  | ||||
| We believe we have the expertise within the existing maintenance team to carry out the proposed changes in Abra. In our estimations, we expect that 2 developers can engage significantly in Abra development on a more dedicated basis over the course of 8 months. | ||||
| @ -0,0 +1,91 @@ | ||||
| --- | ||||
| title: User-Operated Internet Fund | ||||
| --- | ||||
|  | ||||
| # User-Operated Internet Fund | ||||
|  | ||||
| > Status: **rejected** ([Link to open call](https://nlnet.nl/useroperated/)) | ||||
|  | ||||
| ## Questions | ||||
|  | ||||
| > Please be short and to the point in your answers; focus primarily on the what and how, not so much on the why. Add longer descriptions as attachments (see below). If English isn't your first language, don't worry - our reviewers don't care about spelling errors, only about great ideas. We apologise for the inconvenience of having to submit in English. On the up side, you can be as technical as you need to be (but you don't have to). Do stay concrete. Use plain text in your reply only, if you need any HTML to make your point please include this as attachment. | ||||
|  | ||||
| ### 1. Abstract: Can you explain the whole project and its expected outcome(s). (1200 chars) | ||||
|  | ||||
| We're seeking financial support to build a web interface for [The Co-operative Cloud](https://coopcloud.tech), an open platform for public interest infrastructure. This will allow us to accelerate our plans to bring Co-op Cloud to end users, expanding the model from community hosting to self-hosting. | ||||
|  | ||||
| The command-line version of Co-op Cloud is already helping empower democratic collectives to run their own applications securely and reliably -- from file-sharing to broadcasting to real-time chat. We released the CLI in alpha form in March 2021, and we're currently working towards a beta release in November 2022. | ||||
|  | ||||
| Our current plan is to develop a web interface within the next 3-5 years, using income from providing managed Co-op Cloud hosting, to remove the requirement to be familiar with a shell prompt, and provide an open version of the "one click apps" available with some corporate providers. | ||||
|  | ||||
| ### 2. Have you been involved with projects or organisations relevant to this project before? And if so, can you tell us a bit about your contributions? (??) | ||||
|  | ||||
| We have participated in the [Yunohost](https://yunohost.org) and [Librehosters](https://libreho.st) projects, which aim to address some of the same challenges as Co-op Cloud, and our experiences with those organisations informed our design. More broadly than those very similar projects, we have also contributed to libre software applications like Discourse, Drupal and Peertube, and we're helping with community stewardship of the Mailu libre email project. | ||||
|  | ||||
| ### 3. Requested Amount (5000 to 50,000 EUR) | ||||
|  | ||||
| 46,000 | ||||
|  | ||||
| ### 3A. Explain what the requested budget will be used for? | ||||
|  | ||||
| - Brand design, UI research & design: 10% | ||||
| - UX testing: 5% | ||||
| - Software architecture and implementation: 40% | ||||
| - Project management: 10% | ||||
| - Community engagement & outreach: 5% | ||||
| - Security audit & bug bounties: 20% | ||||
| - Language translations: 10% | ||||
|  | ||||
| ### 3B. Does the project have other funding sources, both past and present? | ||||
|  | ||||
| We are currently receiving funding from the European Culture of Solidarity Foundation under the "Infodemic" call, to build the beta version of the Co-op Cloud platform, €31,000 in total from July 2021 - November 2022. | ||||
|  | ||||
| Beyond our grant funding, and support in terms of time and technical resources from Autonomic Co-operative, Co-op Cloud is also supported by 11 co-funding partner organisations who are now running some or all of their technology infrastructure using the platform: [ruangrupa](https://ruangrupa.id) -- curators of the upcoming ["documenta fifteen" event](https://www.documenta.de/en/documenta-fifteen/#) -- [WASHNote](https://washnote.com), [Social Media Analysis Toolkit (SMAT)](https://www.smat-app.com), [Neuronic Games](https://www.neuronicgames.com), [Third Sector Accountancy](https://www.thirdsectoraccountancy.coop), [Biobulkbende](https://biobulkbende.org), [Anarchy Rules](https://anarchyrules.info), [Fashion Revolution](https://fashionrevolution.org), the [Industrial Workers of the World](https://iww.org.uk), [Shaping Our Lives](https://www.shapingourlives.org.uk/) and [United Tech and Allied Workers](https://utaw.tech). | ||||
|  | ||||
| ### 4. Compare your own project with existing or historical efforts. (eg what is new, more thorough, or otherwise different) | ||||
|  | ||||
| We maintain an ongoing analysis of Co-op Cloud compared to other options in the [Co-op Cloud documentation](https://docs.coopcloud.tech/faq/#what-about-alternative). | ||||
|  | ||||
| Overall, Co-op Cloud has architectural and organisational advantages over existing libre options like Yunohost and [Caprover](https://caprover.com), and our open governance and libre licencing make Co-op Cloud a better long-term, pro-social choice than proprietary platforms like [Cloudron](https://cloudron.io). Versus options like [Ansible](https://ansible.com) or [Kubernetes](https://kubernetes.io), Co-op Cloud aims to be usable by less-technical users, to reduce their reliance on third parties to manage their data and tools. | ||||
|  | ||||
| ### 5. What are significant technical challenges you expect to solve during the project, if any? | ||||
|  | ||||
| The main challenge that we aim to overcome in building this web application is making some of the complex concepts around self-hosting accessibile to non-technical users, simplifying and automating DNS, backups, application updates, and updates of the Co-op Cloud web application itself. | ||||
|  | ||||
| A key secondary technical challenge will be ensuring up-to-date, high-quality translations, which we plan to achieve by closely integrating Weblate with our code and documentation management systems. | ||||
|  | ||||
| Another goal is to ensure the web application is resource-efficient, while remaining delightful to use, to maximise the range of hardware that it can be used on. | ||||
|  | ||||
| Lastly, we hope to continue the project of user education around the concept of data sovereignty, as well as provide the technical tools to help people migrate away from, and stay away from, big-tech surveillance. | ||||
|  | ||||
| In terms of technical risks in the project, we see: | ||||
|  | ||||
| - security (mitigated by an in-depth security review before launch, and the going bug bounty program) | ||||
| - configuration management (mitigated by using the existing git-based configuration management system from Co-op Cloud's command-line interface) | ||||
| - support (mitigated by continuing to grow the Co-op Cloud community, to maximise the opportunity for peer assistance) | ||||
|  | ||||
| ### 6. Describe the ecosystem of the project, and how you will engage with relevant actors and promote the outcomes? (Eg which actors will you involve? Who should deploy or run your solution to make it a success?) | ||||
|  | ||||
| We plan to build on our existing, successful, outreach strategy throughout our networks. We will make use of: | ||||
|  | ||||
| .. forums such as [CoTech](https://community.coops.tech, 581 members) and [International Co-operative Alliance](https://patio.ica.coop, 250 members) to make the project visible for technology co-operatives. Estimated 861 technology co-operative members, representing over 100 different co-operatives. | ||||
|  | ||||
| .. the [CHATONS](https://chatons.org, 70 members) and [Librehosters](https://libreho.st, 21 members) networks to maximise our reach amongst democratic technology collectives based in Europe. Estimated 91 collectives. | ||||
|  | ||||
| .. Cyberia Computer Club, an international network with whom we've already collaborated on integrations between their software and Co-op Cloud. Approximately 260 people. | ||||
|  | ||||
| .. both [traditional](https://twitter.com/autonomiccoop, 220 followers) and [alternative social media](https://sunbeam.city/@autonomic, 119 followers) to reach open source developers and other wider comunity members. Estimated 339 followers. | ||||
|  | ||||
| .. our own [co-operative website](https://autonomic.zone), which is visited by a wide range of potential clients, partners, and members. Estimated 1,000 visitors / month. | ||||
|  | ||||
| .. our self-hosted Matrix channel for [Co-op Cloud](#coop-cloud:autonomic.zone). 44 members (and growing), including representatives of some international organisations. | ||||
|  | ||||
| .. our personal relationships with democratic technologists internationally, including in Pakistan, India, Brazil, Canada, Spain, the USA, and others. Estimated ~50 unique contacts. | ||||
|  | ||||
| Our goal would be to see at least 3 other democratic collectives, from anywhere within these networks, using Co-op Cloud by the time of the launch of the beta web application, and to see a further 20 people join our Matrix chat as individual users. We also hope to see at least one strategic alliance with an initiative like Freedombox, or Cyberia's Greenhouse, to integrate Co-op Cloud with other efforts to improve the self-hosting landscape. | ||||
|  | ||||
| ### Attachments | ||||
|  | ||||
| Attachments: add any additional information about the project that may help us to gain more insight into the proposed effort, for instance a more detailed task description, a justification of costs or relevant endorsements. Attachments should only contain background information, please make sure that the proposal without attachments is self-contained and concise. Don't waste too much time on this. Really. | ||||
|  | ||||
| We have attached a budget document. | ||||
| @ -12,7 +12,7 @@ We still haven't worked this out. We're working on it. | ||||
|  | ||||
| ## Gathering new case studies | ||||
|  | ||||
| We try to gather as many "case studies" as possible, stories & concrete examples of Co-op Cloud being used For Good :tm: See [coopcloud.tech](https://coopcloud.tech) for our existing examples. These studies help people identify what the purpose of the project is for. | ||||
| We try to gather as many "case studies" as possible, stories & concrete examples of Co-op Cloud being used For Good :tm: See [coopcloud.tech](https://coopcloud.tech) for our existing examples. These studies help people identify what the purpose of the project is. | ||||
|  | ||||
| ## Monthly updates | ||||
|  | ||||
|  | ||||
| @ -1,9 +1,23 @@ | ||||
| --- | ||||
| title: Organisers Guide | ||||
| title: Organisers | ||||
| --- | ||||
|  | ||||
| Welcome to the organisers guide! Organisers are folks who focus on the social work in the project. Speaking for the project at talks, helping new tech co-ops & collectives join, keeping an eye out for funding opportunities, seeing what things up come up in the community chats, etc. It's important work. | ||||
| Welcome to the organisers guide! Organisers are folks who focus on the social work in the project. Speaking for the project at talks, helping new tech co-ops & collectives join, keeping an eye out for funding opportunities, seeing what things come up in the community chats, etc. It's important work. | ||||
|  | ||||
| <div class="grid cards" markdown> | ||||
|  | ||||
| - __Organisers Handbook__ | ||||
|  | ||||
|     One-stop shop for all you need to know to organise in the community :sparkles: | ||||
|  | ||||
|     [Read Handbook](/organisers/handbook){ .md-button .md-button--primary } | ||||
|  | ||||
| - __Say Hello First__ | ||||
|  | ||||
|     If you like what you see, but are not sure how to best contribute :speech_left: | ||||
|  | ||||
|     [Get In Touch](/get-involved/){ .md-button .md-button--primary } | ||||
|  | ||||
| </div> | ||||
|  | ||||
| We're still working out what it looks like to do this kind of work in the project. If you like the idea of this kinda of work and/or are already doing it, please send patches to improve this documentation :rocket: | ||||
|  | ||||
| - [Organising handbook](/organisers/handbook): One-stop shop for all you need to know to organise in the community :sparkles: | ||||
|  | ||||
							
								
								
									
										243
									
								
								docs/organisers/proposals/federation.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										243
									
								
								docs/organisers/proposals/federation.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,243 @@ | ||||
| --- | ||||
| title: The Co-op Cloud Federation Proposal | ||||
| --- | ||||
|  | ||||
| # The Co-op Cloud Federation Proposal | ||||
|  | ||||
| ## Table of Contents | ||||
|  | ||||
| - [Goal](#Goal) | ||||
| - [Overview](#Overview) | ||||
| - [Process](#Process) | ||||
| - [The Federation Proposal](#The-Federation-Proposal) | ||||
| - [The Code of Co-operation Proposal](#The-Code-of-Co-operation-Proposal) | ||||
|  | ||||
| ## Goal | ||||
|  | ||||
| This document is for the folks who are curious about what is means to "join the Co-op Cloud". You may already be lurking the Matrix channels, have deployed some apps with `abra` or support the project and want it to succeed :heart: | ||||
|  | ||||
| If this is the first time you're seeing the project, please do take a look at [coopcloud.tech](https://coopcloud.tech) & maybe [docs.coopcloud.tech](https://docs.coopcloud.tech) for more of a technical deep dive. You're also more than welcome to join the project! | ||||
|  | ||||
| ## Overview | ||||
|  | ||||
| As part of the [beta bikemap goals](https://pad.autonomic.zone/s/C3uuqfSCk) we are aiming to formalise the idea of what ["Co-op Cloud 'The Organisation'"](https://pad.autonomic.zone/s/C3uuqfSCk#Co-op-Cloud-%E2%80%9CThe-Organisation%E2%80%9D) could mean concretely. Here is what we wrote in our bike map originally: | ||||
|  | ||||
| > One of the core goals of Co-op Cloud is to have the project run and managed by a diverse group of tech co-ops and collectives who are invested into building, maintaining and extending this digital configuraton commons. In order to open the project up we need to work on shared governance guidelines, codes of conduct, building community trust and working towards economic sustainability. | ||||
|  | ||||
| Now that we are reaching the moment where we can make the beta release, we are ready to publish this proposal for feedback, discussion & amendments. | ||||
|  | ||||
| ## Process | ||||
|  | ||||
| In terms of feedback, we don't think we have to figure it all out now. What is more important is to lay the foundations for democratically working it out as we go on. Any red flags, major concerns & blockers to participation would be great to discover at this early stage. All comments, feedback & constructive criticism is welcome! | ||||
|  | ||||
| We are happy to receive this on any of the communication channels that we have. Please see our [contact docs](https://docs.coopcloud.tech/intro/contact/) for more. We will gather all feedback, discussions & follow up with people by the end of April 2022. We are aiming to publish this proposal by mid May 2022. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## The Federation Proposal | ||||
|  | ||||
| ### Members | ||||
|  | ||||
| Co-op Cloud is a federation of co-operative hosters centred around the [Co-op Cloud project](https://coopcloud.tech). By Co-operative hosters, we mean worker- or user-owned co-operatives, or other democratic collectives who are operating in the public interest. | ||||
|  | ||||
| ### Vision | ||||
|  | ||||
| A world where it's much easier to host technology services, creating local, community-run and participatory tech hosters, enabling more and more people to use services provided in the public interest, instead of ones operated by predatory advertising or planned obsolescence companies. | ||||
|  | ||||
| ### Aims | ||||
|  | ||||
| 1. Develop the Co-op Cloud technical app platform, including the [abra](https://docs.coopcloud.tech/abra/) command-line tool, the [application recipe catalogue](https://recipes.coopcloud.tech), and the [documentation](https://docs.coopcloud.tech). | ||||
| 1. Maintain a community of mutual support between co-operative hosters. | ||||
| 1. Facilitate communication between users and developers of libre software. | ||||
| 1. Create a support and knowledge sharing network to make setting up new co-operatives easier. | ||||
|  | ||||
| ### Benefits | ||||
|  | ||||
| As a member of Co-op Cloud, you'll be able to: | ||||
|  | ||||
| - Participate in decision-making -- about the direction of Co-op Cloud, and how to distribute income from grants and donations. | ||||
|  | ||||
| - Get listed as a recommended service provider [on the Co-op Cloud website](https://coopcloud.tech). | ||||
|  | ||||
| - Receive announcements about opportunities for funded work on Co-op Cloud early, before they're sent out to the wider community. | ||||
|  | ||||
| - Use shared Co-op Cloud services, including code hosting ([git.coopcloud.tech](https://git.coopcloud.tech)), continuous deployment ([builds.coopcloud.tech](https://builds.coopcloud.tech)) and any future digital infrastructure we all decide to set up. | ||||
|  | ||||
| ### Responsibilities | ||||
|  | ||||
| **Co-op Cloud members are expected to:** | ||||
|  | ||||
| - participate in all Large decisions, | ||||
|  | ||||
| - pay a financial contribution of £10/month or more via our [Open Collective](https://opencollective.com/coop-cloud), | ||||
|  | ||||
| - uphold the Code of Co-operation (see [below](#The-Code-of-Co-operation-Proposal)) | ||||
|  | ||||
| ### Decision-making | ||||
|  | ||||
| We propose to follow the decision making method of [Autonomic Co-op](https://autonomic.zone) which is explained in [this blog post](https://autonomic.zone/blog/how-we-make-decisions/) and adapted here for review.  Decisions can be split intro three categories: Small, Medium and Large. | ||||
|  | ||||
| #### Small - "Get on and do a thing" | ||||
|  | ||||
| - No one cares. | ||||
|  | ||||
| - Made by an individual within the federation. | ||||
|  | ||||
| - Could be in any area. | ||||
|  | ||||
| - Up to individual members to decide if they should just make the decision, or share it with the rest of the members to seek consensus. | ||||
|  | ||||
| #### Medium - "consensus pending objections" | ||||
|  | ||||
| - Potentially about shared tools, recipes, `abra`, etc. | ||||
|  | ||||
| - Doesn’t have an effect on the direction or operation of Co-op Cloud as a whole. | ||||
|  | ||||
| - Give a deadline: unless other members object or ask for more time by then, it goes ahead. | ||||
|  | ||||
| - The deadline must be reasonable (a week by default). | ||||
|  | ||||
| - If any member of Co-op Cloud thinks it’s a Large decision, achieve Maximum Consensus™ (see [below](#Large---Maximum-Consensus-™)). | ||||
|  | ||||
| #### Large - "Maximum Consensus ™" | ||||
|  | ||||
| - Important decisions affecting the operation, direction, working conditions and finances of Co-op Cloud. | ||||
|  | ||||
| - Consensus voting: addressing any concerns. | ||||
|  | ||||
| - Can be requested by any member of Co-op Cloud for any decision. | ||||
|  | ||||
| - Input from every Co-op Cloud member. | ||||
|  | ||||
| - Whoever proposes Large decisions is responsible for chasing up members for votes. | ||||
|  | ||||
| - Votes can be in favour, against, abstain (stand aside) or block. | ||||
|  | ||||
| - One member (individual or organisation) = 1 vote | ||||
|  | ||||
| #### Process | ||||
|  | ||||
| For Medium and Large decisions: | ||||
|  | ||||
| - Write up a proposal somewhere publicly accessible on the internet. | ||||
|  | ||||
| - Announce the decision in the [General chat (`#coopcloud:autonomic.zone`)](https://docs.coopcloud.tech/intro/contact/#matrix) on Matrix | ||||
|  | ||||
| - List the decision on the [decisions page](https://docs.coopcloud.tech/democracy/decisions) on our documentation | ||||
|  | ||||
| - Announce the result in the [General chat (`#coopcloud:autonomic.zone`)](https://docs.coopcloud.tech/intro/contact/#matrix) and record it on the [decisions page](https://docs.coopcloud.tech/democracy/decisions) of the documentation | ||||
|  | ||||
| #### Proposal format | ||||
|  | ||||
| (For Medium and Large decisions). | ||||
|  | ||||
| - What you want to change. | ||||
|  | ||||
| - Who it affects. | ||||
|  | ||||
| - Size (Medium / Large). | ||||
|  | ||||
| - Decision number | ||||
|  | ||||
| - Deadline. | ||||
|  | ||||
| - What chat channel you want discussion to happen in. | ||||
|  | ||||
| #### Example Proposal | ||||
|  | ||||
| **Large decision 001**: *Change the name of Co-op Cloud to Co-op Sun* | ||||
|  | ||||
| This decision affects everyone who uses and contributes to the project. I think the current name is too corporate. | ||||
|  | ||||
| The voting deadline for this decision is **January 1st 1970**. | ||||
|  | ||||
| Please discuss this proposal in `#coopcloud-comm-org:autonomic.zone`. | ||||
|  | ||||
| --- | ||||
|  | ||||
| ## The Code of Co-operation Proposal | ||||
|  | ||||
| > Huge thanks to the folks at [Varia](https://varia.zone/) & [LURK](https://lurk.org) who carefully prepared wonderful Code of Conduct documents which we have adapted for our needs (with permission). See the original documents [here](https://varia.zone/en/pages/code-of-conduct.html) and [there](https://lurk.org/TOS.txt). | ||||
|  | ||||
| Co-op Cloud is used by several communities coming from a variety of cultural, ethnic and professional backgrounds. We strive for to be welcoming to people of these various backgrounds and provide a non-toxic and harassment-free environment. | ||||
|  | ||||
| The Code of Conduct is a set of guidelines that help establish shared values and ensure that behaviour that may harm participants is avoided. | ||||
|  | ||||
| We acknowledge that we come from different backgrounds and all have certain biases and privileges. Therefore, this Code of Conduct cannot account for all the ways that people might feel excluded, unsafe or uncomfortable. We commit to open dialogues, and as such this Code of Conduct is never finished and should change whenever needed. We amend this document over time so it reflects the priorities and sensitivities of the community as it changes. | ||||
|  | ||||
| It is a collective responsibility for all of us to enact the behaviour described in this document. | ||||
|  | ||||
| ## Expected behaviour | ||||
|  | ||||
| We expect each other to: | ||||
|  | ||||
| ### Be considerate... | ||||
|  | ||||
| ...of each other, the space we enter, the Co-op Cloud community and the practices that it houses. | ||||
|  | ||||
| ### Be open and generous... | ||||
|  | ||||
| ...while trying not to make assumptions about others. This can include assumptions about identity, knowledge, experiences or preferred pronouns. Be generous with our time and our abilities, when we are able to. Help others, but ask first. There are many ways to contribute to a collective practice, which may differ from our individual ways. | ||||
|  | ||||
| ### Be respectful... | ||||
|  | ||||
| ...of different viewpoints and experiences. Respect physical and emotional boundaries. Be respectful of each others' limited time and energy. Take each other and each other's practices seriously. Acknowledge that this might lead to disagreement. However, disagreement is no excuse for poor manners. | ||||
|  | ||||
| ### Be responsible.... | ||||
|  | ||||
| ...for the promises we make, meaning that we follow up on our commitments. We take responsibility for the good things we do, but also for the bad ones. We listen to and act upon respectful feedback. We correct ourselves when necessary, keeping in mind that the impact of our words and actions on other people doesn't always match our intent. | ||||
|  | ||||
| ### Be dedicated... | ||||
|  | ||||
| ...which means not letting the group happen to us, but making the group together. We participate in the group with self-respect and don't exhaust ourselves. This might mean saying how we feel, setting boundaries, being clear about our expectations. Nobody is expected to be perfect in this community. Asking questions early avoids problems later. Those who are asked should be responsive and helpful. | ||||
|  | ||||
| ### Be empathetic... | ||||
|  | ||||
| ..by actively listening to others and not dominating discussions. We give each other the chance to improve and let each other step up into positions of responsibility. We make room for others. We are aware of each other's feelings, provide support where necessary, and know when to step back. One's idea of caring may differ from how others want to be cared for. We ask to make sure that our actions are wanted. | ||||
|  | ||||
| ### Foster an inclusive environment... | ||||
|  | ||||
| ...by trying to create opportunities for others to express views, share skills and make other contributions. Being together is something we actively work on and requires negotiation. We recognize that not everyone has the same opportunities, therefore we must be sensitive to the context we operate in. There are implicit hierarchies that we can challenge, and we should strive to do so. When we organize something (projects, events, etc.), we think about how we can consider degrees of privilege, account for the needs of others, promote an activist stance and support other voices. | ||||
|  | ||||
| ## Unacceptable behaviour | ||||
|  | ||||
| ### No structural or personal discrimination | ||||
|  | ||||
| Attitudes or comments promoting or reinforcing the oppression of any groups or people based on gender, gender identity and expression, race, ethnicity, nationality, sexuality, sexual orientation, religion, disability, mental illness, neurodiversity, personal appearance, physical appearance, body size, age, or class. Do not claim “reverse-isms”, for example “reverse racism”. | ||||
|  | ||||
| ### No harrassment | ||||
|  | ||||
| Neither public nor private. Also no deliberate intimidation, stalking, following, harassing photography or recording, disruption of events, aggressive, slanderous, derogatory, or threatening comments online or in person and unwanted physical or electronic contact or sexual attention. No posting or disseminating libel, slander, or other disinformation. | ||||
|  | ||||
| ### No violation of privacy | ||||
|  | ||||
| Namely publishing others’ private information, such as a physical or electronic address, without explicit permission. Do not take or publish photos or recordings of others after their request to not do so. Delete recordings if asked. | ||||
|  | ||||
| ### No unwelcome sexual conduct | ||||
|  | ||||
| Including unwanted sexual language, imagery, actions, attention or advances. | ||||
|  | ||||
| ### No destructive behaviour | ||||
|  | ||||
| Or any other conduct which could reasonably be considered inappropriate. This includes (but is not exclusive to) depictions of violence without content warnings, consistently and purposely derailing or disrupting conversations, or other behaviour that persistently disrupts the ability of others to engage in the group or space. | ||||
|  | ||||
| ## Intervention procedure | ||||
|  | ||||
| **Immediate intervention (help is needed now!)** | ||||
|  | ||||
| If you are feeling unsafe, you can immediately contact the Co-op Cloud members who are tasked with making sure the code of co-operation is respected. | ||||
|  | ||||
| These contact people are members of Co-op Cloud who will do their best to help, or to find the correct assistance if relevant/necessary. Here is the list so far. If you would like to help in this task, please also feel free to volunteer to be a support member. | ||||
|  | ||||
| > handle: `decentral1se` | ||||
| > contact: [helo@coopcloud.tech](mailto:helo@coopcloud.tech) | ||||
| > handle: `3wc` | ||||
| > contact: [helo@coopcloud.tech](mailto:helo@coopcloud.tech) | ||||
|  | ||||
| For example, something happened during a still-ongoing online event and needs to be acted upon right away. Action is taken immediately when this violation of the code of co-operation is reported. This could involve removing an attendee from said event. | ||||
|  | ||||
| ## Non-immediate intervention (a situation that requires more time) | ||||
|  | ||||
| Other violations need to be considered and consulted upon with more people or in a more measured way. For example: If you experience an ongoing pattern of harrassment; if you witness structurally unacceptable behaviour; if somebody keeps "accidentally" using discriminatory language, after being asked to stop. | ||||
|  | ||||
| If you feel comfortable or able, discuss the issues with the involved parties before consulting a mediator. We prefer to constructively resolve disagreements together and work to right the wrong, when it is possible and safe to do so. However, if the problems still persist, those who are responsible for enforcing the code of co-operation can help you deal with these kinds of problems. Contact the members listed above. Information will be handled with sensitivity. | ||||
							
								
								
									
										3
									
								
								docs/organisers/proposals/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								docs/organisers/proposals/index.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,3 @@ | ||||
| --- | ||||
| title: Proposals | ||||
| --- | ||||
| @ -1,83 +0,0 @@ | ||||
| --- | ||||
| title: Recipes | ||||
| --- | ||||
|  | ||||
| !!! note "Unsure of what a "recipe" is exactly?" | ||||
|  | ||||
|     Not to worry, we've got you covered, check out our [glossary page entry](/glossary#recipe). | ||||
|  | ||||
| ## Catalogue | ||||
|  | ||||
| The recipe catalogue is a web interface for exploring | ||||
| what kind of configurations we have available in the project and therefore what apps can be deployed. | ||||
|  | ||||
| It aims to be a helpful place to understand the status of apps, who is taking care of the configs and who is maintaining deployed instances of which app. | ||||
|  | ||||
| The recipe catalogue is available on [recipes.coopcloud.tech](https://recipes.coopcloud.tech/). | ||||
|  | ||||
| ## Status / features / scoring | ||||
|  | ||||
| Each recipe README has a "metadata" section, to help communicate the overall status of the recipe, and which features are supported. Here's an example, from [the Wordpress recipe](https://git.coopcloud.tech/coop-cloud/wordpress/): | ||||
|  | ||||
| ``` | ||||
| <!-- metadata --> | ||||
|  | ||||
| * **Category**: Apps | ||||
| * **Status**: 3, stable | ||||
| * **Image**: [`wordpress`](https://hub.docker.com/_/wordpress), 4, upstream | ||||
| * **Healthcheck**: Yes | ||||
| * **Backups**: Yes | ||||
| * **Email**: 3 | ||||
| * **Tests**: 2 | ||||
| * **SSO**: No | ||||
|  | ||||
| <!-- endmetadata --> | ||||
| ``` | ||||
|  | ||||
| Currently, recipe maintainers need to update the scores in this section manually. The specific meanings of the scores are: | ||||
|  | ||||
| ### Status (overall score) | ||||
|  | ||||
| - 5: everything in 4 + Single-Sign-On | ||||
| - 4: upstream image, backups, email, healthcheck, integration testing | ||||
| - 3: upstream image, missing 1-2 items from 4 | ||||
| - 2: missing 3-4 items from 4 or no upstream image | ||||
| - 1: alpha | ||||
|  | ||||
| ### Image | ||||
|  | ||||
| - 4: official upstream image | ||||
| - 3: semi-official / actively-maintained image | ||||
| - 2: 3rd-party image | ||||
| - 1: our own custom image | ||||
|  | ||||
| ### Email | ||||
|  | ||||
| - 3: automatic (using environment variables) | ||||
| - 2: mostly automatic | ||||
| - 1: manual | ||||
| - 0: none | ||||
| - N/A: app doesn't send email | ||||
|  | ||||
| ### CI | ||||
|  | ||||
| - 3: as 2, plus healthcheck | ||||
| - 2: auto secrets + networks | ||||
| - 1: basic deployment using `stack-ssh-deploy`, manual secrets + networks | ||||
| - 0: none | ||||
|  | ||||
| ### Single-Sign-On | ||||
|  | ||||
| - 3: automatic (using environment variables) | ||||
| - 2: mostly automatic | ||||
| - 1: manual | ||||
| - 0: none | ||||
| - N/A: app doesn't support SSO | ||||
|  | ||||
| ## Wishlist | ||||
|  | ||||
| If you'd like to see a new recipe packaged, make a request on the [recipes-wishlist](https://git.coopcloud.tech/coop-cloud/recipes-wishlist) repository issue tracker. | ||||
|  | ||||
| We've seen nice things happen when the requesters are also willing to take an active role in testing the new recipe. Teaming up with whoever volunteers to help do the packaging is best. | ||||
|  | ||||
| If no one is around to help, you can always take a run at it yourself, we have [a section](/maintainers/) ready to help you on your way. | ||||
| @ -4,6 +4,14 @@ | ||||
|   --md-primary-fg-color--dark: #ee4a33; | ||||
| } | ||||
|  | ||||
| /* Button styling tweaks */ | ||||
|  | ||||
| .md-button { | ||||
|   margin: .25em !important; | ||||
|   padding: .15em .6em !important; | ||||
|   font-size: .85em !important; | ||||
| } | ||||
|  | ||||
| /* Navbar styling tweaks */ | ||||
|  | ||||
| .md-search__form { | ||||
| @ -38,3 +46,37 @@ | ||||
|   background-color: #6A9CFF !important; | ||||
|   color: var(--md-primary-bg-color) !important; | ||||
| } | ||||
|  | ||||
| .md-score { | ||||
|   display: inline-block; | ||||
|   padding: .15em .75em; | ||||
|   cursor: normal; | ||||
|   border-radius: .25em; | ||||
|   font-size: .85em; | ||||
|   font-weight: 700; | ||||
| } | ||||
|  | ||||
| .md-score-5 { | ||||
|   color: #ffffff !important; | ||||
|   background-color: #28a745; | ||||
| } | ||||
|  | ||||
| .md-score-4 { | ||||
|   color: #ffffff !important; | ||||
|   background-color: #007bff; | ||||
| } | ||||
|  | ||||
| .md-score-3 { | ||||
|   color: #ffffff !important; | ||||
|   background-color: #ffc107; | ||||
| } | ||||
|  | ||||
| .md-score-2 { | ||||
|   color: #ffffff !important; | ||||
|   background-color: #dc3545; | ||||
| } | ||||
|  | ||||
| .md-score-1 { | ||||
|   color: #ffffff !important; | ||||
|   background-color: #343a40; | ||||
| } | ||||
|  | ||||
							
								
								
									
										100
									
								
								mkdocs.yml
									
									
									
									
									
								
							
							
						
						
									
										100
									
								
								mkdocs.yml
									
									
									
									
									
								
							| @ -1,6 +1,6 @@ | ||||
| --- | ||||
| site_author: Co-op Cloud | ||||
| site_name: "Co-op Cloud: Public Interest Infrastructure" | ||||
| site_name: "Co-op Cloud: Docs"  | ||||
| site_url: https://docs.coopcloud.tech | ||||
| use_directory_urls: true | ||||
|  | ||||
| @ -26,56 +26,83 @@ theme: | ||||
| copyright: Copyleft 2023 Co-op Cloud | ||||
|  | ||||
| markdown_extensions: | ||||
|   - meta | ||||
|   - admonition | ||||
|   - attr_list | ||||
|   - codehilite: | ||||
|       guess_lang: false | ||||
|   - def_list | ||||
|   - footnotes | ||||
|   - md_in_html | ||||
|   - meta | ||||
|   - toc: | ||||
|       permalink: true | ||||
|   - attr_list | ||||
|   - pymdownx.tabbed | ||||
|   - pymdownx.superfences | ||||
|   - pymdownx.tilde | ||||
|   - pymdownx.magiclink | ||||
|   - pymdownx.betterem: | ||||
|       smart_enable: all | ||||
|   - pymdownx.details | ||||
|   - pymdownx.emoji: | ||||
|       emoji_index: !!python/name:materialx.emoji.twemoji | ||||
|       emoji_generator: !!python/name:materialx.emoji.to_svg | ||||
|       emoji_generator: !!python/name:material.extensions.emoji.to_svg | ||||
|       emoji_index: !!python/name:material.extensions.emoji.twemoji | ||||
|   - pymdownx.magiclink | ||||
|   - pymdownx.mark | ||||
|   - pymdownx.smartsymbols | ||||
|   - pymdownx.snippets | ||||
|   - pymdownx.superfences | ||||
|   - pymdownx.tabbed | ||||
|   - pymdownx.tilde | ||||
|   - pymdownx.superfences: | ||||
|       custom_fences: | ||||
|         - name: mermaid | ||||
|           class: mermaid | ||||
|           format: !!python/name:pymdownx.superfences.fence_code_format | ||||
|  | ||||
| nav: | ||||
|   - "Introduction": | ||||
|       - index.md | ||||
|       - "Frequently asked questions": intro/faq.md | ||||
|       - "Project strategy": intro/strategy.md | ||||
|       - "Project status": intro/bikemap.md | ||||
|       - "Managed hosting": intro/managed.md | ||||
|       - "Get in touch": intro/contact.md | ||||
|       - "Frequently Asked Questions": intro/faq.md | ||||
|       - "Project Strategy": intro/strategy.md | ||||
|       - "Comparisons": intro/comparisons.md | ||||
|       - "Project Status": intro/bikemap.md | ||||
|       - "Managed Hosting": intro/managed.md | ||||
|       - "Get In Touch": intro/contact.md | ||||
|       - "Credits": intro/credits.md | ||||
|   - "Operators Guide": | ||||
|   - "Operators": | ||||
|       - operators/index.md | ||||
|       - "New operators tutorial": operators/tutorial.md | ||||
|       - "Operations handbook": operators/handbook.md | ||||
|   - "Maintainers Guide": | ||||
|       - "New Operators Tutorial": operators/tutorial.md | ||||
|       - "Operations Handbook": operators/handbook.md | ||||
|   - "Maintainers": | ||||
|       - maintainers/index.md | ||||
|       - "New maintainers tutorial": maintainers/tutorial.md | ||||
|       - "Packaging handbook": maintainers/handbook.md | ||||
|   - "Organisers Guide": | ||||
|       - "New Maintainers Tutorial": maintainers/tutorial.md | ||||
|       - "Packaging Handbook": maintainers/handbook.md | ||||
|   - "Organisers": | ||||
|       - organisers/index.md | ||||
|       - "Organising handbook": organisers/handbook.md | ||||
|   - "Recipes": | ||||
|     - recipes/index.md | ||||
|       - "Organisers Handbook": organisers/handbook.md | ||||
|       - "Funding applications": | ||||
|         - organisers/funding-applications/index.md | ||||
|         - organisers/funding-applications/culture-of-solidarity.md | ||||
|         - organisers/funding-applications/ford-foundation.md | ||||
|         - organisers/funding-applications/private-funder.md | ||||
|         - organisers/funding-applications/sovereign-tech-fund.md | ||||
|         - organisers/funding-applications/user-operated-internet.md | ||||
|       - "Proposals": | ||||
|         - organisers/proposals/index.md | ||||
|         - organisers/proposals/federation.md | ||||
|   - "Abra": | ||||
|       - abra/index.md | ||||
|       - "Install": abra/install.md | ||||
|       - "Quick start": abra/quickstart.md | ||||
|       - "Quick Start": abra/quickstart.md | ||||
|       - "Upgrade": abra/upgrade.md | ||||
|       - "Recipes": abra/recipes.md | ||||
|       - "Hack": abra/hack.md | ||||
|       - "Troubleshoot": abra/trouble.md | ||||
|       - "Cheat Sheet": abra/cheat-sheet.md | ||||
|   - "Get Involved": | ||||
|       - get-involved/index.md | ||||
|       - "Support Us": get-involved/support.md | ||||
|   - "Federation": | ||||
|       - federation/index.md | ||||
|       - "FAQ": federation/faq.md | ||||
|       - "Bylaws": federation/bylaws.md | ||||
|       - "Finance": federation/finance.md | ||||
|       - "Membership": federation/membership.md | ||||
|       - "Resolutions": | ||||
|         - federation/resolutions/index.md | ||||
|         - "Passed": | ||||
| @ -90,18 +117,21 @@ nav: | ||||
|           - federation/resolutions/passed/009.md | ||||
|           - federation/resolutions/passed/010.md | ||||
|           - federation/resolutions/passed/011.md | ||||
|         - "In progress": | ||||
|           - federation/resolutions/in-progress/index.md | ||||
|           - federation/resolutions/in-progress/012.md | ||||
|         - "Draft": | ||||
|           - federation/resolutions/drafts/index.md | ||||
|       - "Finance": federation/finance.md | ||||
|       - "Membership": federation/membership.md | ||||
|           - federation/resolutions/passed/012.md | ||||
|           - federation/resolutions/passed/014.md | ||||
|           - federation/resolutions/passed/015.md | ||||
|         - "In Progress": | ||||
|           - federation/resolutions/in-progress/013.md | ||||
|           - federation/resolutions/in-progress/016.md | ||||
|           - federation/resolutions/in-progress/017.md | ||||
|       - "Minutes": | ||||
|         - federation/minutes/index.md | ||||
|         - "2022": | ||||
|         - "Recently": | ||||
|           - federation/minutes/2024-02-01.md | ||||
|         - "Archive": | ||||
|           - federation/minutes/2022-03-03.md | ||||
|       - "Digital tools": federation/tools.md | ||||
|           - federation/minutes/2023-05-03.md | ||||
|       - "Digital Tools": federation/tools.md | ||||
|   - "Glossary": | ||||
|     - glossary/index.md | ||||
|  | ||||
|  | ||||
| @ -1,4 +1,15 @@ | ||||
| markdown~=3.2 | ||||
|  | ||||
| mkdocs~=1.5.3 | ||||
| mkdocs-material~=9.5.7 | ||||
| mkdocs-material-extensions~=1.3.1 | ||||
| mkdocs-awesome-pages-plugin==2.9.2 | ||||
| mkdocs-material-extensions==1.1.1 | ||||
| mkdocs-material==9.2.8 | ||||
| mkdocs==1.5.2 | ||||
| pygments~=2.16 | ||||
| pymdown-extensions~=10.2 | ||||
|  | ||||
| # Requirements for plugins | ||||
| babel~=2.10 | ||||
| colorama~=0.4 | ||||
| paginate~=0.5 | ||||
| regex>=2022.4 | ||||
| requests~=2.26 | ||||
|  | ||||
		Reference in New Issue
	
	Block a user