Compare commits
1 Commits
proxy_scri
...
c46c763c1f
Author | SHA1 | Date | |
---|---|---|---|
c46c763c1f |
8
dev/docker.yml
Normal file
8
dev/docker.yml
Normal file
@@ -0,0 +1,8 @@
|
||||
- name: Install Docker Server
|
||||
hosts: all
|
||||
become: true
|
||||
vars_files:
|
||||
- host_vars/docker.yml
|
||||
roles:
|
||||
- base
|
||||
- docker
|
13
dev/host_vars/docker.yml
Normal file
13
dev/host_vars/docker.yml
Normal file
@@ -0,0 +1,13 @@
|
||||
# base
|
||||
allow_reboot: false
|
||||
manage_network: false
|
||||
|
||||
# docker
|
||||
docker_users:
|
||||
- vagrant
|
||||
|
||||
docker_compose_deploy:
|
||||
- name: docs
|
||||
url: git@git.krislamo.org:kris/homelab-docs.git
|
||||
version: main
|
||||
sync: true
|
@@ -53,13 +53,21 @@
|
||||
loop: "{{ docker_compose_deploy }}"
|
||||
when: docker_compose_deploy is defined
|
||||
|
||||
- name: Copy docker-compose project directory
|
||||
ansible.builtin.copy:
|
||||
src: "{{ docker_repos_path }}/{{ item.name }}/"
|
||||
dest: "{{ docker_compose_root }}/{{ item.name }}/"
|
||||
remote_src: yes
|
||||
loop: "{{ docker_compose_deploy }}"
|
||||
when: docker_compose_deploy is defined and item.sync | default(false)
|
||||
|
||||
- name: Copy docker-compose.yml files to their service directories
|
||||
ansible.builtin.copy:
|
||||
src: "{{ docker_repos_path }}/{{ item.name }}/{{ item.path | default('docker-compose.yml') }}"
|
||||
dest: "{{ docker_compose_root }}/{{ item.name }}/docker-compose.yml"
|
||||
remote_src: yes
|
||||
loop: "{{ docker_compose_deploy }}"
|
||||
when: docker_compose_deploy is defined
|
||||
when: docker_compose_deploy is defined and not item.sync | default(false)
|
||||
|
||||
- name: Set environment variables for docker-compose projects
|
||||
ansible.builtin.template:
|
||||
|
46
run-proxy.sh
46
run-proxy.sh
@@ -1,46 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Find private key file
|
||||
PRIVATE_KEY="$(find .vagrant -name "private_key")"
|
||||
|
||||
# Does the private_key file exist?
|
||||
if [ ! -f "$PRIVATE_KEY" ]; then
|
||||
echo "[ERROR] File not found at \"$PRIVATE_KEY\""
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Is the private_key a valid SSH key?
|
||||
echo "Checking validity of private key at $(pwd)/$PRIVATE_KEY"
|
||||
if ! ssh-keygen -l -f "$PRIVATE_KEY"; then
|
||||
echo "[Error] The private key at \"$PRIVATE_KEY\" is invalid (CODE: $?)"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Find an IP on the VM for the SSH tunnel
|
||||
HOST_IP="$(vagrant ssh -c "hostname -I | cut -d' ' -f${HOSTNAME_FIELD:-1}" 2>/dev/null | sed 's/.$//')"
|
||||
|
||||
# SSH command to match in processes table
|
||||
CMD="ssh -fNT -i $PRIVATE_KEY -L 8443:localhost:8443 -L 80:localhost:80 -L 443:localhost:443.*vagrant@$HOST_IP"
|
||||
|
||||
# Not just after PIDs
|
||||
# shellcheck disable=SC2009
|
||||
PS_TUNNELS="$(ps aux | grep -e "$CMD" | grep -v grep)"
|
||||
PS_COUNTER="$(echo "$PS_TUNNELS" | wc -l)"
|
||||
|
||||
if [ "$PS_COUNTER" -gt 0 ]; then
|
||||
echo "[ERROR] Tunnel(s) already seems to exist (counted $PS_COUNTER)"
|
||||
echo \""$PS_TUNNELS"\"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Create an SSH tunnel
|
||||
echo "Starting background SSH connection for localhost port forwarding"
|
||||
set -x
|
||||
ssh -fNT -i "$PRIVATE_KEY" \
|
||||
-L 8443:localhost:8443 \
|
||||
-L 80:localhost:80 \
|
||||
-L 443:localhost:443 \
|
||||
-o UserKnownHostsFile=/dev/null \
|
||||
-o StrictHostKeyChecking=no \
|
||||
vagrant@"${HOST_IP}" 2>/dev/null
|
||||
|
Reference in New Issue
Block a user