Compare commits
	
		
			1 Commits
		
	
	
		
			1.1.2+5.9.
			...
			ssh
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| d2a3fc6937 | 
							
								
								
									
										23
									
								
								.env.sample
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								.env.sample
									
									
									
									
									
								
							@ -5,27 +5,44 @@ DOMAIN=wordpress.example.com
 | 
			
		||||
#EXTRA_DOMAINS=', `www.wordpress.example.com`'
 | 
			
		||||
LETS_ENCRYPT_ENV=production
 | 
			
		||||
 | 
			
		||||
# Necessary for optional features, leave this alone:
 | 
			
		||||
COMPOSE_FILE="compose.yml"
 | 
			
		||||
 | 
			
		||||
## Additional extensions
 | 
			
		||||
#PHP_EXTENSIONS="calendar"
 | 
			
		||||
 | 
			
		||||
SECRET_DB_ROOT_PASSWORD_VERSION=v1
 | 
			
		||||
SECRET_DB_PASSWORD_VERSION=v1
 | 
			
		||||
 | 
			
		||||
# SSH access
 | 
			
		||||
#COMPOSE_FILE="$COMPOSE_FILE:compose.ssh.yml"
 | 
			
		||||
#SSH_PUBLIC_KEY=<your pubkey here>
 | 
			
		||||
 | 
			
		||||
# Multisite
 | 
			
		||||
#WORDPRESS_CONFIG_EXTRA="\
 | 
			
		||||
#	define('WP_CACHE', false);\
 | 
			
		||||
#	define('WP_ALLOW_MULTISITE', true );"
 | 
			
		||||
 | 
			
		||||
# Multisite phase 2 (see README)
 | 
			
		||||
# WORDPRESS_CONFIG_EXTRA="define('MULTISITE', true); define('SUBDOMAIN_INSTALL', true); define('DOMAIN_CURRENT_SITE', '${DOMAIN}'); define('PATH_CURRENT_SITE', '/');	define('SITE_ID_CURRENT_SITE', 1); define('BLOG_ID_CURRENT_SITE', 1); define('FORCE_SSL_ADMIN', true ); define('COOKIE_DOMAIN', \$_SERVER['HTTP_HOST']);"
 | 
			
		||||
#WORDPRESS_CONFIG_EXTRA="\
 | 
			
		||||
#	define('WP_CACHE', false);\
 | 
			
		||||
#	define('WP_ALLOW_MULTISITE', true );\
 | 
			
		||||
#	define('MULTISITE', true);\
 | 
			
		||||
#	define('SUBDOMAIN_INSTALL', true);\
 | 
			
		||||
#	define('DOMAIN_CURRENT_SITE', '${DOMAIN}');\
 | 
			
		||||
#	define('PATH_CURRENT_SITE', '/');\
 | 
			
		||||
#	define('SITE_ID_CURRENT_SITE', 1);\
 | 
			
		||||
#	define('BLOG_ID_CURRENT_SITE', 1);\
 | 
			
		||||
#	define('FORCE_SSL_ADMIN', true );\
 | 
			
		||||
#	define('COOKIE_DOMAIN', \$_SERVER['HTTP_HOST']);"
 | 
			
		||||
 | 
			
		||||
# Local SMTP relay
 | 
			
		||||
#COMPOSE_FILE="compose.yml:compose.mailrelay.yml"
 | 
			
		||||
#COMPOSE_FILE="$COMPOSE_FILE:compose.mailrelay.yml"
 | 
			
		||||
#SMTP_HOST="postfix_relay_app"
 | 
			
		||||
#MAIL_FROM="wordpress@example.com"
 | 
			
		||||
 | 
			
		||||
# Remote SMTP relay
 | 
			
		||||
#COMPOSE_FILE="compose.yml:compose.mailrelay.yml:compose.smtp.yml"
 | 
			
		||||
#COMPOSE_FILE="$COMPOSE_FILE:compose.smtp.yml"
 | 
			
		||||
