162 Commits

Author SHA1 Message Date
51bd9c9935 feat: agregar configuración group_vars para host testing
- Definir host_ip: 157.180.114.62
- Requerido por rol knsupdate y certbot
2025-11-26 18:13:55 -03:00
7cdf7bb885 ej de test net 2025-11-26 14:41:57 -03:00
ecab24c02f VPS 4 testing 2025-11-26 13:11:59 -03:00
f2668d63ef closes #12
@f confirmas porfa si la url del sub-repo esta correcta?
2025-11-20 17:18:05 -03:00
29182e8eaf closes #23 2025-11-20 16:55:40 -03:00
fa59614c2a actualizo mi pubkey 2025-11-20 16:27:01 -03:00
94e71c7516 Revert "quite stream.yml"
This reverts commit b7139145dc.
2025-11-20 12:52:33 -03:00
65090c8c2c alta nodo llavero 2025-11-05 16:16:55 -06:00
b7139145dc quite stream.yml 2025-10-29 22:23:42 -06:00
8e17401f12 kaasavi 2025-10-29 16:43:30 -06:00
206f8adf60 samatuun 2025-10-28 13:34:09 -06:00
1f73abb74f Merge pull request 'feat: rate limits #39' (#65) from issue-39 into master
Reviewed-on: #65

Probaremos en una huerta primero, luego #72
2025-10-24 12:40:14 +00:00
f
2aa6ddcc4d fix: configuración de ssl #69
adaptado de https://ssl-config.mozilla.org/#server=nginx&version=1.29.2&config=intermediate&openssl=3.5.1&guideline=5.7
2025-10-23 17:18:44 -03:00
f
41b30d3a8d fix: headers de seguridad #68 2025-10-23 17:17:19 -03:00
f
4361acfde1 fix: ocultar versión de nginx #67 2025-10-23 17:13:10 -03:00
f
7b5669eae8 Merge branch 'master' into issue-39 2025-10-23 16:36:15 -03:00
f
d2569a7e29 fix: usar los limites recomendados 2025-10-23 15:45:16 -03:00
f
47759f5464 fix: typo 2025-10-23 15:02:27 -03:00
f
3c690dd1f5 feat: rate limits #39 2025-10-23 15:01:58 -03:00
3c30dc976d Merge pull request 'SSH' (#61) from SSH into master
Reviewed-on: #61
2025-10-23 14:36:32 +00:00
b369e9824b Merge branch 'master' into SSH 2025-10-23 11:35:35 -03:00
a75f06474c Merge pull request 'feat: firewall #8' (#63) from issue-8-firewall into master
Reviewed-on: #63

Cómo irán a jugar el firewall con los múltiples puertos distintos necesarios para SSH?
Va a haber que hacer que se abran puertos al vuelo y modificar el rules.v4 tambien
No  hay que reiniciar el firewall cada vez porque se pierden las reglas de docker

8-(
2025-10-23 14:27:47 +00:00
e1b4fb8ba1 hacer de firewall un rol Ansible 2025-10-23 11:10:13 -03:00
f0f0c688c9 muevo upgrades a rol Althost conteniendo instalaciones del Host
elimino unos comentarios
closes #35
2025-10-23 10:36:39 -03:00
f
5aea3651c2 fix: bookworm! 2025-10-22 16:51:55 -03:00
f
bc44c5074e feat: actualizaciones de seguridad automáticas #35 2025-10-22 16:48:50 -03:00
f
b36346e6d3 fix: asegurarse que dnsmasq se reinicia con la configuracion 2025-10-01 09:03:23 -03:00
f
0d48f04f15 feat: firewall #8 2025-10-01 08:57:52 -03:00
957a923a7c nodo carabobolibre 2025-09-05 09:23:25 -06:00
bd07232180 no mezclar con rama fqdn 2025-08-29 12:23:38 -04:00
f5cd3f2e2e sintaxis puertos ssh
problemas con multiples dominios
2025-08-25 19:26:56 -04:00
d0beebfe12 puerto SSH como variable en la matriz, es ports [0]
en el service.yml del proxy recorre los servicios con el atributo 'ports' definido
2025-08-22 21:13:46 -04:00
299f970b95 naca 2025-08-22 20:14:48 -04:00
a581e89f22 eliminando stream de git
que es otra cosa mariposa
2025-08-22 20:05:05 -04:00
23ac2f0b64 proxy SSH en el 222 y git en el 2222 2025-08-22 19:57:58 -04:00
144f9c9d85 proxy SSH Nginx funcional 2025-08-22 19:57:58 -04:00
121c07f766 añadiendo stream {} en nginx.conf 2025-08-22 19:57:58 -04:00
7bc06903eb TODO 2025-08-22 19:26:27 -04:00
ed1edd6269 nodo resistencia 2025-08-09 08:33:10 -06:00
f
1910b37547 fix: rebeldia 2025-08-07 12:18:09 -03:00
9c38fea199 nodo kipu alta 2025-08-06 14:56:43 -06:00
f
9455e50af9 feat: rebeldia 2025-08-06 12:08:23 -03:00
645630e9c8 nodo kipu 2025-08-05 12:00:35 -06:00
d4215f7e3e nodo antisistema 2025-08-03 09:07:10 -06:00
4a886418e8 Actualizar README.md 2025-07-03 02:28:49 +00:00
741a026408 Actualizar README.md
clarificando README
2025-07-03 02:23:46 +00:00
d8f0b5fb66 simplificando++ 2025-06-25 14:52:51 -04:00
31fb3b7526 tags 2025-06-25 14:49:42 -04:00
1bf91dfa24 tablitas ++ 2025-06-25 14:43:36 -04:00
e06d6a4414 tablitas2 2025-06-25 14:42:14 -04:00
d4384187d9 tablitas 2025-06-25 14:41:50 -04:00
28ad0386be simplificando mas mas 2025-06-25 14:39:24 -04:00
e703628d8d simplificando mas 2025-06-25 14:32:08 -04:00
04bcec3352 simplificando... #52 2025-06-25 14:20:11 -04:00
d8600ee1cb nodo barrio 2025-06-18 21:41:42 -04:00
a63bd72256 actualizo mi llave publica 2025-06-18 15:44:57 -04:00
f
8b3a0babf6 feat: puerto 2025-05-20 16:16:39 -03:00
f
38c8db9f53 feat: cad 2025-05-13 12:34:51 -03:00
f
860487aa9d fix: redireccionar marmite a sutty 2025-03-07 14:58:55 -03:00
f
0b22138ab0 fix: permitir ntfy en sutty 2025-03-07 00:34:52 -03:00
f
08cb31c8c9 fix: no crear enlaces todo el tiempo 2025-03-06 22:21:23 -03:00
f
433fda716a feat: habilitar websockets 2025-03-06 22:21:15 -03:00
f
61deebaf25 fix: reducir el tiempo de espera de certbot 2025-03-06 22:21:05 -03:00
94bacbf352 nuevos nodos
y proxy
2025-02-12 17:13:38 -03:00
f
70dc16c042 feat: mexe 2025-01-16 15:11:07 -03:00
f
0b4c0534f6 fix: sin guión 2025-01-16 14:48:53 -03:00
75b2b5d269 nodo armanddo 2025-01-16 11:23:28 -06:00
f
c0b5978ef5 feat: compresión opcional 2025-01-02 13:44:41 -03:00
f
f1c5ee7654 feat: sutty 2025-01-02 13:44:27 -03:00
f
4a98e1e92f Merge branch 'master' of ssh://git.coopcloud.tech:2222/escuela-comun/abyayala 2024-12-13 12:17:56 -03:00
1548d9f7c2 terminales VPN noviembre 2024-11-26 14:24:20 -03:00
c3247017f0 agregue terminal fundeps 2024-11-26 08:30:03 -06:00
a700bc0b88 nodos yanapak 2024-11-12 14:17:38 -06:00
f
a4b66d5c49 feat: kurmi 2024-11-09 10:35:17 -03:00
f
539c1e47f3 feat: padiuxiterminal 2024-11-08 13:13:52 -03:00
f
789c0dbfcc fix: aumentar el límite de archivos de nodo 2024-11-08 13:09:11 -03:00
f
b36f2e3910 feat: agregar registros extra 2024-11-06 18:08:44 -03:00
c08b998d21 una terminal 2024-11-06 17:36:40 -03:00
f
fdff1e3496 feat: respaldos 2024-11-06 16:14:43 -03:00
f
d6edca2ac6 Merge branch 'master' of ssh://git.coopcloud.tech:2222/escuela-comun/abyayala 2024-11-06 16:04:03 -03:00
f
bd3117579a fix: agregar ganam 2024-11-06 16:00:29 -03:00
008a8b97ae terminales a la vpn 2024-10-27 12:26:54 -03:00
f
9820cf1db8 feat: narkitila 2024-10-25 17:05:33 -03:00
f
a67caf2f57 feat: nodochasqui 2024-10-21 13:59:25 -03:00
f
c49a2b73cc doc: cómo dar de alta waykis 2024-10-15 10:32:41 -03:00
f
fc46e78fb3 feat: chasqui y fauno 2024-10-15 10:30:16 -03:00
f
aa36848906 feat: vmcpogt 2024-10-08 15:46:25 -03:00
f
35bbc39a3d fix: aumentar el límite de subida a 1G 2024-10-01 19:54:38 -03:00
5f031b7688 se armo la red abyaya.la 2024-09-30 13:15:43 -03:00
ee3deadaf8 a nivel de server en el vhost nginx se puede habilitar limite de peso de request para subida de archivos
pero en realidad solo lo quiero para nube.
2024-09-14 19:05:58 -03:00
219ede45ec arregla bugs en seleccion de default vhost
y deshabilita synchronize peligroso al que ademas no le cabe 'creates'
2024-09-14 12:30:27 -03:00
780a848f25 todos los vhost son forzados por https 2024-09-14 12:02:57 -03:00
07f3164720 forzar https por servicio 2024-09-14 11:58:11 -03:00
c075375ae8 pirra 2024-09-12 17:52:20 -03:00
c4b114ebaa arregla tasks/users.yml 2024-09-12 17:45:57 -03:00
053ca48945 fixes 2024-09-12 16:44:01 -03:00
85f64fd7f0 ABYAYA.LA 2024-09-12 16:41:38 -03:00
ed6691c575 LEAMOS 2024-09-12 16:38:13 -03:00
868393a045 LEAMO 2024-09-12 16:23:07 -03:00
f
7e4eb3f21f feat: nodos 2024-09-12 15:32:47 -03:00
f
1a15ebe1e8 fix: typo 2024-09-12 15:32:36 -03:00
4753b8a270 orden del rEADME invertido 2024-09-11 21:19:38 -03:00
0a378d665c fix: debe coincidir con coso 2024-09-11 18:38:46 -03:00
ae95c2dd0e troubleshooting 2024-09-11 18:33:29 -03:00
4bb2c14c83 con esto ya logra sacar el dominio wildcard,
estoy ahora peleando con bugs en el proxy
2024-09-11 18:21:01 -03:00
52e7da204d Merge branch 'master' into knsupdate 2024-09-11 17:36:17 -03:00
87b77339c5 rol proxy incluye al rol knsupdate antes de certbot
es en el proxy! que se ejecuta knsupdate, q de hecho es una forma de actualizar el DNS de sutty como desde este api
2024-09-11 17:35:16 -03:00
79f052d2a7 fixes 2024-09-11 16:52:47 -03:00
1630c554ff para cada servicio que tenga definido dominios se ejecuta en loop el template update 2024-09-11 16:38:39 -03:00
f5252a4c18 knupd 2024-09-11 16:26:04 -03:00
5e61a46c4b variables de knot dentro del rol, se usan en update 2024-09-11 16:08:59 -03:00
9c1bae22d8 la verdad acerca del vps: se llama hetzner
idem
2024-09-11 15:58:32 -03:00
b53f1686bf sacamos users y knot de deploy, para ponerlos en sus propias tareas
esto se debiera invocar asi
ansible-playbook tasks/knot.yml -e "host=localhost"
include_role no busca bien en la carpeta cuando esta en subidrectorio
2024-09-11 15:50:36 -03:00
34672f27e6 simple tag kdns 2024-09-11 15:25:44 -03:00
6504043f4e ususarix infinito 2024-09-11 15:07:58 -03:00
142727cdcd llave de he 2024-09-11 14:56:24 -03:00
d7306ec168 llabe publica de veto 2024-09-11 14:39:47 -03:00
f
078a55de7c draft: dar de alta nodos con knsupdate 2024-09-10 17:01:13 -03:00
a91e793b28 en realidad estoy escribiendo el README
eso le falto a gitea, el editor on-line del README?
2024-09-10 13:45:48 -03:00
71984956d3 trolleando... 2024-09-10 13:34:22 -03:00
81b863a359 spameando.. 2024-09-10 13:30:28 -03:00
9b334741c9 ... 2024-09-10 13:28:47 -03:00
b78859b71b ascii art 2024-09-10 13:27:35 -03:00
a2e5550967 el chem, el que
sutty
2024-09-10 13:24:57 -03:00
ae29a088af Merge branch 'master' into rap 2024-09-10 12:31:31 -03:00
1229ed7276 2012K 2024-09-10 12:15:42 -03:00
f
7b783f861e fix: typo 2024-09-10 12:14:13 -03:00
8d9079ca50 merge de faunas amazonicas: fixes de fauno al proxy,
tambien en la vpn (no se resolvia en el regex en effet, no estaba invocandose bien ?)
en esta rama se hace reset HEAD^ de mis fixes truchos de master a la ultima, en la que se basó
2024-09-10 12:02:10 -03:00
20e13644f9 Merge branch 'master' into rap 2024-09-10 12:01:55 -03:00
f
9aeed678e3 fix: expedir certificados para todos los dominios y sus subdominios 2024-09-10 11:46:03 -03:00
f
92bc0fe191 fix: resolver por dnsmasq 2024-09-10 10:51:13 -03:00
f
d664a15af9 fix: siempre nos conectamos por ssh 2024-09-10 10:51:04 -03:00
f
cf63a24756 fix: enviar el subdominio correcto 2024-09-10 10:50:44 -03:00
f
62b191d039 feat: acelerar ssh 2024-09-10 10:50:21 -03:00
836a58f37e la dependencia es dhcpd5 2024-09-10 09:51:11 -03:00
f
972321637b typo 2024-09-10 09:49:17 -03:00
f450087ab0 desambiguacion de variable
hubo que actualizar el cache de apt una vez
2024-09-09 23:07:24 -03:00
d6f4a3fcd7 hay que instalar dhclient en el nodo
aunque el paquete esta deprecado...
... y sigue sin funcionar
2024-09-09 20:41:51 -03:00
3544b27e4a hacer rap install despues de rap init, aun no resuelve rakiduam.comun
pero si genera carpeta /etc/tinc/comun
2024-09-09 14:45:41 -03:00
ca75a34eeb staging en certbot (tiene errores) Ooo 2024-09-09 13:46:03 -03:00
f61f22377c recuperamos la logica de vhosts especificos para poder desplegar kemal
kemal es el gate, el servicio web al que los nodos deben pedir acceso para unirse a la rap
ademas, esto nos servira para desplegar servicios que tienen requerimientos especificos a nivel del proxy
2024-09-09 10:24:18 -03:00
487945bf80 no forzar el init en el nodo porque no funciona en nodos nuevos
y actualizaciones en el README y definicion de mi nodo de prueba
2024-09-08 10:44:51 -03:00
87c922250b Leeme porfis 2024-09-08 10:22:25 -03:00
20ce4fb6f3 mejora README 2024-09-08 10:16:59 -03:00
b1574f1967 esto es para no pisar configuracion local de RAP en proxy... 2024-09-07 21:42:16 -04:00
eec4aafd72 intentando desplegar otro servicio, no funciona
la parte RAP pareciera correr, pero luego ni proxy ni nodo resuelven chem.comun
la parte de cerbot vuelve a fallar, sin encontrar TXT en _acme_challenge.chem.abyaya.la
2024-09-07 21:40:48 -04:00
4d4e855fcc se agrega dhcpd a la RAP 2024-09-07 21:16:52 -04:00
1d85e24f63 correcciones, deja funcionando despliegue de VPN en el proxy 2024-09-06 21:52:01 -04:00
f0e4dbb7e0 instalacion de los nodos en el servidor de la VPN 2024-09-06 15:31:15 -04:00
3a2a235199 inicializacion de la RAP en el nodo cliente ansibilizada 2024-09-06 14:13:02 -04:00
5546a6a8b9 rap como submodulo en git 2024-09-06 12:27:48 -04:00
f9746c1ff2 esto no va 2024-09-06 12:14:08 -04:00
6f8146aa16 Eliminar web/wireframe.scss 2024-09-06 01:19:01 +00:00
a31c155609 Eliminar web/wireframe.css 2024-09-06 01:18:55 +00:00
da3c25fe58 Eliminar web/styleguide.html 2024-09-06 01:18:48 +00:00
83bcadaab0 Eliminar web/new-page.html 2024-09-06 01:18:42 +00:00
60bdce36aa Eliminar web/index.html 2024-09-06 01:18:36 +00:00
1f103c16f0 Eliminar web/test.md 2024-09-06 00:19:40 +00:00
98ab948b9d Subir archivos a "web" 2024-09-06 00:19:30 +00:00
c42b1b773a Añadir web/test.md 2024-09-06 00:17:39 +00:00
37f1866300 Eliminar web/index.html 2024-09-06 00:17:18 +00:00
3adee1fd7c Añadir web/index.html 2024-09-06 00:15:25 +00:00
51 changed files with 921 additions and 169 deletions

3
.gitmodules vendored Normal file
View File

@ -0,0 +1,3 @@
[submodule "roles/rap/code/rap"]
path = roles/rap/code/rap
url = https://0xacab.org/pip/rap.git

216
README.md
View File

@ -1,17 +1,217 @@
## DEPLOY
# ABYAYA.LA #
Este sistema automatiza el despliegue de la red Abyaya.la, mediante [Ansible](https://docs.ansible.com/), un software de automatización de código abierto, que permite la gestión de configuraciones, el despliegue de aplicaciones y la orquestación de tareas.
- Sintaxis basada en YAML, que significa "Yet Another Markup Language". Un formato de serialización de datos legible por humanes.
- Se definien playbooks, que son scripts que automatizan secuencias de tareas y configuraciones.
- Opera sin necesidad de instalar agentes en los nodos gestionados, ya que se comunica a través de SSH.
### abyayala.yml
Así, gestionamos la __infraestructura como código__, en un único archivo de matriz __abyayala.yml__
Este describe los componentes a desplegar para qu esta red funcione. Podríamos dividirlos en dos grandes componentes:
### La RAP
La _Red Autónoma Pirata_ es la __VPN__ que nos permite acceder a nuestros servidores, sin importar el lugar donde estén conectados.
|Características||
|-------------------------------|--------------------------------------------|
| Red | `10.13.12.1/24` |
| DHCP | Automático |
| Resolución de nombres | Hostname (ej. `ping ka.comun`) |
### El PROXY
Es un servidor con una IP pública, a la que apuntamos el dominio __abyaya.la__.
Hace de **proxy reverso** para los demás servidores, ruteando el tráfico a cada servidor a través de la RAP.
|Características||
|-------------------------------|--------------------------------------------|
| Subdominios para los servidores|`nuevo.abyaya.la` |
| Servicios en los sub-sub-dominios| Ej: `https://sitio.nuevo.abyaya.la` |
| Certificados Wildcard| `*.nuevo.abyaya.la` |
----
# Cómo funciona
La idea es reducir todo a un solo comando único *deploy.yml", el cual leerá la matriz **abyayala.yml** para desplegar o actualizar, tanto a la VPN como al Proxy.
# Componentes Principales
## Estructura de Archivos
- deploy.yml: Playbook principal, el "comando único"
- abyayala.yml: Configuración principal (YAML) en donde se define declarativamente la infraestructura de ambos componentes (VPN y Proxy)
- tasks/: Playbooks adicionales para tareas específicas
- roles/: Cada rol configura un servicio del sistema
# ALTA DE NODOS "EN 2 PASOS"
Esta se hace en dos partes, pues hay que configurarlo primero en el nodo de destino y después en el servidor del proxy.
## 1.1 - Autorizar nuevo nodo en la RAP...
También tenemos que avisar a la RAP, la cual se define en el archivo abyayala.yml, en el **server_name: vpn**
En la lista de **nodos** mantenemos los nodos autorizados para conectarse a la RAP
```
- service_name: vpn
roles:
- rap
nodos:
- marmite
- ka
```
Lo agregamos a la lista y ejecutamos el comando **deploy.yml** para autorizarlos.
Le especificaremos parámetros con **- e**:
```
ansible-playbook deploy.yml -e "alt=abyayala host=hetzner"
```
Así estamos desplegando entonces los servicios definidos en el archivo **abyayala.yml**, a nuestro servidor en **hetzner**.
### Parámetros de deploy.yml
Los parámetros obligatorios son:
- **alt**: nombre de nuestro servidor autónomo, en este caso siempre es 'abyayala'
- **host**: nombre del servidor de destino en el archivo de inventario hosts.production
Los parámetros opcionales pueden ser:
- **service**: limita al despliegue a un servicio específico, en lugar de actualizarlos todos
Siguiendo con el ejemplo anterior, utilizaremos el parametro **service** para ejecutar solamente la vpn.
```
ansible-playbook deploy.yml -e "host=abyayala alt=abyayala"
ansible-playbook deploy.yml -e "alt=abyayala host=hetzner service=vpn"
```
# opcional: service define despliegue de servicio especifico
# service undefined: ejecuta todos los roles
## 1.2 - Instalar la RAP en el nodo
# -e "service=defined" si es master, ejecuta su rol | si es worker, tambien pero en el otro host
# --skip-tags=installation saltea una parte, marcada por un tag. por ejemplo, la instalacion. o --skip-tags=installation,keys
Para desplegar la RAP en nuestro nodo destino, utilizamos otro playbook, el script **tasks/rap.yml** especificando sus parámetros con **-e
"..."**
```
ansible-playbook --become tasks/rap.yml -e "nodo=nuevo host=miservidora"
```
En donde:
- **host**: es el nodo nuevo a configurar, según su definición en el inventario de ansible
- **nodo**: es el nombre que le daremos, el cual debe coincidir con el que desplegamos en el proxy más adelante
## 2 - HABILITAR ACCESO HTTPS AL NUEVO NODO
Por otro lado, hay que actualizar al **Proxy** para que el nuevo nodo sea accesible por HTTPS, en un subdominio público.
Vemos que cada nodo debe tener una entrada en el archivo **abyayala.yml**, en donde se asocia su **subdominio público** con su **nodo en la RAP**, de esta forma:
```
- service_name: nuevo
domains:
- nuevo.abyaya.la
nodo: nuevo.comun
ssl: yes
```
Donde
- **service_name**: es un nombre arbitrario
- **domains**: la unica entrada de domains es el subdominio principal
- **nodo**: es el hostname del nodo en la RAP
- **ssl**: habilita la conexión SSL/TLS
### 2.2 DEPLOY.YML
Luego de agregar nuestro nuevo nodo, volvemos entonces a ejecutar el comando **deploy.yml** para habilitar el acceso HTTPS a éste, y publicar ese subdominio.
En esta ocasión, lo acotaremos a actualizar la configuración de solamente **un nodo**, especificándolo con el parámetro **service**:
```
ansible-playbook deploy.yml -e "alt=abyayala host=hetzner service=nuevo"
```
### DEPLOY LOCAL
### TAGS
También hay **tags** que marcan secciones del código.
Por ejemplo se puede acotar aún más, saltándose todas las tareas de instalación con **--skip-tags**
```
ansible-playbook --become deploy.yml -e "host=localhost alt=abyayala" -i hosts.local
ansible-playbook deploy.yml -e "alt=abyayala host=hetzner service=nuevo" --skip-tags=installation
```
----
# INSTALACIÓN
## Instalar Ansible
```
# Si tienen Python
pip install ansible
# Para sistemas basados en Debian/Ubuntu
sudo apt-get install ansible
# Para sistemas RHEL/CentOS
sudo yum install ansible
```
## PREPARAR SSH
También deben tener sus llaves públicas de **SSH** añadidas tanto al nodo como al servidor de destino.
### Generar clave SSH (si no existe)
```
ssh-keygen -t ed25519
```
### Copiar clave pública al nodo de destino
```
ssh-copy-id root@nuevo.comun
```
### ALTA DE USUARIXS EN EL PROXY
Para conectarse al proxy deben agregar sus llaves como dice a continuación:
* Copiar la(s) llave(s) pública(s) de cada wayki en `tasks/files/ssh/WAYKI.pub`.
* Agregarle en `group_vars/all/ssh_users.yml` (copiando la sintaxis)
* Correr `ansible-playbook tasks/users.yml -e "host=hetzner"`
---
# TESTING
Si todo anda bien, podemos probarlo así:
## Conexión VPN
Como resultado del deploy de la primera parte (RAP), la máquina **nodo** debe conectarse a la red comun en IPv4 y en el rango 10.13.12.1/24 y poder pingear al server, que es 10.13.12.1
El proxy a su vez puede pingear a cada nodo por su nombre de host en la red comun. por ej.
```
root@proxy-reverso-escuela-comun:~# ping ka.comun
PING ka.comun (10.13.12.129) 56(84) bytes of data.
64 bytes from ka.comun (10.13.12.129): icmp_seq=1 ttl=64 time=169 ms
```
## Acceso HTTPS
Por otra parte, como resultado del despliegue de la segunda parte (PROXY), el **nodo** debe ser accesible en el subdominio **nuevo. abyaya.la**
Los servicios de cada nodo son accesibles a través de SSL en **sub-sub-** dominios.
Por ej. **https://sitio.nuevo.abyaya.la** o **https://nube.nuevo.abyaya.la**
---
## DEPLOY LOCAL
En este ejemplo, instalaremos todo en nuestro localhost para desarrollo, como si fuera un nodo del proxy.
```
ansible-playbook --become tasks/rap.yml -e "host=localhost nodo=nombrelo" -i hosts.local
```
Esto también es útil para instalar Ansible en nuestra terminal, junto con sus dependencias (Módulos para docker, etc.)
#### SSH PARA DESARROLLO
Para autoconectarse por SSH hay que autorizarse a sí mismx:
```
# Habilitar auto-conexión SSH
cat ~/.ssh/id_ed25519.pub >> ~/.ssh/authorized_keys
```

View File

@ -1,7 +1,229 @@
althost: abyayala
matrix:
- service_name: marmita
- service_name: comun
roles:
- kemal
domains:
- comun.abyaya.la
- service_name: knot
roles:
- knsupdate
- service_name: vpn
roles:
- rap
nodos:
- llavero
- marmite
- nodochasqui
- yanapak
- comun01
- pilmaiken
- fundeps
- lluvia
- lazarzamora
- padiuxi
- otra
- qhanapukara
- gtanw
- pakkiru
- tepeyac
- cpogt
- vmcpogt
- rednasa
- respaldos
- rednasaazun
- comixcal
- nodochasqui
- narkitila
- naxuxi
- padiuxiterminal
- kurmi
- yanapaknodo2
- tule
- fundepsterminal
- jilgerilla
- sutty
- evoterminal
- mexe
- chukao
- cads
- cadt
- puerto
- barrio
- antisistema
- rebeldia
- kipu
- resistencia
- carabobolibre
- samatuun
- kaasavi
- service_name: respaldos
domains:
- respaldos.abyaya.la
nodo: respaldos.comun
force_https: yes
- service_name: marmite
domains:
- marmite.abyaya.la
nodo: marmite.comun
ssl: yes
force_https: yes
- service_name: yanapak
domains:
- yanapak.abyaya.la
nodo: yanapak.comun
force_https: yes
- service_name: comun01
domains:
- comun01.abyaya.la
nodo: comun01.comun
force_https: yes
- service_name: pilmaiken
domains:
- pilmaiken.abyaya.la
nodo: pilmaiken.comun
force_https: yes
ports:
- 222
- service_name: fundeps
domains:
- fundeps.abyaya.la
nodo: fundeps.comun
force_https: yes
- service_name: lluvia
domains:
- lluvia.abyaya.la
nodo: lluvia.comun
force_https: yes
- service_name: lazarzamora
domains:
- lazarzamora.abyaya.la
nodo: lazarzamora.comun
force_https: yes
- service_name: padiuxi
domains:
- padiuxi.abyaya.la
nodo: padiuxi.comun
force_https: yes
- service_name: otra
domains:
- otra.abyaya.la
nodo: otra.comun
force_https: yes
- service_name: qhanapukara
domains:
- qhanapukara.abyaya.la
nodo: qhanapukara.comun
force_https: yes
- service_name: gtanw
domains:
- gtanw.abyaya.la
nodo: gtanw.comun
force_https: yes
- service_name: pakkiru
domains:
- pakkiru.abyaya.la
nodo: pakkiru.comun
force_https: yes
- service_name: tepeyac
domains:
- tepeyac.abyaya.la
nodo: tepeyac.comun
force_https: yes
- service_name: cpogt
domains:
- cpogt.abyaya.la
nodo: cpogt.comun
force_https: yes
- service_name: rednasa
domains:
- rednasa.abyaya.la
nodo: rednasa.comun
force_https: yes
- service_name: sutty
domains:
- sutty.abyaya.la
nodo: sutty.comun
force_https: yes
enable_compression: yes
- service_name: mexe
domains:
- mexe.abyaya.la
nodo: mexe.comun
force_https: yes
- service_name: chukao
domains:
- chukao.abyaya.la
nodo: chukao.comun
force_https: yes
enable_compression: yes
- service_name: cads
domains:
- cads.abyaya.la
nodo: cads.comun
force_https: yes
- service_name: puerto
domains:
- puerto.abyaya.la
nodo: puerto.comun
force_https: yes
- service_name: barrio
domains:
- barrio.abyaya.la
nodo: barrio.comun
force_https: yes
- service_name: rebeldia
domains:
- rebeldia.abyaya.la
nodo: rebeldia.comun
force_https: yes
- service_name: kipu
domains:
- kipu.abyaya.la
nodo: kipu.comun
ports:
- 223
force_https: yes
- service_name: carabobolibre
domains:
- carabobolibre.abyaya.la
nodo: carabobolibre.comun
force_https: yes
- service_name: samatuun
domains:
- samatuun.abyaya.la
nodo: samatuun.comun
force_https: yes
- service_name: kaasavi
domains:
- kaasavi.abyaya.la
nodo: kaasavi.comun
force_https: yes

View File

@ -1,2 +1,12 @@
[defaults]
inventory = ./hosts.production
forks = 10
[ssh_connection]
ssh_args = -C -o ControlMaster=auto -o ControlPersist=1h -o PreferredAuthentications=publickey -o ForwardAgent=yes
control_path_dir = ~/.ansible/cp
control_path = /tmp/ssh-%%r@%%h:%%p
pipelining = True
scp_if_ssh = smart
transfer_method = smart
sftp_batch_mode = True

View File

@ -1,4 +1,4 @@
# ansible-playbook --vault-id @prompt deploy.yml -e "host=digitalocean alt=numerica"
# ansible-playbook --vault-id @prompt deploy.yml -e "alt=abyayala host=hetzner"
# opcional: service define despliegue de servicio especifico
---
- hosts: "{{ host }}"
@ -8,9 +8,9 @@
- include_role: name=althost
- include_role: name=users
tags: users, installation
- include_role: name=firewall
tags: firewall
- include_role: name=proxy
tags: proxy

View File

@ -1,14 +1,31 @@
---
ssh_users:
- name: beto
- name: berto
comment: "Roberto Soto"
sudo: yes
servers_allow:
- all
# - name: latina
# comment: "intra servers"
# root: yes
# servers_allow:
# - macarena.latina.red
- name: infinito
comment: "infinito@fedora"
sudo: yes
servers_allow:
- all
- name: pirra
comment: "pirra@drwagnerjr"
sudo: yes
servers_allow:
- all
- name: chasqui
comment: ""
sudo: yes
servers_allow:
- all
- name: fauno
comment: ""
sudo: yes
servers_allow:
- all

View File

@ -1,2 +1,3 @@
host_ip: 5.161.236.18
proxy_scale: 2
domains_default_force_https: yes

1
group_vars/testing/vars Normal file
View File

@ -0,0 +1 @@
host_ip: 157.180.114.62

View File

@ -1,8 +1,19 @@
[localhost]
127.0.0.1
[abyayala]
[hetzner]
5.161.236.18
[abyayala:vars]
[hetzner:vars]
ansible_ssh_user=root
[sutty]
sutty.nl
[sutty:vars]
[testing]
157.180.114.62
[testing:vars]
ansible_ssh_user=root

View File

@ -1,7 +1,11 @@
# DOCKER CE this is specific for Debian
# https://docs.docker.com/install/linux/docker-ce/debian/
- block:
- name: "unattended upgrades"
apt:
name: "unattended-upgrades"
state: "present"
- name: required packages
apt:
name: ['apt-transport-https', 'ca-certificates', 'curl', 'gnupg2', 'software-properties-common', 'python3-pip']
@ -14,7 +18,7 @@
- name: docker apt repository
apt_repository:
repo: deb [arch=amd64] https://download.docker.com/linux/debian bullseye stable
repo: deb [arch=amd64] https://download.docker.com/linux/debian bookworm stable
- name: install docker community edition
apt:
@ -56,18 +60,6 @@
state: present
break_system_packages: true
# # https://stackoverflow.com/questions/77490435/attributeerror-cython-sources
# - name: fix python package Cython version
# pip:
# name: Cython
# state: present
# version: <3.0.0
# break_system_packages: true
# changed_when: false
# - name: fix python package PyYAML version
# shell: pip install "pyyaml==5.4.1" --no-build-isolation --break-system-packages
- name: ensure python package docker-compose is present
pip:
name: docker-compose
@ -76,7 +68,6 @@
tags: installation
# DOCKER COMPOSITION IN MASTER
- block:
- name: make sure compose path exists

View File

@ -26,7 +26,7 @@
state: started
volumes:
- "{{ althost }}_certs_data:/etc/letsencrypt"
command: "--non-interactive --agree-tos --email {{ webmaster_email }} certonly --preferred-challenges dns --authenticator dns-standalone --dns-standalone-address={{ host_ip }} --dns-standalone-port=53 --dns-standalone-propagation-seconds=60 -d {{ loop.domains[0] }} -d *.{{ loop.domains[0] }}"
command: "--non-interactive --agree-tos --email {{ webmaster_email }} certonly --preferred-challenges dns --authenticator dns-standalone --dns-standalone-address={{ host_ip }} --dns-standalone-port=53 --dns-standalone-propagation-seconds=10 {% for domain in loop.domains %} -d {{ domain }} -d *.{{ domain }} {% endfor %}"
detach: no
cleanup: yes
ports:

View File

@ -2,10 +2,14 @@
apt:
name: dnsmasq
state: present
- name: configuracion de red comun
template:
src: dnsmasq.conf
dest: "/etc/dnsmasq.conf"
notify:
- restart dnsmasq
- name: activar el servicio
systemd_service:
name: dnsmasq
enabled: true
state: restarted

View File

@ -0,0 +1,14 @@
- name: "Paquetes"
apt:
name:
- "iptables-persistent"
- "ipset-persistent"
state: "present"
- name: "Rules"
with_items:
- "rules.v4"
- "rules.v6"
template:
src: "{{ item }}.j2"
dest: "/etc/iptables/{{ item }}"

View File

@ -0,0 +1,18 @@
*filter
:INPUT DROP [106:5591]
:FORWARD DROP [28:1715]
:OUTPUT ACCEPT [0:0]
-A INPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
-A INPUT -m conntrack --ctstate INVALID -j DROP
-A INPUT -p icmp -m icmp --icmp-type 8 -m conntrack --ctstate NEW -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -i comun -j ACCEPT
-A INPUT -p tcp -m tcp --dport 22 -j ACCEPT
-A INPUT -p udp -m udp --dport 53 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 53 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 80 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 443 -j ACCEPT
-A INPUT -p udp -m udp --dport 655 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 655 -j ACCEPT
-A INPUT -p tcp -m tcp --dport 3000 -j ACCEPT
COMMIT

View File

@ -0,0 +1,5 @@
*filter
:INPUT DROP [0:0]
:FORWARD DROP [0:0]
:OUTPUT ACCEPT [0:0]
COMMIT

View File

@ -0,0 +1,10 @@
server {
server_name {{ vhost.domains | join(' ') }};
listen 80;
client_max_body_size 4k;
location / {
proxy_pass http://10.13.12.1:3000;
}
}

View File

@ -0,0 +1,22 @@
- include_vars: dir="../vars" files_matching="main.yml"
- name: import matrix
local_action: "include_vars dir=../../../ files_matching={{ alt }}.yml"
- name: domains' stuff
block:
- name: filtrar solo los servicios de la matrix que definen dominios DNS
set_fact:
matrix_loop: "{{ matrix_loop | default([]) | union([ domino ]) }}"
with_items: "{{ matrix }}"
when: "{{ domino.domains is defined }}"
loop_control:
loop_var: domino
- name: knsupdate ACTUALIZA A KNOT ACERCA DE CADA DOMINIO
include_tasks: ./update.yml
with_items: "{{ matrix_loop }}"
loop_control:
loop_var: vhost
tags: knot

View File

@ -0,0 +1,6 @@
- name: "required packages"
apt:
name: "knot-dnsutils"
state: "present"
- include_tasks: loop.yml

View File

@ -0,0 +1,19 @@
{% for dns_server in dns_servers %}
server {{ dns_server }}
zone abyaya.la.
origin abyaya.la.
ttl 60
del {{ vho }} a
del {{ vho }} ns
add {{ vho }} a {{ host_ip }}
add *.{{ vho }} a {{ host_ip }}
add _acme-challenge.{{ vho }} a {{ host_ip }}
add _acme-challenge.{{ vho }} ns _acme-challenge
{% if vhost.dns_extras is defined %}
{% for dns_extra in vhost.dns_extras %}
{{ dns_extra }}
{% endfor %}
{% endif %}
send
{% endfor %}
quit

View File

@ -0,0 +1,7 @@
- set_fact:
vho: "{{ vhost.domains[0] | regex_replace('([a-z0-9]+)\\.abyaya\\.la', '\\1')}}"
- name: knsupdate
shell: knsupdate
args:
stdin: "{{ lookup('template', 'templates/commands.j2') }}"

View File

@ -0,0 +1,5 @@
dns_servers:
- "anarres.sutty.nl"
- "athshe.sutty.nl"
- "gethen.sutty.nl"
- "ganam.sutty.nl"

View File

@ -0,0 +1 @@
return 301 https://hedgedoc.sutty.abyaya.la$request_uri;

View File

@ -0,0 +1,11 @@
proxy_buffering off;
proxy_request_buffering off;
proxy_redirect off;
proxy_connect_timeout 3m;
proxy_send_timeout 3m;
proxy_read_timeout 3m;
limit_conn connection_limit 50;
limit_req zone=request_limit nodelay burst=20;
add_header Retry-After $retry_after always;

View File

@ -0,0 +1 @@
client_max_body_size 0;

View File

@ -0,0 +1,4 @@
add_header X-Frame-Options "sameorigin";
add_header X-XSS-Protection "1; mode=block";
add_header X-Content-Type-Options "nosniff";
add_header Referrer-Policy "strict-origin-when-cross-origin";

View File

@ -2,21 +2,21 @@
include_role: name=dnsmasq
tags: dns
- name: knsupdate
include_role: name=knsupdate
tags: knot
- name: certbot role
include_role: name=certbot
tags: certbot
- include_tasks: ../../althost/tasks/compose.yml
vars: # forcing since this role is included statically
service_name: proxy
- name: configuration path
file: path={{ conf_path }} state=directory
# TODO leaving unused vhosts bugs proxy
- name: clean vhosts_path
file: path={{ vhosts_path }} state=absent
when: clean_vhosts is defined
- name: configuration paths
file: path={{ comun }} state=directory
with_items:
- "{{ stream_path }}"
- "{{ conf_path }}"
loop_control:
loop_var: comun
- name: virtual hosts path
file: path={{ vhosts_path }} state=directory
@ -31,6 +31,7 @@
with_items:
- common.conf
- common_ssl.conf
- nginx.conf
loop_control:
loop_var: common
@ -40,7 +41,7 @@
set_fact:
matrix_loop: "{{ matrix_loop | default([]) | union([ domino ]) }}"
with_items: "{{ matrix }}"
when: "{{ domino.domains is defined }}"
when: "{{ domino.domains is defined and domino.nodo is defined }}"
loop_control:
loop_var: domino
@ -58,3 +59,22 @@
loop_control:
loop_var: vhost
when: (service is undefined) or (service is defined and service == vhost.service_name)
- name: streams loop
include_tasks: stream.yml
with_items: "{{ matrix_loop }}"
loop_control:
loop_var: vhost
when: (service is undefined) or (service is defined and service == vhost.service_name)
- name: slice matrix with those having ports defined
set_fact:
matrix_ports: "{{ matrix_ports | default([]) | union(ma.ports) }}"
with_items: "{{ matrix }}"
when: (ma.ports is defined)
loop_control:
loop_var: ma
- include_tasks: ../../althost/tasks/compose.yml
vars: # forcing since this role is included statically
service_name: proxy

View File

@ -0,0 +1,10 @@
- set_fact:
vhost_dest: "{{ stream_path }}/{{ vhost.domains[0] }}.conf"
- name: default stream for ssh
template:
src: "{{ default_stream }}"
dest: "{{ vhost_dest }}"
when: vhost.ports is defined
notify:
- reload proxy

View File

@ -1,10 +1,29 @@
- set_fact:
vhost_dest: "{{ vhosts_path }}/{{ vhost.domains[0] }}.conf"
- name: generate nginx vhosts
- block:
- set_fact:
custom_vhost: "roles/{{ vhost.roles[0] }}/templates/vhost.conf"
- set_fact:
proxy_conf: "roles/{{ vhost.roles[0] }}/templates/proxy.conf"
when: vhost.roles is defined
- set_fact:
proxy_conf_look: "{{ lookup('template', proxy_conf) }}"
when: proxy_conf is defined and proxy_conf is is_file
- name: generate default vhosts
template:
src: "{{ default_vhost }}"
dest: "{{ vhost_dest }}"
when: (vhost.roles is undefined or vhost.roles[0] == 'proxy') or (custom_vhost is undefined or custom_vhost is not is_file)
notify:
- reload proxy
- name: generate nginx custom vhosts
template:
src: "{{ custom_vhost }}"
dest: "{{ vhost_dest }}"
when: (vhost.roles is defined and vhost.roles[0] != 'proxy') and custom_vhost is defined and custom_vhost is is_file
notify:
- reload proxy

View File

@ -6,6 +6,14 @@
# openssl dhparam -outform pem -out dhparam2048.pem 2048
ssl_dhparam /etc/nginx/conf/dhparam2048.pem;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:AES128-SHA:AES256-SHA:AES:CAMELLIA:DES-CBC3-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!MD5:!PSK:!aECDH:!EDH-DSS-DES-CBC3-SHA:!EDH-RSA-DES-CBC3-SHA:!KRB5-DES-CBC3-SHA';
ssl_prefer_server_ciphers on;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ecdh_curve X25519:prime256v1:secp384r1;
ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:DHE-RSA-CHACHA20-POLY1305;
ssl_prefer_server_ciphers off;
ssl_session_timeout 1d;
ssl_session_cache shared:MozSSL:10m;
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
ssl_trusted_certificate /etc/ssl/certs/ca-certificates.crt;

View File

@ -1,15 +1,31 @@
# BEGIN PROXY
location / {
proxy_ssl_verify off;
proxy_ssl_name $comun;
proxy_ssl_server_name on;
{% if vhost.enable_compression | default(false) %}
gzip on;
gzip_static on;
gzip_proxied any;
gzip_http_version 1.1;
gzip_comp_level 5;
gzip_min_length 10240;
gzip_vary on;
gzip_types application/atom+xml application/javascript text/javascript application/json application/rss+xml application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/svg+xml image/x-icon text/css text/plain text/x-component;
proxy_pass https://$comun_{{ vhost.nodo | replace(".", "_") }};
gzip_disable "msie6";
{% endif %}
client_max_body_size 1G;
proxy_ssl_verify off;
proxy_ssl_server_name on;
proxy_ssl_name $ssl_server_name;
proxy_pass https://$comun_{{ vhost.nodo | replace(".", "") }};
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Proto https;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection upgrade;
{% include "files/custom_proxy_includes/" ~ vhost.domains[0] ignore missing %}
}

View File

@ -0,0 +1,56 @@
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log notice;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
server_tokens off;
sendfile on;
#tcp_nopush on;
keepalive_timeout 65;
# Limitar cada dirección IP a 50 peticiones por segundo por IP y
# servidor.
limit_req_zone $server_name$binary_remote_addr zone=request_limit:10m rate=10r/s;
limit_req_status 429;
# Limita la cantidad de conexiones concurrentes por IP. Según la
# documentación de Nginx, cada request en HTTP/2 se cuenta como una
# conexión separada aunque sean la misma.
limit_conn_zone $binary_remote_addr zone=connection_limit:10m;
limit_conn_status 429;
# Informar a los navegadores que cuando reciban un error de muchas
# conexiones, esperen un segundo antes de reintentar.
map $status $retry_after {
default '';
429 '1';
}
#gzip on;
include /etc/nginx/conf.d/*.conf;
}
stream {
include /etc/nginx/stream.d/*.conf;
}

View File

@ -8,11 +8,14 @@
ports:
- "80:80"
- "443:443"
{% for port in matrix_ports %}
- "{{ port }}:{{ port }}"
{% endfor %}
networks:
- proxy
volumes:
- "{{ vhosts_path }}:/etc/nginx/conf.d/"
- "{{ conf_path }}:/etc/nginx/conf/"
- "certs_data:{{ nginx_certs_path }}:ro"
- "{{ conf_path }}/nginx.conf:/etc/nginx/nginx.conf:ro"
- "{{ stream_path }}:/etc/nginx/stream.d/"

View File

@ -0,0 +1,11 @@
upstream ssh_{{ vhost.nodo | replace(".", "") }} {
server {{ vhost.nodo }}:22;
}
server {
listen {{ vhost.ports[0] }};
server_name .{{ vhost.domains | join(' .') }};
proxy_pass ssh_{{ vhost.nodo | replace(".", "") }};
}

View File

@ -1,4 +1,4 @@
map $http_host $comun_{{ vhost.nodo | replace(".", "_") }} {
map $http_host $comun_{{ vhost.nodo | replace(".", "") }} {
hostnames;
{% for domain in vhost.domains %}
.{{ domain }} {{ vhost.nodo }};
@ -10,7 +10,7 @@ server {
listen 80;
resolver 127.0.0.1 valid=300s;
resolver 10.13.12.1 valid=300s;
resolver_timeout 5s;
{% if not needs_vhost and ((vhost.ssl | default(domains_default_ssl) ) or (vhost.force_https | default(domains_default_force_https))) %}
@ -38,7 +38,11 @@ server {
include conf/common.conf;
{% include "default_proxy.conf" %}
{% if proxy_conf is defined and proxy_conf is is_file %}
{{ proxy_conf_look }}
{% else %}
{% include "default_proxy.conf" %}
{% endif %}
{% include "files/custom_server_includes/" ~ vhost.domains[0] ignore missing %}

View File

@ -3,12 +3,14 @@ domains_default_force_https: no
# nginx
vhosts_path: "{{ compose_path }}/proxy/vhosts"
stream_path: "{{ compose_path }}/proxy/stream"
conf_path: "{{ compose_path }}/proxy/conf"
nginx_certs_path: /etc/nginx/certs
# defaults
needs_vhost: no
default_vhost: roles/proxy/templates/vhost.conf
default_stream: roles/proxy/templates/stream.conf
# certbot
webmaster_email: webmaster@numerica.cl

1
roles/rap/code/rap Submodule

Submodule roles/rap/code/rap added at ec4cd71e6e

View File

@ -1,16 +0,0 @@
Address = latina.red
Port = 65000
-----BEGIN RSA PUBLIC KEY-----
MIICCgKCAgEAv0oPDlf8mbr8fbiLLfUEucm5QxFLxarqhuph/ui3PmDXoiJGQK0d
zHl92dYDdgRMw+4b1ogThGUZ8ryAt3UtpD8B6oLCRmhGn2tjNIFQN3kUIJQ3aa+M
5nEBf6ys0IHEieUYVHXr5lxSc09Y/wsNbtATVZ25VT0ercR0c3gbpcypu8JpTdyn
iul43IXiO8zKjeQhn9VQAnwIMzAa+6Y5Aj4y2HtFsUqzjJYY3KZBRTTNR1277QJ8
NDMuQT0opE79E8ipOZaOdcFRZIUOG8cBhhavozSVCzjI8A1iA8QrJpEjo/zjV+D4
h5EQpztvvzYdlOsE/9Cclc+iAGbnxOUt6K2bopMu/TI+gNh7DoA2wgFZ7DlQhCuO
MiYV+9dzI4gKZvAO0IxiGnmq8s2UjWRnD9zVZztU5IOE1xBo7OrmcHnnOvsMMsmx
Bc8F8jR6u8XgfSODS22sNK62N9joC2E3Gg/ulW75IUqIlyyHumwjm0XMuIXI6qDZ
AUv0lOnYOWATveQlgCqLO9OyJmocbejz1ZtkcLgI/EDzwDYEpaKLf+39a7eLuNRa
sqf+BIoJkGxi6LVG8gW5YhOLaaPclmsOztiID7vPHs0jH4bY7N0JR2TI8aaIlY9O
P6ZJArG60IPtMUvurTrSmUGdHLoSg6+PSPZLfYMXoqKatrAhdEcc9ssCAwEAAQ==
-----END RSA PUBLIC KEY-----

View File

@ -1,16 +0,0 @@
Address = tierra
Port = 65000
-----BEGIN RSA PUBLIC KEY-----
MIICCgKCAgEAtr75G3mVKBr8k7Sz5LQLuOBMdN2cwIZVQt0BVPq/gWeUowDPM8he
QcjmSDZrwRE0NUQRiB5/Gicb9UXoQaEfq7xQfgcMl4Nt9MfHbhY6sORviAyHOsjM
xYw/vy5SfWq3O7E/sH01BEbUt5r/oVoG2dy2rDQ5xBW30zeMJisvTMH5kMwHAWIG
kdq0xI1WgFEa8eXo004Li8QD9k064wajN3mU0rUXEY0FCl9GbjP1S6a6ge3Sz+MP
Je5RZzbNxvtY/YVeQBzjwUDawsjTZ9Lx968U9RaO2Z7LBrltLSSVU4aw6tH78zN8
qVZ5PR0LmUQ38FWYNGcbUtfWRQACZOYkgBKbR0UOyLIbEODMUMmqZD7yOwAWf9BI
Tw8NemFmkCs+Jb2LrayIOYaqvV3iY01oL2NgPhjV01XLs51GnHmiWUTfsEvu1lmM
2uJoX75AzlL8We2RgWjknux3m4ce1sVTzMM36uatoz2lLDwBw9F6RKd2h6Gwb0kI
k5ltlnjEttyQg/X1NowQClOfaUza+75mGaj1owK1zoYWZEUk4iRwoCT0KM1jnSKz
z4w0uDz9YHhHDEG/evD6VLgPLcXdU2a+dKMU5GLGOcElKxi0p9bfzLJ9Efb2+PEY
IJYfFlMT3YEacWsxLFuxUGbTbVCNccCIwv6QVQ8gnio+rowr8q64wwkCAwEAAQ==
-----END RSA PUBLIC KEY-----

View File

@ -0,0 +1,38 @@
# DHCLIENT ESTA DEPRCADO
# https://serverfault.com/questions/1108989/isc-dhcp-client-dhclient-alternative
- name: instalar dependecias de la RAP
apt:
name: ['tinc', 'rsync', 'dhcp5']
state: latest
# update_cache: yes
tags: installation
- include_vars: dir="../vars" files_matching="main.yml"
- name: copiar el codigo fuente
synchronize:
src: ../roles/rap/code/rap
dest: "{{ rap_path }}"
perms: true
- name: hacer ejecutable el archivo rap
file:
path: "{{ rap_path }}/rap/rap"
state: touch
mode: '774'
modification_time: preserve
access_time: preserve
- name: inicializar el nodo
shell:
cmd: "./rap init -i {{ nodo }}"
chdir: "{{ rap_path }}/rap"
environment:
NETWORK: comun
- name: instalar el nodo
shell:
cmd: "./rap install -v {{ nodo }}"
chdir: "{{ rap_path }}/rap"
environment:
NETWORK: comun

39
roles/rap/tasks/main.yml Normal file
View File

@ -0,0 +1,39 @@
- name: instalar dependecias de la RAP
apt:
name: ['tinc', 'rsync', 'git']
state: present
tags: installation
- name: Verificar si ya existe el codigo fuente
stat:
path: "{{ rap_path }}"
register: rap_status
- name: copiar el codigo fuente, si no existe
synchronize:
src: ../roles/rap/code/rap/
dest: "{{ rap_path }}"
perms: true
rsync_opts:
- "--exclude=.git"
tags: rap
when: not rap_status.stat.exists
- name: agregar nodos a la VPN
shell:
cmd: "./rap add-host {{ althost }} {{ nod }}"
chdir: "{{ rap_path }}"
args:
creates: "{{ rap_path }}/networks/comun/abyayala/hosts/{{ nod }}"
environment:
NETWORK: comun
with_items: "{{ item.nodos }}"
loop_control:
loop_var: nod
- name: actualizar la VPN
shell:
cmd: "./rap install -v {{ althost }}"
chdir: "{{ rap_path }}"
environment:
NETWORK: comun

1
roles/rap/vars/main.yml Normal file
View File

@ -0,0 +1 @@
rap_path: "/root/rap"

View File

@ -0,0 +1 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCrhho0oQcAWX6ndpwxkNykJTohUg6vvEplqBa5pENU1gD61eahP4BU4weGrOWY28fBy3BhXOYFITWOxmdv7V7T9fG8WKXqT8MHkC9zaLzAZJ11tHq8OeDo0QGkBOoetf0dv0e3+FNijA9QKhqiwz+v0t5Ev0bSuSl28zHI3Tr0vF98SZulIR9CxDTTPA+Hel2Tl+LcVDZb80/tG9oAFBctzMK7AWB80X/DgXVfY0qgP97809JPX+Cqo/Q+LK55HxeDnfqDsA3m3KXQPODZm6ATEfmcx3MBYqJ8m0rdMKBwR16xDvAyB/LezHVCgmQvmzTRgzTwwwitOX83F5oIEArTK64s1dm0VLzj+Pw5Tetkde4YPHfajffXUbUxGTgD6M3NCvCLHedDMQDQT3LNOfFJGngGcwWJdStmMCWR6dd81epzPZiWHEZ093UWCPtE8kvrL4fRfIc/qSKWNCIyAoagKw4SwwyOfg0ONBJpjOfI7+vBKJVCZSDZQYyU/+Bo60k= berto@concon

View File

@ -0,0 +1 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAII3J2KEOs3PN50dRiA69qci3XV8vUtbd13RWYjRZzAVV chasqui@laboportatil

View File

@ -0,0 +1 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIOceAWSgtO+0pFhvhYGMlHTbpXIN1LDJK1Hx0qgw9qW fauno@local

View File

@ -0,0 +1 @@
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJYJlf9XD7scKJIQX7ufxYSiZ9FALOiXPLy6g3oKyR56 infinito@fedora

View File

@ -0,0 +1 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCrhho0oQcAWX6ndpwxkNykJTohUg6vvEplqBa5pENU1gD61eahP4BU4weGrOWY28fBy3BhXOYFITWOxmdv7V7T9fG8WKXqT8MHkC9zaLzAZJ11tHq8OeDo0QGkBOoetf0dv0e3+FNijA9QKhqiwz+v0t5Ev0bSuSl28zHI3Tr0vF98SZulIR9CxDTTPA+Hel2Tl+LcVDZb80/tG9oAFBctzMK7AWB80X/DgXVfY0qgP97809JPX+Cqo/Q+LK55HxeDnfqDsA3m3KXQPODZm6ATEfmcx3MBYqJ8m0rdMKBwR16xDvAyB/LezHVCgmQvmzTRgzTwwwitOX83F5oIEArTK64s1dm0VLzj+Pw5Tetkde4YPHfajffXUbUxGTgD6M3NCvCLHedDMQDQT3LNOfFJGngGcwWJdStmMCWR6dd81epzPZiWHEZ093UWCPtE8kvrL4fRfIc/qSKWNCIyAoagKw4SwwyOfg0ONBJpjOfI7+vBKJVCZSDZQYyU/+Bo60k= berto@concon

View File

@ -0,0 +1 @@
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC6XFkmTCotjxvlwxcmXrZcs7nmY/gtgc4FQorge9EGBWBXDLy3+tMel0XzHu9P8vKGGPEiw9TjIyBG6sEujwq74+q3rR6w2WfELEXRfIyq7HXpWtmL7RUYRrz7syfCvof8YXAPbYGv/ai7IYI41VzOHaI3mliIX+T5R74954ksI72n/qzsYHdiMHkYOGcO8P/n6T2R/SIdXCkDeCuc47IPVjSb4jTC5elv6p5YPSTozEcRP2TgkjWAa+JHXhzbknHUv6qphJVVSn66O5TYZJBXfkM0v4+7sm8k6nMP7CFkvyAN/YuvL+ZDy3XXQacG7c39meXlCdW0czyhjsvJLyaoZoH5mXPJAQkTJO8bZhJTs26gOCih9mpjr9DjbLKEv85/qyKbzUCxoBqOeaD58De1g9csy0eFo2wMx4xczKKUoWDBswOL58AfXX9CV/pPMbgjIYrkcKzfVxxfeNH+UwNLaC+J1iiHX7V1vVK1D0hQOKbEH/LdOFEzUTmluLsOwd4OXc00cPzsfqal9tiJ9/FIP9fbcCg6z+8zkZaC07+9XpclnmN9Zm0mx7JLzeFgJU1N0ij3rEA399ZjQmcnXjtFM0tW0catBvBIKi7ltxZ+FeGTDoS3w4NhMJkfzs93OSjE2kBtROwHYDM1vUpv/nzNg/DaCJ9HA2VAx0C7sMOlUQ== pirra@drwagnerjr

8
tasks/knot.yml Normal file
View File

@ -0,0 +1,8 @@
# Instalacion de KNOT - por ahora se ejecuta contra sutty, con variable host (local) e inventario especificado
# ansible-playbook --become tasks/knot.yml -e "host=localhost alt=abyayala" -i hosts.local
---
- hosts: "{{ host }}"
tasks:
- name: actualizacion de KNOT en el servidor DNS en la configuracion por vhost
include_tasks: ../roles/knsupdate/tasks/loop.yml

View File

@ -1,72 +1,7 @@
# ansible-playbook rap.yml -e "host=hetzner"
# Instalacion de la RAP en maquina local
# ansible-playbook --become tasks/rap.yml -e "host=localhost nodo=chem" -i hosts.local
---
- hosts: "{{ host }}"
vars:
rap:
port: 65000
rap_dir: "{{ directory | default('/root') }}"
environment:
PATH: "/usr/sbin:{{ ansible_env.PATH }}"
tasks:
- name: install dependencies
package:
name: "{{ item }}"
state: present
loop:
- rsync
- git
- tinc
become: yes
- name: iptables
iptables:
action: append
chain: INPUT
table: filter
destination_port: "{{ rap.port }}"
protocol: "{{ item }}"
jump: ACCEPT
loop:
- tcp
- udp
become: yes
- name: install rap
git:
repo: "https://0xacab.org/pip/rap.git"
dest: "{{ rap_dir }}/rap"
- set_fact:
hostname: "{% if '{{ host }} != localhost' %} {{ ansible_hostname }} {% else %} {{ inventory_hostname }} {% endif %}"
# inventory_hostname=> localhost/IP | ansible_hostname=>infra
- name: node name
shell: 'echo {{ hostname }} | tr -cd "[:alnum:]" | tr "[:upper:]" "[:lower:]"'
register: node_name
changed_when: false
- stat:
path: "{{ rap_dir }}/rap/hosts/{{ node_name.stdout }}"
register: node_exists
- name: init node
when: "node_exists.stat.exists == False"
shell: "cd {{ rap_dir }}/rap && ./rap init -f -a {{ hostname }} -p {{ rap.port }}"
- name: fetch hosts files
fetch:
flat: true
src: "{{ rap_dir }}/rap/hosts/{{ node_name.stdout }}"
dest: "./rap/hosts/{{ node_name.stdout }}"
- name: copy hosts files
copy:
src: "./rap/hosts/"
dest: "{{ rap_dir }}/rap/hosts/"
- name: connectto
shell: 'cd {{ rap_dir }}/rap && for host in ./hosts/*; do test "./hosts/{{ node_name.stdout }}" = "${host}" && continue ; basename "${host}" | xargs -r ./rap connectto "{{ node_name.stdout }}"; done'
- name: install node
shell: "cd {{ rap_dir }}/rap && ./rap install {{ node_name.stdout }}"
- name: instalacion de la RAP en maquina cliente
include_tasks: ../roles/rap/tasks/client.yml

View File

@ -1,6 +1,7 @@
# ansible-playbook --vault-id @prompt users.yml -e "host=hetzner"
# Creacion de usuarixs linux y publicacion de llaves ssh
# ansible-playbook tasks/users.yml -e "host=localhost"
---
- hosts: "{{ host }}"
tasks:
- include_role:
name: users
- name: llamar al rol tasks
include_tasks: ../roles/users/tasks/main.yml

23
testnet.yml Normal file
View File

@ -0,0 +1,23 @@
althost: testnet
matrix:
- service_name: comun
roles:
- kemal
domains:
- comun.abyayala.red
- service_name: dns
roles:
- knsupdate
- service_name: vpn
roles:
- rap
nodos:
- qi
- service_name: qi
domains:
- qi.abyayala.red
nodo: qi.comun
# force_https: yes