✨ feat(infrastructure): introduce ansible deployment for taler services
- add ansible playbooks and roles for deploying taler exchange and merchant
- configure PostgreSQL, GNU Taler repositories, and services
🔧 chore(config): provide example env and gitignore for sensitive files
- create .env-example with placeholders for sensitive info
- add .gitignore entries for .env and common editor files
This commit is contained in:
parent
ca89a06864
commit
fdc9234540
18 changed files with 525 additions and 0 deletions
26
roles/taler_exchange/handlers/main.yml
Normal file
26
roles/taler_exchange/handlers/main.yml
Normal file
|
|
@ -0,0 +1,26 @@
|
|||
---
|
||||
- name: Restart taler-exchange-httpd
|
||||
ansible.builtin.service:
|
||||
name: taler-exchange-httpd
|
||||
state: restarted
|
||||
|
||||
- name: Restart taler-exchange-aggregator
|
||||
ansible.builtin.service:
|
||||
name: taler-exchange-aggregator
|
||||
state: restarted
|
||||
|
||||
- name: Restart taler-exchange-closer
|
||||
ansible.builtin.service:
|
||||
name: taler-exchange-closer
|
||||
state: restarted
|
||||
|
||||
- name: Restart taler-exchange-transfer
|
||||
ansible.builtin.service:
|
||||
name: taler-exchange-transfer
|
||||
state: restarted
|
||||
|
||||
- name: Restart taler-exchange-wirewatch
|
||||
ansible.builtin.service:
|
||||
name: taler-exchange-wirewatch
|
||||
state: restarted
|
||||
|
||||
63
roles/taler_exchange/tasks/main.yml
Normal file
63
roles/taler_exchange/tasks/main.yml
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
- name: Ensure master public key is provided
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- taler_config.exchange_master_key is defined
|
||||
- taler_config.exchange_master_key | length > 0
|
||||
fail_msg: "Provide TALER_MASTER_PUBLIC_KEY in .env before running exchange deployment."
|
||||
|
||||
- name: Install GNU Taler exchange packages
|
||||
ansible.builtin.apt:
|
||||
name:
|
||||
- taler-exchange
|
||||
- taler-exchange-httpd
|
||||
- taler-exchange-aggregator
|
||||
- taler-exchange-closer
|
||||
- taler-exchange-transfer
|
||||
- taler-exchange-wirewatch
|
||||
state: present
|
||||
|
||||
- name: Ensure exchange runtime directories exist
|
||||
ansible.builtin.file:
|
||||
path: "{{ item }}"
|
||||
state: directory
|
||||
owner: taler-exchange-httpd
|
||||
group: taler-exchange-httpd
|
||||
mode: "0750"
|
||||
loop:
|
||||
- /var/lib/taler/exchange
|
||||
- /etc/taler/conf.d
|
||||
|
||||
- name: Deploy exchange configuration
|
||||
ansible.builtin.template:
|
||||
src: exchange.conf.j2
|
||||
dest: /etc/taler/conf.d/exchange.conf
|
||||
owner: root
|
||||
group: root
|
||||
mode: "0640"
|
||||
notify:
|
||||
- Restart taler-exchange-httpd
|
||||
- Restart taler-exchange-aggregator
|
||||
- Restart taler-exchange-closer
|
||||
- Restart taler-exchange-transfer
|
||||
- Restart taler-exchange-wirewatch
|
||||
|
||||
- name: Run taler-exchange-dbinit
|
||||
ansible.builtin.command:
|
||||
cmd: taler-exchange-dbinit -c /etc/taler/conf.d/exchange.conf
|
||||
register: dbinit_result
|
||||
changed_when: "'already initialized' not in dbinit_result.stdout"
|
||||
failed_when: dbinit_result.rc not in [0]
|
||||
become: true
|
||||
become_user: taler-exchange-httpd
|
||||
|
||||
- name: Validate exchange configuration
|
||||
ansible.builtin.command:
|
||||
cmd: taler-config -c /etc/taler/conf.d/exchange.conf -s exchange -o CURRENCY
|
||||
register: exchange_config_validation
|
||||
changed_when: false
|
||||
|
||||
- name: Assert exchange currency matches expected
|
||||
ansible.builtin.assert:
|
||||
that:
|
||||
- exchange_config_validation.stdout.strip() == taler_config.currency
|
||||
fail_msg: "Exchange currency does not match expected value {{ taler_config.currency }}. Check configuration."
|
||||
47
roles/taler_exchange/templates/exchange.conf.j2
Normal file
47
roles/taler_exchange/templates/exchange.conf.j2
Normal file
|
|
@ -0,0 +1,47 @@
|
|||
# Generated by Ansible - manual edits will be overwritten.
|
||||
[exchange]
|
||||
BASE_URL = https://{{ taler_config.exchange_host }}/
|
||||
CURRENCY = {{ taler_config.currency }}
|
||||
DB = postgres
|
||||
MASTER_PUBLIC_KEY = {{ taler_config.exchange_master_key }}
|
||||
IDLE_RESERVE_EXPIRATION_TIME = 4 weeks
|
||||
RESHARE_RESERVE_EXPIRATION_TIME = 8 weeks
|
||||
|
||||
{% set exchange_user = taler_config.db.exchange.user %}
|
||||
{% set exchange_pass = taler_config.db.exchange.password %}
|
||||
{% set exchange_auth = exchange_user if not exchange_pass else exchange_user ~ ':' ~ exchange_pass %}
|
||||
[exchangedb-postgres]
|
||||
CONFIG = postgres://{{ exchange_auth }}@{{ taler_config.db.host }}:{{ taler_config.db.port }}/{{ taler_config.db.exchange.name }}
|
||||
|
||||
[coin_{{ taler_config.currency | lower }}_1]
|
||||
VALUE = {{ taler_config.currency }}:0.50
|
||||
DURATION_WITHDRAW = 12 weeks
|
||||
DURATION_SPEND = 52 weeks
|
||||
DURATION_DEPOSIT = 104 weeks
|
||||
DURATION_LEGAL = 208 weeks
|
||||
FEE_WITHDRAW = 0.00 {{ taler_config.currency }}
|
||||
FEE_DEPOSIT = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFRESH = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFUND = 0.00 {{ taler_config.currency }}
|
||||
|
||||
[coin_{{ taler_config.currency | lower }}_2]
|
||||
VALUE = {{ taler_config.currency }}:1.00
|
||||
DURATION_WITHDRAW = 12 weeks
|
||||
DURATION_SPEND = 52 weeks
|
||||
DURATION_DEPOSIT = 104 weeks
|
||||
DURATION_LEGAL = 208 weeks
|
||||
FEE_WITHDRAW = 0.00 {{ taler_config.currency }}
|
||||
FEE_DEPOSIT = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFRESH = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFUND = 0.00 {{ taler_config.currency }}
|
||||
|
||||
[coin_{{ taler_config.currency | lower }}_3]
|
||||
VALUE = {{ taler_config.currency }}:5.00
|
||||
DURATION_WITHDRAW = 12 weeks
|
||||
DURATION_SPEND = 52 weeks
|
||||
DURATION_DEPOSIT = 104 weeks
|
||||
DURATION_LEGAL = 208 weeks
|
||||
FEE_WITHDRAW = 0.00 {{ taler_config.currency }}
|
||||
FEE_DEPOSIT = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFRESH = 0.00 {{ taler_config.currency }}
|
||||
FEE_REFUND = 0.00 {{ taler_config.currency }}
|
||||
Loading…
Add table
Add a link
Reference in a new issue