#SMTP_HOST="mail.example.com"
 | 
			
		||||
#MAIL_FROM="wordpress@example.com"
 | 
			
		||||
#SMTP_PORT=587
 | 
			
		||||
 | 
			
		||||
@ -32,7 +32,10 @@ Coöp Cloud + [Wordpress](https://wordpress.org) = 🥳
 | 
			
		||||
 | 
			
		||||
## Running WP-CLI
 | 
			
		||||
 | 
			
		||||
`abra app cmd YOURAPPDOMAIN app wp -- core check-update --major`
 | 
			
		||||
`abra app YOURAPPDOMAIN wp 'core check-update --major'`
 | 
			
		||||
 | 
			
		||||
(the WP-CLI arguments need to be quoted, because of how `abra` handles
 | 
			
		||||
command-line arguments)
 | 
			
		||||
 | 
			
		||||
## Network (Multi-site)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										8
									
								
								abra.sh
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								abra.sh
									
									
									
									
									
								
							@ -1,12 +1,8 @@
 | 
			
		||||
export PHP_UPLOADS_CONF_VERSION=v3
 | 
			
		||||
export ENTRYPOINT_CONF_VERSION=v3
 | 
			
		||||
export ENTRYPOINT_MAILRELAY_CONF_VERSION=v2
 | 
			
		||||
export ENTRYPOINT_CONF_VERSION=v2
 | 
			
		||||
export ENTRYPOINT_MAILRELAY_CONF_VERSION=v1
 | 
			
		||||
export MSMTP_CONF_VERSION=v3
 | 
			
		||||
 | 
			
		||||
wp() {
 | 
			
		||||
  /usr/local/bin/wp $@
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
sub_wp() {
 | 
			
		||||
  CONTAINER=$(docker container ls -f "Name=${STACK_NAME}_app" --format '{{ .ID }}')
 | 
			
		||||
  if [ -z "$CONTAINER" ]; then
 | 
			
		||||
 | 
			
		||||
@ -6,7 +6,6 @@ services:
 | 
			
		||||
    entrypoint: /docker-entrypoint.mailrelay.sh
 | 
			
		||||
    environment:
 | 
			
		||||
      - SMTP_HOST=${SMTP_HOST}
 | 
			
		||||
      - SMTP_PORT=${SMTP_PORT:-25}
 | 
			
		||||
      - MAIL_FROM=${MAIL_FROM}
 | 
			
		||||
    configs:
 | 
			
		||||
      - source: mstmp_conf
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										27
									
								
								compose.ssh.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								compose.ssh.yml
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,27 @@
 | 
			
		||||
---
 | 
			
		||||
version: "3.8"
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  ssh:
 | 
			
		||||
    image: lscr.io/linuxserver/openssh-server
 | 
			
		||||
    environment:
 | 
			
		||||
      - PUID=33
 | 
			
		||||
      - PGID=33
 | 
			
		||||
      - PUBLIC_KEY=${SSH_PUBLIC_KEY}
 | 
			
		||||
      - USER_NAME=wordpress
 | 
			
		||||
      - PASSWORD_ACCESS=false
 | 
			
		||||
    networks:
 | 
			
		||||
      - proxy
 | 
			
		||||
    deploy:
 | 
			
		||||
      update_config:
 | 
			
		||||
        failure_action: rollback
 | 
			
		||||
        order: start-first
 | 
			
		||||
      labels:
 | 
			
		||||
        - "traefik.enable=true"
 | 
			
		||||
        - "traefik.tcp.routers.${STACK_NAME}-ssh.rule=HostSNI(`*`)"
 | 
			
		||||
        - "traefik.tcp.routers.${STACK_NAME}-ssh.entrypoints=gitea-ssh"
 | 
			
		||||
        - "traefik.tcp.services.${STACK_NAME}-ssh.loadbalancer.server.port=2222"
 | 
			
		||||
 | 
			
		||||
networks:
 | 
			
		||||
  proxy:
 | 
			
		||||
    external: true
 | 
			
		||||
							
								
								
									
										15
									
								
								compose.yml
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								compose.yml
									
									
									
									
									
								
							@ -3,14 +3,13 @@ version: "3.8"
 | 
			
		||||
 | 
			
		||||
services:
 | 
			
		||||
  app:
 | 
			
		||||
    image: "wordpress:5.9.3"
 | 
			
		||||
    image: "wordpress:5.8.1"
 | 
			
		||||
    volumes:
 | 
			
		||||
      - "wordpress_content:/var/www/html/wp-content/"
 | 
			
		||||
    networks:
 | 
			
		||||
      - backend
 | 
			
		||||
      - proxy
 | 
			
		||||
    environment:
 | 
			
		||||
      - PAGER=more
 | 
			
		||||
      - WORDPRESS_DB_HOST=db
 | 
			
		||||
      - WORDPRESS_DB_USER=wordpress
 | 
			
		||||
      - WORDPRESS_DB_PASSWORD_FILE=/run/secrets/db_password
 | 
			
		||||
@ -49,12 +48,10 @@ services:
 | 
			
		||||
        #- "traefik.http.routers.${STACK_NAME}.rule=HostRegexp(`{subdomain:.+}.${DOMAIN}`, `${DOMAIN}`)"
 | 
			
		||||
        - "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
 | 
			
		||||
        - "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.version=1.1.2+5.9.3"
 | 
			
		||||
        - "backupbot.backup=true"
 | 
			
		||||
        - "backupbot.backup.path=/var/www/html"
 | 
			
		||||
        - "coop-cloud.${STACK_NAME}.version=1.0.0+5.8.1"
 | 
			
		||||
 | 
			
		||||
  db:
 | 
			
		||||
    image: "mariadb:10.8"
 | 
			
		||||
    image: "mariadb:10.6"
 | 
			
		||||
    volumes:
 | 
			
		||||
      - "mariadb:/var/lib/mysql"
 | 
			
		||||
    networks:
 | 
			
		||||
@ -67,12 +64,6 @@ services:
 | 
			
		||||
    secrets:
 | 
			
		||||
      - db_password
 | 
			
		||||
      - db_root_password
 | 
			
		||||
    deploy:
 | 
			
		||||
      labels:
 | 
			
		||||
        - "backupbot.backup=true"
 | 
			
		||||
        - "backupbot.backup.path=/tmp/dump.sql.gz"
 | 
			
		||||
        - "backupbot.backup.post-hook=rm -f /tmp/dump.sql.gz"
 | 
			
		||||
        - "backupbot.backup.pre-hook=mysqldump -u root -p`cat /run/secrets/db_root_password` wordpress | gzip > /tmp/dump.sql.gz"
 | 
			
		||||
 | 
			
		||||
networks:
 | 
			
		||||
  backend:
 | 
			
		||||
 | 
			
		||||
@ -3,5 +3,3 @@
 | 
			
		||||
apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y msmtp && rm -rf /var/lib/apt/lists/*
 | 
			
		||||
 | 
			
		||||
echo "sendmail_path = /usr/bin/msmtp -t -i" > /usr/local/etc/php/conf.d/sendmail.ini
 | 
			
		||||
 | 
			
		||||
/docker-entrypoint.sh
 | 
			
		||||
 | 
			
		||||
@ -4,9 +4,6 @@
 | 
			
		||||
docker-php-ext-install {{ env "PHP_EXTENSIONS" }}
 | 
			
		||||
{{ end }}
 | 
			
		||||
 | 
			
		||||
curl -z /usr/local/bin/wp -o /usr/local/bin/wp https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar
 | 
			
		||||
chmod +x /usr/local/bin/wp
 | 
			
		||||
 | 
			
		||||
if [ -n "$@" ]; then
 | 
			
		||||
	"$@"
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user