forked from toolshed/abra
		
	Compare commits
	
		
			82 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d68444be9e | |||
| f7bc8efabe | |||
| f5284ba725 | |||
| 293d3ff558 | |||
| c00319ab01 | |||
| 8b4141670c | |||
| 23c852125d | |||
| b4eae2e5e5 | |||
| 9e953319cf | |||
| 0814fa9146 | |||
| 0e1b6c858b | |||
| 28618bd3ac | |||
| b04bfea1c7 | |||
| bc0ef0d6fc | |||
| 16c91fedd1 | |||
| 9f5945094c | |||
| 76513a1f35 | |||
| 86eb8d7fde | |||
| e31b3d3173 | |||
| 58b13d7528 | |||
| b0fca49ecb | |||
| 79dacf557e | |||
| d6caf03301 | |||
| 9b90712d28 | |||
| 1dd3fe6fcd | |||
| 29953c17d9 | |||
| 3b59adfe34 | |||
| 00c8a988e1 | |||
| 524fb6a44c | |||
| e99bedf9e4 | |||
| 0d98c442a2 | |||
| bcc15ecdb0 | |||
| a617629a7a | |||
| f7ae400eb3 | |||
| 7141d364e1 | |||
| 057ce223f1 | |||
| 7511b25e47 | |||
| 62b447d61f | |||
| 88d2a75575 | |||
| 8cb6617a0f | |||
| 1a649c56cb | |||
| fd655274f8 | |||
| 946d1a068d | |||
| e8651976ca | |||
| af52ba1fec | |||
| 499c08c374 | |||
| 08281891a1 | |||
| 5bce042922 | |||
| 3276c9fe47 | |||
| 040374e781 | |||
| 621c8cd5c4 | |||
| 7434b67c34 | |||
| 17306a753b | |||
| 2e3f4cabd8 | |||
| cf2308cdd7 | |||
| eec49d6dd1 | |||
| d6195ad6d7 | |||
| fd04c5a6e9 | |||
| 1c9d7282b2 | |||
| dd9c485c66 | |||
| 99ab5bf369 | |||
| 25a0afed65 | |||
| 44e22db11b | |||
| 3321010089 | |||
| e04c4626f2 | |||
| 65ce949e03 | |||
| 5931cbd791 | |||
| 0bbff91722 | |||
| 7f5e753dfd | |||
| d3776f4424 | |||
| 544c4e86ba | |||
| 516309b478 | |||
| dfd7e29a30 | |||
| bb30fa28da | |||
| 044de5824b | |||
| 00cdce7bd2 | |||
| f163d4b0fa | |||
| e0032fb74a | |||
| 152dfe9349 | |||
| 5a95ae97a0 | |||
| 98e674b8e8 | |||
| b655cf20be | 
							
								
								
									
										21
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@ -1,5 +1,26 @@
 | 
			
		||||
# abra x.x.x (UNRELEASED)
 | 
			
		||||
 | 
			
		||||
# abra 0.6.0 (2021-03-17)
 | 
			
		||||
 | 
			
		||||
- Show version and digest of app if labelled ([98e674b8e8](https://git.autonomic.zone/coop-cloud/abra/commit/98e674b8e83458a83dcbf331e8e34c7188559c4a))
 | 
			
		||||
- Implement basic version checking on deployment ([#82](https://git.autonomic.zone/coop-cloud/abra/issues/82))
 | 
			
		||||
- New `app-catalogue.sh` script to auto-generate app list for documentation ([f163d4b](https://git.autonomic.zone/coop-cloud/abra/commit/f163d4b0fa920232e9d995a22d20fe78b174b3a9))
 | 
			
		||||
- Support app service rollbacks with `abra <app> rollback <service>` ([#76](https://git.autonomic.zone/coop-cloud/abra/issues/76))
 | 
			
		||||
- Detect when latest version is deployed and perform a no-op ([#87](https://git.autonomic.zone/coop-cloud/abra/issues/87))
 | 
			
		||||
- Allow cloning of app repos with different main branches using `-b, --branch=<branch>` ([#80](https://git.autonomic.zone/coop-cloud/abra/issues/80))
 | 
			
		||||
- Protect against lengthy app names which gives Docker trouble later on ([#83](https://git.autonomic.zone/coop-cloud/abra/issues/83))
 | 
			
		||||
- Support removal of secrets and volumes when `rm`'ing apps ([#44](https://git.autonomic.zone/coop-cloud/abra/issues/44))
 | 
			
		||||
- Always choose the default IPv4 address with `abra server <host> init` ([#91](https://git.autonomic.zone/coop-cloud/abra/issues/91))
 | 
			
		||||
- Add `--type=<type>` filtering option to `abra <app> ls` ([0828189](https://git.autonomic.zone/coop-cloud/abra/commit/0828189))
 | 
			
		||||
- Check for bash 4+ ([#96](https://git.autonomic.zone/coop-cloud/abra/commit/0828189))
 | 
			
		||||
- Add `--dev` option to installer using `git clone` ([88d2a75](https://git.autonomic.zone/coop-cloud/abra/commit/88d2a75))
 | 
			
		||||
- Support `--dev` on the `abra upgrade` command also ([bcc15ec](https://git.autonomic.zone/coop-cloud/abra/commit/bcc15ec))
 | 
			
		||||
- Vendor [yq](https://github.com/mikefarah/yq/releases) automatically ([3b59adf](https://git.autonomic.zone/coop-cloud/abra/commit/3b59adf))
 | 
			
		||||
- Extend version handling logic to support all underlying services ([#90](https://git.autonomic.zone/coop-cloud/abra/issues/90))
 | 
			
		||||
- Fix development installation script symlink issue ([#98](https://git.autonomic.zone/coop-cloud/abra/issues/98))
 | 
			
		||||
- Add `app-version.sh` script to help packagers version apps ([28618bd](https://git.autonomic.zone/coop-cloud/abra/commit/28618bd))
 | 
			
		||||
- Add git digest to `abra version` output ([8b41416](https://git.autonomic.zone/coop-cloud/abra/commit/8b41416))
 | 
			
		||||
 | 
			
		||||
# abra 0.5.0 (2021-03-01)
 | 
			
		||||
 | 
			
		||||
- `secret auto` merged into `secret generate` and `app new --auto` is now `app new --secrets` ([#64](https://git.autonomic.zone/coop-cloud/abra/pulls/64))
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										39
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								README.md
									
									
									
									
									
								
							@ -7,12 +7,51 @@
 | 
			
		||||
 | 
			
		||||
The cooperative cloud utility belt 🎩🐇
 | 
			
		||||
 | 
			
		||||
`abra` is a command-line tool for managing your own [Co-op Cloud](https://cloud.autonomic.zone). It can provision new servers, create applications, deploy them, run backup and restore operations and a whole lot of other things. It is the go-to tool for day-to-day operations when managing a Co-op Cloud instance.
 | 
			
		||||
 | 
			
		||||
## Change log
 | 
			
		||||
 | 
			
		||||
See [CHANGELOG.md](./CHANGELOG.md).
 | 
			
		||||
 | 
			
		||||
## Documentation
 | 
			
		||||
 | 
			
		||||
> [docs.cloud.autonomic.zone](https://docs.cloud.autonomic.zone/)
 | 
			
		||||
 | 
			
		||||
## Install
 | 
			
		||||
 | 
			
		||||
Install the latest stable release:
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
curl https://install.abra.autonomic.zone | bash
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
or the bleeding-edge development version:
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
curl https://install.abra.autonomic.zone | bash -s -- --dev
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
The source for this script is [here](./installer/installer).
 | 
			
		||||
 | 
			
		||||
## Update
 | 
			
		||||
 | 
			
		||||
Run `abra upgrade` to automatically download and install the latest release
 | 
			
		||||
version.
 | 
			
		||||
 | 
			
		||||
To update the development version, run `abra upgrade --dev`.
 | 
			
		||||
 | 
			
		||||
## Hack
 | 
			
		||||
 | 
			
		||||
It's written in Bash version 4 or greater!
 | 
			
		||||
 | 
			
		||||
Install it via `curl https://install.abra.autonomic.zone | bash -s -- --dev`, then you can hack on the source in `~/.abra/src`.
 | 
			
		||||
 | 
			
		||||
The command-line interface is generated via [docopt](http://docopt.org/). If you add arguments then you need to run `make docopt` ro regenerate the parser.
 | 
			
		||||
 | 
			
		||||
Please remember to update the [CHANGELOG](./CHANGELOG.md) when you make a change.
 | 
			
		||||
 | 
			
		||||
To deploy a new version of the installer scripts:
 | 
			
		||||
 | 
			
		||||
```sh
 | 
			
		||||
make release-installer
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										100
									
								
								app-catalogue.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										100
									
								
								app-catalogue.sh
									
									
									
									
									
										Executable file
									
								
							@ -0,0 +1,100 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
# Usage: ./app-catalogue.sh
 | 
			
		||||
#
 | 
			
		||||
# Gather metadata from Co-op Cloud apps in $ABRA_DIR/apps (default
 | 
			
		||||
# ~/.abra/apps), and format it as a Markdown table for this page:
 | 
			
		||||
# https://docs.cloud.autonomic.zone/apps/
 | 
			
		||||
 | 
			
		||||
stack_dir="${ABRA_DIR:-$HOME/.abra}/apps/"
 | 
			
		||||
 | 
			
		||||
cd "$stack_dir"
 | 
			
		||||
 | 
			
		||||
# load all README files into ENV_FILES array
 | 
			
		||||
mapfile -t readmes < <(find -L . -name "README.md")
 | 
			
		||||
# FIXME 3wc: requires bash 4, use for loop instead
 | 
			
		||||
 | 
			
		||||
base_url="https://git.autonomic.zone/coop-cloud"
 | 
			
		||||
 | 
			
		||||
cat_apps=()
 | 
			
		||||
cat_development=()
 | 
			
		||||
cat_utilities=()
 | 
			
		||||
cat_graveyard=()
 | 
			
		||||
 | 
			
		||||
get_var() {
 | 
			
		||||
	echo "$1" | grep "$2" | sed 's/^[^:]*: //'
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# shellcheck disable=SC2120
 | 
			
		||||
trim() {
 | 
			
		||||
	# accept input as argument or from STDIN, see here:
 | 
			
		||||
	# https://zwbetz.com/passing-input-to-a-bash-function-via-arguments-or-stdin/
 | 
			
		||||
	# shellcheck disable=SC2155
 | 
			
		||||
	local input="$([[ -p /dev/stdin ]] && cat - || echo "$@")"
 | 
			
		||||
	[[ -z "$input" ]] && return 1
 | 
			
		||||
	echo "$input" | tr -d ' '
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
# shellcheck disable=SC2120
 | 
			
		||||
prettify() {
 | 
			
		||||
	# as above
 | 
			
		||||
	# shellcheck disable=SC2155
 | 
			
		||||
	local input="$([[ -p /dev/stdin ]] && cat - || echo "$@")"
 | 
			
		||||
	[[ -z "$input" ]] && return 1
 | 
			
		||||
 | 
			
		||||
	echo "$input" | sed -e 's/Yes/✅/' -e 's/No/❌/' -e 's/N\/A/⛔/'
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
for readme in "${readmes[@]}"; do
 | 
			
		||||
	type="$(basename "${readme%README.md}")"
 | 
			
		||||
	if [ "$type" = "example" ]; then
 | 
			
		||||
		continue
 | 
			
		||||
	fi
 | 
			
		||||
	title="$(grep '^# ' "$type/README.md" | sed 's/^# //' )"
 | 
			
		||||
	# find section between 'metadata' and 'endmetadata' comments
 | 
			
		||||
	metadata="$(awk '/-- metadata --/,/-- endmetadata --/' "$type/README.md")"
 | 
			
		||||
	status="$(get_var "$metadata" "Status")"
 | 
			
		||||
	category="$(get_var "$metadata" "Category" | cut -d',' -f2 | trim)"
 | 
			
		||||
 | 
			
		||||
	if [ -z "$category" ]; then
 | 
			
		||||
		echo "ERROR: missing category for $type"
 | 
			
		||||
		continue
 | 
			
		||||
	fi
 | 
			
		||||
 | 
			
		||||
	image="$(get_var "$metadata" "Image" | cut -d',' -f2 | trim)"
 | 
			
		||||
	healthcheck="$(get_var "$metadata" "Healthcheck" | prettify)"
 | 
			
		||||
	backups="$(get_var "$metadata" "Backups" | prettify)"
 | 
			
		||||
	email="$(get_var "$metadata" "Email" | prettify)"
 | 
			
		||||
	tests="$(get_var "$metadata" "Tests" | prettify)"
 | 
			
		||||
	sso="$(get_var "$metadata" "SSO" | prettify)"
 | 
			
		||||
 | 
			
		||||
	row="| [$title]($base_url/$type) | $status | $image | $healthcheck | $backups | $email | $tests | $sso |"
 | 
			
		||||
 | 
			
		||||
	category_lower="$(echo "$category" | tr '[:upper:]' '[:lower:]')"
 | 
			
		||||
	eval "cat_$category_lower+=( '$row' )"
 | 
			
		||||
done
 | 
			
		||||
 | 
			
		||||
headers="
 | 
			
		||||
| **Name** | **Status** | **Image** | **Healtcheck** | **Backups** | **Email** | **CI** | **Single-Sign-On** |
 | 
			
		||||
| --- | --- | --- | --- | --- | --- | --- | --- |"
 | 
			
		||||
 | 
			
		||||
echo "## Applications"
 | 
			
		||||
echo "$headers"
 | 
			
		||||
printf '%s\n' "${cat_apps[@]}" | sort
 | 
			
		||||
 | 
			
		||||
echo
 | 
			
		||||
 | 
			
		||||
echo "## Developer tools"
 | 
			
		||||
echo "$headers"
 | 
			
		||||
printf '%s\n' "${cat_development[@]}" | sort
 | 
			
		||||
 | 
			
		||||
echo
 | 
			
		||||
 | 
			
		||||
echo "## Utilities"
 | 
			
		||||
echo "$headers"
 | 
			
		||||
printf '%s\n' "${cat_utilities[@]}" | sort
 | 
			
		||||
 | 
			
		||||
echo
 | 
			
		||||
 | 
			
		||||
echo "## Graveyard"
 | 
			
		||||
echo "$headers"
 | 
			
		||||
printf '%s\n' "${cat_graveyard[@]}" | sort
 | 
			
		||||
							
								
								
									
										42
									
								
								app-version.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										42
									
								
								app-version.sh
									
									
									
									
									
										Executable file
									
								
							@ -0,0 +1,42 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
 | 
			
		||||
# Usage: ./app-version.sh <image> <service>
 | 
			
		||||
# Example: ./app-version.sh drone/drone:1.10.1 app
 | 
			
		||||
#
 | 
			
		||||
# Accepts a full format hub.docker.com image tag which it pulls locally and
 | 
			
		||||
# generates output which can be used to put in the abra.sh for app packaging.
 | 
			
		||||
# Requires the yq program https://mikefarah.gitbook.io/yq/
 | 
			
		||||
 | 
			
		||||
error() {
 | 
			
		||||
  echo "$(tput setaf 1)ERROR: $*$(tput sgr0)"
 | 
			
		||||
  exit 1
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IMAGE="$1"
 | 
			
		||||
SERVICE="$2"
 | 
			
		||||
 | 
			
		||||
if ! docker pull -q "$IMAGE" > /dev/null 2>&1; then
 | 
			
		||||
	error "Failed to download image, is the tag correct?"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
version=$(echo "$IMAGE" | cut -d ':' -f2)
 | 
			
		||||
digest=$(docker image inspect -f "{{.Id}}" "$IMAGE" | cut -d ':' -f2- | cut -c 1-8)
 | 
			
		||||
 | 
			
		||||
echo "--- Add the following to your abra.sh ---"
 | 
			
		||||
echo "export ABRA_TYPE_${SERVICE^^}_VERSION=${version}"
 | 
			
		||||
echo "export ABRA_TYPE_${SERVICE^^}_DIGEST=${digest}"
 | 
			
		||||
 | 
			
		||||
version_lookup="ABRA_TYPE_${SERVICE^^}_VERSION"
 | 
			
		||||
digest_lookup="ABRA_TYPE_${SERVICE^^}_DIGEST"
 | 
			
		||||
 | 
			
		||||
label='- "coop-cloud.${STACK_NAME}.'
 | 
			
		||||
label+="${SERVICE}"
 | 
			
		||||
label+='.version=${'
 | 
			
		||||
label+="${version_lookup}"
 | 
			
		||||
label+='}-${'
 | 
			
		||||
label+="${digest_lookup}"
 | 
			
		||||
label+='}"'
 | 
			
		||||
 | 
			
		||||
echo
 | 
			
		||||
echo "--- And don't forget to label the actual service in the compose file ---"
 | 
			
		||||
echo "$label"
 | 
			
		||||
@ -26,10 +26,8 @@ services:
 | 
			
		||||
 | 
			
		||||
configs:
 | 
			
		||||
  abra_installer:
 | 
			
		||||
    name: abra_installer_v1
 | 
			
		||||
    file: installer
 | 
			
		||||
  abra_conf:
 | 
			
		||||
    name: abra_conf_v1
 | 
			
		||||
    file: nginx.conf
 | 
			
		||||
 | 
			
		||||
networks:
 | 
			
		||||
 | 
			
		||||
@ -1,18 +1,34 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
 | 
			
		||||
ABRA_VERSION="0.5.0"
 | 
			
		||||
ABRA_SRC="https://git.autonomic.zone/coop-cloud/abra/raw/tag/$ABRA_VERSION/abra"
 | 
			
		||||
ABRA_VERSION="0.6.0"
 | 
			
		||||
GIT_URL="https://git.autonomic.zone/coop-cloud/abra"
 | 
			
		||||
ABRA_SRC="$GIT_URL/raw/tag/$ABRA_VERSION/abra"
 | 
			
		||||
 | 
			
		||||
function install_abra {
 | 
			
		||||
function install_abra_release {
 | 
			
		||||
  mkdir -p "$HOME/.local/bin"
 | 
			
		||||
  curl "$ABRA_SRC" > "$HOME/.local/bin/abra"
 | 
			
		||||
  chmod +x "$HOME/.local/bin/abra"
 | 
			
		||||
  echo "abra installed to $HOME/.local/bin/abra"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function run_installation {
 | 
			
		||||
  install_abra
 | 
			
		||||
function install_abra_dev {
 | 
			
		||||
  mkdir -p "$HOME/.abra/"
 | 
			
		||||
  if [[ ! -d "$HOME/.abra/src" ]]; then
 | 
			
		||||
    git clone "$GIT_URL" "$HOME/.abra/src"
 | 
			
		||||
  fi
 | 
			
		||||
  ( cd "$HOME/.abra/src" && git pull origin main && cd -)
 | 
			
		||||
  mkdir -p "$HOME/.local/bin"
 | 
			
		||||
  ln -sf "$HOME/.abra/src/abra" "$HOME/.local/bin/abra"
 | 
			
		||||
  echo "abra installed to $HOME/.local/bin/abra (development bleeding edge)"
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
run_installation
 | 
			
		||||
function run_installation {
 | 
			
		||||
  if [ "$1" = "--dev" ]; then
 | 
			
		||||
    install_abra_dev
 | 
			
		||||
  else
 | 
			
		||||
    install_abra_release
 | 
			
		||||
  fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
run_installation "$@"
 | 
			
		||||
exit 0
 | 
			
		||||
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
.PHONY: test shellcheck docopt kcov codecov
 | 
			
		||||
.PHONY: test shellcheck docopt kcov codecov release-installer
 | 
			
		||||
 | 
			
		||||
test:
 | 
			
		||||
	@sudo DOCKER_CONTEXT=default docker run \
 | 
			
		||||
@ -43,3 +43,8 @@ codecov: SHELL:=/bin/bash
 | 
			
		||||
codecov:
 | 
			
		||||
	@bash <(curl -s https://codecov.io/bash) \
 | 
			
		||||
		-s coverage -t $$(pass show hosts/swarm.autonomic.zone/drone/codecov/token)
 | 
			
		||||
 | 
			
		||||
release-installer:
 | 
			
		||||
	@docker stack rm abra-installer-script && \
 | 
			
		||||
		cd installer && \
 | 
			
		||||
		docker stack deploy -c compose.yml abra-installer-script
 | 
			
		||||
		Reference in New Issue
	
	Block a user