Browse Source

Cyclos docker containers added to docker-compose.yml + complete init script for odoo & cyclos

dev
Maxime Mazouth-Laurol 5 years ago
parent
commit
b9f37d570d
  1. 24
      src/.env.dist
  2. 2
      src/.gitignore
  3. 6
      src/Dockerfile
  4. 99
      src/docker-compose.yml
  5. 121
      src/etc/cyclos/cyclos_constants.yml.sample
  6. 120
      src/etc/cyclos/cyclos_constants_dev.yml
  7. 245786
      src/etc/cyclos/dump/cyclos.sql
  8. 245786
      src/etc/cyclos/dump/cyclos_test.sql
  9. 460
      src/etc/cyclos/init_test_data.py
  10. 120
      src/etc/cyclos/script_clean_database.sql
  11. 90
      src/etc/cyclos/script_transaction_extensionpoint.groovy
  12. 80
      src/etc/cyclos/script_transfer_extensionpoint.groovy
  13. 2878
      src/etc/cyclos/setup.py
  14. 43
      src/etc/cyclos/setup_cyclos.sh
  15. 162
      src/init.sh

24
src/.env.dist

@ -0,0 +1,24 @@
## Location of the charm-store (to build postgres)
CHARM_STORE=/home/cairn/.charm-store
## Password for postgres's 'odoo' user
PG_DATABASE=odoo
PG_USER=odoo
PG_PASS=password
## Password for odoo admin tasks (create/delete/archive databases)
ODOO_ADMIN_PASSWORD=password
## Password for postgres admin user 'postgres'
POSTGRES_ROOT_PASSWORD=password
CYCLOS_PORT=1234
CURRENCY_SLUG=cairn
CURRENCY_SYMBOL=CRN
ENV=dev
SESSION_TIMEOUT=1500
MIN_LENGTH_PWD=8
MAX_LENGTH_PWD=25
POSTGRES_DB=cyclos
POSTGRES_USER=cyclos
POSTGRES_PASSWORD=cyclos

2
src/.gitignore

@ -0,0 +1,2 @@
.env
./logs/cyclos/*

6
src/Dockerfile

@ -0,0 +1,6 @@
FROM cyclos/cyclos:4.11.2
RUN set -x; \
apt-get update \
&& apt-get install -y --no-install-recommends python3 \
python3-requests python3-slugify python3-yaml

99
src/docker-compose.yml

@ -0,0 +1,99 @@
version: '3.5'
networks:
mlc_net:
driver: bridge
name: mlc_net
services:
odoo:
image: docker.0k.io/mirror/odoo:rc_12.0-MYC-INIT
container_name: odoo_server
ports:
- 8069:8069
command:
- odoo
- --config=/opt/odoo/auto/odoo.conf
- --workers=1
- -i base,l10n_fr
- --database=odoo
- --addons-path=/opt/odoo/auto/my_addons,/opt/odoo/auto/addons
environment:
- ADMIN_PASSWORD=${ODOO_ADMIN_PASSWORD}
- INITIAL_LANG=fr_FR
- LIST_DB='true'
- PGDATABASE=${PG_DATABASE}
- PGHOST=postgres
- PGPASSWORD=${PG_PASS}
- PGUSER=${PG_USER}
restart: unless-stopped
tty: true
volumes:
## Volume is changed from normal 'compose' build
- ./etc/cyclos:/cyclos
- odoo-data:/var/lib/odoo:rw
- ./my_addons:/opt/odoo/auto/my_addons
depends_on:
- postgres
- cyclos-app
networks:
- mlc_net
postgres:
build: ${CHARM_STORE}/postgres/build
container_name: postgres_odoo
restart: unless-stopped
volumes:
## Volume is changed from normal 'compose' build
- postgres-data:/var/lib/postgresql/data:rw
## Was added, differing from the normal 'compose' build
environment:
- POSTGRES_ROOT_PASSWORD
- PG_DATABASE
- PG_USER
- PG_PASS
networks:
- mlc_net
cyclos-app:
build: .
container_name: cyclos-app
environment:
- CURRENCY_SLUG=${CURRENCY_SLUG}
- CURRENCY_SYMBOL=${CURRENCY_SYMBOL}
- ENV=${ENV}
- SESSION_TIMEOUT=${SESSION_TIMEOUT}
- MIN_LENGTH_PWD=${MIN_LENGTH_PWD}
- MAX_LENGTH_PWD=${MAX_LENGTH_PWD}
- DB_HOST=cyclos-db
- DB_NAME=${POSTGRES_DB}
- DB_USER=${POSTGRES_USER}
- DB_PASSWORD=${POSTGRES_PASSWORD}
ports:
- '${CYCLOS_PORT}:8080'
volumes:
- ./etc/cyclos:/cyclos
- ./logs/cyclos:/var/log/cyclos
depends_on:
- cyclos-db
networks:
- mlc_net
cyclos-db:
image: cyclos/db
container_name: cyclos-db
environment:
- POSTGRES_DB=${POSTGRES_DB}
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
volumes:
- ./etc/cyclos/dump/cyclos.sql:/docker-entrypoint-initdb.d/cyclos.sql
- ./data/cyclos/postgresql:/var/lib/postgresql/data
networks:
- mlc_net
## new section
volumes:
odoo-data:
postgres-data:

121
src/etc/cyclos/cyclos_constants.yml.sample

@ -0,0 +1,121 @@
access_clients:
point_de_vente_nfc: -7371965201600299221
account_types:
banque_de_depot: -7371965184420430037
caisse_euro_bdc: -7371965205895266517
caisse_eusko_bdc: -7371965175830495445
compte_d_adherent: -7371965162945593557
compte_de_debit_euro: -7371965197305331925
compte_de_debit_eusko_billet: -7371965214485201109
compte_de_debit_eusko_numerique: -7371965158650626261
compte_de_transit: -7371965223075135701
compte_dedie: -7371965188715397333
compte_des_billets_en_circulation: -7371965193010364629
retours_d_eusko_bdc: -7371965180125462741
stock_de_billets: -7371965218780168405
stock_de_billets_bdc: -7371965201600299221
currencies:
euro: -7371965218780168405
eusko: -7371965214485201109
groups:
adherents_prestataires: -7371965180125462741
adherents_sans_compte: -7371965158650626261
adherents_utilisateurs: -7371965184420430037
anonyme: -7371965197305331925
banques_de_depot: -7371965205895266517
bureaux_de_change: -7371965201600299221
comptes_dedies: -7371965175830495445
gestion_interne: -7371965223075135701
operateurs_bdc: -7371965193010364629
porteurs: -7371965188715397333
password_types:
login_password: -7371965214485201109
one_time_password: -7371965193010364629
pin: -7371965223075135701
transaction_password: -7371965218780168405
payment_modes:
cheque: -7371965214485201109
especes: -7371965218780168405
paiement_en_ligne: -7371965223075135701
prelevement: -7371965193010364629
virement: -7371965197305331925
payment_types:
change_billets_versement_des_euro: -7371965188715397333
change_numerique_en_bdc_versement_des_euro: -7371965235960037589
change_numerique_en_ligne_versement_des_euro: -7371965227370102997
change_numerique_en_ligne_versement_des_eusko: -7371965231665070293
cotisation_en_euro: -7371965167240560853
cotisation_en_eusko: -7371965171535528149
credit_du_compte: -7371965351924154581
de_retours_d_eusko_bdc_vers_stock_de_billets_bdc: -7371965343334219989
de_stock_de_billets_bdc_vers_retours_d_eusko_bdc: -7371965339039252693
depot_de_billets: -7371965347629187285
depot_en_banque: -7371965287499645141
destruction_de_billets_d_eusko: -7371965218780168405
entree_coffre: -7371965193010364629
entree_stock_bdc: -7371965197305331925
gain_de_billets: -7371965184420430037
impression_de_billets_d_eusko: -7371965214485201109
paiement_de_banque_de_depot_vers_caisse_euro_bdc: -7371965261729841365
paiement_de_caisse_euro_bdc_vers_banque_de_depot: -7371965266024808661
paiement_par_carte: -7371965334744285397
perte_de_billets: -7371965180125462741
reconversion_billets_versement_des_eusko: -7371965162945593557
reconversion_numerique: -7371965240255004885
regularisation_depot_excessif: -7371965270319775957
regularisation_depot_insuffisant: -7371965291794612437
remise_d_euro_en_caisse: -7371965274614743253
retrait_de_billets: -7371965356219121877
retrait_du_compte: -7371965360514089173
sortie_caisse_eusko_bdc: -7371965205895266517
sortie_coffre: -7371965223075135701
sortie_retours_eusko_bdc: -7371965175830495445
sortie_stock_bdc: -7371965201600299221
vente_en_euro: -7371965278909710549
vente_en_eusko: -7371965283204677845
virement_de_banque_de_depot_vers_compte_debit_euro: -7371965244549972181
virement_de_banque_de_depot_vers_compte_dedie: -7371965248844939477
virement_de_compte_dedie_vers_compte_debit_euro: -7371965253139906773
virement_entre_comptes_dedies: -7371965257434874069
virement_inter_adherent: -7371965330449318101
products:
foulard: -7371965201600299221
system_accounts:
compte_de_debit_euro: -7371965197305331925
compte_de_debit_eusko_billet: -7371965214485201109
compte_de_debit_eusko_numerique: -7371965201600299221
compte_de_transit: -7371965223075135701
compte_des_billets_en_circulation: -7371965193010364629
stock_de_billets: -7371965218780168405
tokens:
carte_nfc: -7371965197305331925
transaction_custom_fields:
adherent: -7371965223075135701
adherent_facultatif: -7371965193010364629
bdc: -7371965214485201109
mode_de_paiement: -7371965197305331925
montant_changes_billet: -7371965184420430037
montant_changes_numerique: -7371965188715397333
montant_cotisations: -7371965175830495445
montant_ventes: -7371965180125462741
numero_de_bordereau: -7371965205895266517
numero_de_facture: -7371965162945593557
numero_de_transaction_banque: -7371965158650626261
porteur: -7371965218780168405
produit: -7371965201600299221
transfer_status_flows:
rapprochement: -7371965214485201109
remise_a_euskal_moneta: -7371965218780168405
virements: -7371965223075135701
transfer_statuses:
a_rapprocher: -7371965218780168405
a_remettre_a_euskal_moneta: -7371965193010364629
rapproche: -7371965214485201109
remis_a_euskal_moneta: -7371965223075135701
virements_a_faire: -7371965201600299221
virements_faits: -7371965197305331925
user_custom_fields:
bdc: -7371965214485201109
users:
compte_dedie_eusko_billet: -7371965218780168405
compte_dedie_eusko_numerique: -7371965223075135701

120
src/etc/cyclos/cyclos_constants_dev.yml

@ -0,0 +1,120 @@
access_clients:
client_sms: -1928164551898939653
main: -1567876581709299973
point_de_vente_nfc: -2000222145936867589
account_types:
banque_de_depot: -1711991769785155845
caisse_euro_bdc: -1928164551898939653
caisse_mlc_bdc: -1567876581709299973
compte_d_adherent: -1423761393633444101
compte_de_credit_coffre_numerique: -1279646205557588229
compte_de_debit_euro: -1784049363823083781
compte_de_debit_mlc_billet: -2072279739974795525
compte_de_debit_mlc_numerique: -1207588611519660293
compte_de_transit: -2216394928050651397
compte_dedie: -1639934175747227909
compte_des_billets_en_circulation: -1856106957861011717
retours_d_mlc_bdc: -1495818987671372037
stock_de_billets: -2288452522088579333
stock_de_billets_bdc: -2000222145936867589
currencies:
euro: -2288452522088579333
mlc: -2072279739974795525
groups:
adherents_prestataires: -1495818987671372037
adherents_sans_compte: -1279646205557588229
adherents_utilisateurs: -1711991769785155845
anonyme: -1784049363823083781
banques_de_depot: -1928164551898939653
bureaux_de_change: -2000222145936867589
comptes_dedies: -1567876581709299973
gestion_interne: -2216394928050651397
operateurs_bdc: -1856106957861011717
porteurs: -1639934175747227909
password_types:
login_password: -2072279739974795525
one_time_password: -1856106957861011717
pin: -2216394928050651397
transaction_password: -2288452522088579333
payment_modes:
cheque: -2072279739974795525
especes: -2288452522088579333
paiement_en_ligne: -2216394928050651397
prelevement: -1856106957861011717
virement: -1784049363823083781
payment_types:
change_billets_versement_des_euro: -1207588611519660293
change_numerique_en_bdc_versement_des_euro: -4450180343226417413
change_numerique_en_ligne_versement_des_euro: -270839889026597125
change_numerique_en_ligne_versement_des_mlc: -198782294988669189
cotisation_en_euro: -991415829405876485
cotisation_en_mlc: -919358235367948549
creation_mlc_numeriques: -1856106957861011717
credit_du_compte: -4522237937264345349
de_retours_des_mlc_bdc_vers_stock_de_billets_bdc: -4017834778998849797
de_stock_de_billets_bdc_vers_retours_de_mlc_bdc: -3801661996885065989
depot_de_billets: -4594295531302273285
depot_en_banque: -703185453254164741
destruction_de_billets_mlc: -2288452522088579333
destruction_mlc_numeriques: -1784049363823083781
entree_coffre: -2000222145936867589
entree_stock_bdc: -1928164551898939653
gain_de_billets: -1279646205557588229
impression_de_billets_mlc: -2072279739974795525
paiement_de_banque_de_depot_vers_caisse_euro_bdc: -847300641330020613
paiement_de_caisse_euro_bdc_vers_banque_de_depot: -775243047292092677
paiement_par_carte: -3873719590922993925
paiement_par_sms: -4234007561112633605
perte_de_billets: -1639934175747227909
reconversion_billets_versement_des_mlcs: -1351703799595516165
reconversion_numerique: -4378122749188489477
regularisation_depot_excessif: -414955077102452997
regularisation_depot_insuffisant: -631127859216236805
remise_d_euro_en_caisse: -342897483064525061
retrait_de_billets: -4161949967074705669
retrait_du_compte: -4089892373036777733
sortie_caisse_mlc_bdc: -1495818987671372037
sortie_coffre: -2216394928050651397
sortie_retours_mlc_bdc: -1711991769785155845
sortie_stock_bdc: -1567876581709299973
vente_en_euro: -1135531017481732357
vente_en_mlc: -1063473423443804421
virement_de_banque_de_depot_vers_compte_debit_euro: -559070265178308869
virement_de_banque_de_depot_vers_compte_dedie: -487012671140380933
virement_de_compte_dedie_vers_compte_debit_euro: -126724700950741253
virement_entre_comptes_dedies: -54667106912813317
virement_inter_adherent: -4306065155150561541
products:
foulard: -2000222145936867589
tokens:
carte_nfc: -1784049363823083781
transaction_custom_fields:
adherent: -2216394928050651397
adherent_facultatif: -1856106957861011717
bdc: -2072279739974795525
mode_de_paiement: -1784049363823083781
montant_changes_billet: -1711991769785155845
montant_changes_numerique: -1639934175747227909
montant_cotisations: -1567876581709299973
montant_ventes: -1495818987671372037
numero_de_bordereau: -1928164551898939653
numero_de_facture: -1207588611519660293
numero_de_transaction_banque: -1279646205557588229
porteur: -2288452522088579333
produit: -2000222145936867589
transfer_status_flows:
rapprochement: -2072279739974795525
remise_a_l_assocation: -2288452522088579333
virements: -2216394928050651397
transfer_statuses:
a_rapprocher: -2288452522088579333
a_remettre_a_l_assocation: -1856106957861011717
rapproche: -2072279739974795525
remis_a_l_assocation: -2216394928050651397
virements_a_faire: -2000222145936867589
virements_faits: -1784049363823083781
user_custom_fields:
bdc: -2072279739974795525
users:
compte_dedie_mlc_billet: -2288452522088579333
compte_dedie_mlc_numerique: -2216394928050651397

245786
src/etc/cyclos/dump/cyclos.sql
File diff suppressed because it is too large
View File

245786
src/etc/cyclos/dump/cyclos_test.sql
File diff suppressed because it is too large
View File

460
src/etc/cyclos/init_test_data.py

@ -0,0 +1,460 @@
# coding: utf-8
from __future__ import unicode_literals
import os
import argparse
import base64
import logging
import requests
import yaml # PyYAML
from datetime import datetime
from datetime import timedelta
logging.basicConfig()
logger = logging.getLogger(__name__)
def check_request_status(r):
if r.status_code == requests.codes.ok:
logger.info('OK')
else:
logger.error(r.text)
r.raise_for_status()
# Ensemble des constantes nécessaires au fonctionnement du script.
ENV = os.environ.get('ENV')
LOCAL_CURRENCY_INTERNAL_NAME = os.environ.get('CURRENCY_SLUG')
NETWORK_INTERNAL_NAME = LOCAL_CURRENCY_INTERNAL_NAME
if ENV != 'prod':
NETWORK_INTERNAL_NAME = ENV + LOCAL_CURRENCY_INTERNAL_NAME
LOCAL_CURRENCY_SYMBOL = os.environ.get('CURRENCY_SYMBOL')
# Arguments à fournir dans la ligne de commande
parser = argparse.ArgumentParser()
parser.add_argument('url', help='URL of Cyclos')
parser.add_argument('authorization',
help='string to use for Basic Authentication')
parser.add_argument('--debug',
help='enable debug messages',
action='store_true')
args = parser.parse_args()
if not args.url.endswith('/'):
args.url = args.url + '/'
if args.debug:
logger.setLevel(logging.DEBUG)
else:
logger.setLevel(logging.INFO)
for k, v in vars(args).items():
logger.debug('args.%s = %s', k, v)
# URLs des web services
global_web_services = args.url + 'global/web-rpc/'
network_web_services = args.url + '/' + NETWORK_INTERNAL_NAME + '/web-rpc/'
# En-têtes pour toutes les requêtes (il n'y a qu'un en-tête, pour
# l'authentification).
headers = {'Authorization': 'Basic ' + args.authorization}
# On fait une 1ère requête en lecture seule uniquement pour vérifier
# si les paramètres fournis sont corrects.
logger.info('Vérification des paramètres fournis...')
r = requests.post(global_web_services + 'network/search',
headers=headers, json={})
check_request_status(r)
########################################################################
# Création des utilisateurs pour les banques de dépôt et les comptes
# dédiés.
#
def create_user(group, name, login, email=None, password=None,city=None, custom_values=None):
logger.info('Création de l\'utilisateur "%s" (groupe "%s")...', name, group)
# FIXME code à déplacer pour ne pas l'exécuter à chaque fois
r = requests.post(network_web_services + 'group/search',
headers=headers, json={})
check_request_status(r)
groups = r.json()['result']['pageItems']
for g in groups:
if g['name'] == group:
group_id = g['id']
if not city:
city = 'Grenoble'
user_registration = {
'group': group_id,
'name': name,
'username': login,
'skipActivationEmail': True,
'addresses':[
{
'name': 'work',
'addressLine1': '10 rue du test',
'city': city,
'defaultAddress': True,
'hidden': False
}
]
}
if email:
user_registration['email'] = email
if password:
user_registration['passwords'] = [
{
'type': 'login',
'value': password,
'confirmationValue': password,
'assign': True,
'forceChange': False,
},
]
if custom_values:
user_registration['customValues'] = []
for field_id, value in custom_values.items():
r = requests.get(network_web_services + 'userCustomField/load/' + field_id, headers=headers)
check_request_status(r)
custom_field_type = r.json()['result']['type']
if custom_field_type == 'LINKED_ENTITY':
value_key = 'linkedEntityValue'
user_registration['customValues'].append({
'field': field_id,
value_key: value,
})
logger.debug('create_user : json = %s', user_registration)
r = requests.post(network_web_services + 'user/register',
headers=headers,
json=user_registration)
check_request_status(r)
logger.debug('result = %s', r.json()['result'])
user_id = r.json()['result']['user']['id']
logger.debug('user_id = %s', user_id)
return user_id
create_user(
group='Network administrators',
name= 'Administrator',
login= 'admin_network',
email= 'administrator@localhost.fr',
password= '@@bbccdd' #@WARNING : nécessité d'avoir ce mot de passe pour les tests appli CEL du Cairn
)
create_user(
group='Banques de dépôt',
name='Banque de dépôt 1',
login='BDP1',
)
create_user(
group='Banques de dépôt',
name='Banque de dépôt 2',
login='BDP2',
)
########################################################################
# Création des utilisateurs pour les tests.
if ENV != 'prod':
# On récupère l'id du champ perso 'BDC'.
r = requests.get(network_web_services + 'userCustomField/list', headers=headers)
check_request_status(r)
user_custom_fields = r.json()['result']
for field in user_custom_fields:
if field['internalName'] == 'bdc':
id_user_custom_field_bdc = field['id']
gestion_interne = {
'demo': 'Demo',
'demo2': 'Demo2',
}
for login, name in gestion_interne.items():
create_user(
group='Gestion interne',
name=name,
login=login,
password=login,
)
bureaux_de_change = {
'B000': 'Association Monnaie Locale',
'B001': 'Bureau de change 1',
'B002': 'Bureau de change 2',
}
for login, name in bureaux_de_change.items():
id_bdc = create_user(
group='Bureaux de change',
name=name + ' (BDC)',
login=login + '_BDC',
password=login,
)
create_user(
group='Opérateurs BDC',
name=name,
login=login,
password=login,
custom_values={
id_user_custom_field_bdc: id_bdc,
}
)
create_user(
group='Anonyme',
name='Anonyme',
login='anonyme',
password='anonyme',
)
adherents_utilisateurs = [
['gjanssens', 'Janssens Gaetan'],
['cretine_agnes', 'Créttine Agnès'],
['alberto_malik', 'Malik Alberto'],
['noire_aliss', 'La noire Aliss'],
['tous_andre', 'Tous Ensemble André'],
['speedy_andrew', 'Speedy Andrew'],
['stuart_andrew', 'Stuart Andrew'],
['crabe_arnold', 'Le Crabe Arnold'],
['barbare_cohen', 'le Barbare Cohen'],
['lacreuse_desiderata', 'Lacreuse Desiderata'],
['comblant_michel', 'Comblant Michel'],
['nico_faus_perso', 'Le Caméléon Nicolas'],
['benoit_perso', 'Le Rigolo Benoît'],
]
adherents_prestataires = [
['asso_mlc', 'Association Monnaie Locale','Grenoble'],
['maltobar', 'MaltOBar','Grenoble'],
['labonnepioche', 'La Bonne Pioche','Grenoble'],
['DrDBrew', 'DocteurD Brew Pub','Grenoble'],
['apogee_du_vin', 'Apogée du vin','Grenoble'],
['tout_1_fromage', 'Tout un fromage','Grenoble'],
['vie_integrative', 'vie intégrative','Voiron'],
['denis_ketels', 'Denis Ketels','Voiron'], #used only for changePassword test
['nico_faus_prod', 'Nico Faus Production','Grenoble'],
['hirundo_archi', 'Hirundo Architecture','Villard-de-Lans'],
['maison_bambous', 'Maison aux Bambous','Vinay'],
['recycleco', 'Recycleco','Saint-Marcellin'],
['elotine_photo', 'Elotine Photo','Grenoble'],
['boule_antan', 'La Boule d Antan','Villard-de-Lans'],
['la_remise', 'La Remise','Grenoble'],
['episol', 'Episol','Grenoble'],
['alter_mag', 'Alter Mag','Saint-Marcellin'],
['verre_a_soi', 'Le Verre à soi','Bilieu'],
['FluoDelik', 'Fluodélik','Méaudre'],
['1001_saveurs', '1001 Saveurs','Villard-de-Lans'],
['belle_verte', 'La Belle Verte','Susville'],
['kheops_boutique', 'Khéops boutique','Saint-Marcellin'],
['ferme_bressot', 'La ferme du Bressot','Beaulieu'],
['atelier_eltilo', 'Atelier Eltilo','Grenoble'],
['la_belle_verte', 'Belle Verte Permaculture','Sillans'],
['mon_vrac', 'Mon Vrac','Voiron'],
['le_marque_page', 'Le Marque Page','Saint-Marcellin'],
['boutik_creative', 'La Boutik Creative','Rives'],
['pain_beauvoir', 'Le Pain de Beauvoir','Beauvoir-en-Royans'],
['la_mandragore', 'La Mandragore','Grenoble'],
['jardins_epices', 'Les jardins epicés tout','Herbeys'],
['lib_colibri', 'Librairie Colibri','Voiron'],
['Claire_Dode', 'La Vie Claire Dode','Voiron'],
['fil_chantant', 'Le Fil qui Chante','Voiron'],
['epicerie_sol', 'Epicerie Solidaire Amandine','Voiron'],
['NaturaVie', 'Naturavie','Voiron'],
['montagne_arts', 'Les montagnarts','Valbonnais'],
['Biocoop', 'Biocoop','Chatte'],
['Alpes_EcoTour', 'Alpes Ecotourisme','Grenoble'],
['trankilou', 'Le Trankilou','Grenoble']
]
groupes_locaux = [
['gl_grenoble', 'Groupe Local Grenoble','Grenoble'],
['gl_voiron', 'Groupe Local Voiron','Voiron'],
['gl_tullins', 'Groupe Local Tullins','Tullins'],
]
for member in adherents_utilisateurs:
create_user(
group='Adhérents utilisateurs',
name=member[1],
login=member[0],
email = member[0] + '@test.fr',
password = '@@bbccdd',
)
create_user(
group='Adhérents utilisateurs',
name='Max Maz',
login='mazmax',
email = 'maxime.mazouth-laurol@cairn-monnaie.com',
password = '@@bbccdd',
)
for member in adherents_prestataires:
create_user(
group='Adhérents prestataires',
name=member[1],
login=member[0],
email = member[0] + '@test.fr',
city = member[2],
password = '@@bbccdd',
)
for member in groupes_locaux:
create_user(
group='Network administrators',
name=member[1],
login=member[0],
email = member[0] + '@test.fr',
city = member[2],
password = '@@bbccdd',
)
porteurs = {
'P001': 'Porteur 1',
'P002': 'Porteur 2',
'P003': 'Porteur 3',
'P004': 'Porteur 4',
}
for login, name in porteurs.items():
create_user(
group='Porteurs',
name=name,
login=login,
)
# Récupération des constantes
logger.info('Récupération des constantes depuis le YAML...')
CYCLOS_CONSTANTS = None
with open("/cyclos/cyclos_constants_"+ENV+".yml", 'r') as cyclos_stream:
try:
CYCLOS_CONSTANTS = yaml.load(cyclos_stream)
except yaml.YAMLError as exc:
assert False, exc
# Impression billets mlc
logger.info('Impression billets '+ LOCAL_CURRENCY_INTERNAL_NAME +'...')
logger.debug(str(CYCLOS_CONSTANTS['payment_types']['impression_de_billets_mlc']) + "\r\n" +
str(CYCLOS_CONSTANTS['currencies']['mlc']) + "\r\n" +
str(CYCLOS_CONSTANTS['account_types']['compte_de_debit_mlc_billet']) + "\r\n" +
str(CYCLOS_CONSTANTS['account_types']['stock_de_billets']))
r = requests.post(network_web_services + 'payment/perform',
headers={'Authorization': 'Basic {}'.format(base64.standard_b64encode(b'demo:demo').decode('utf-8'))}, # noqa
json={
'type': CYCLOS_CONSTANTS['payment_types']['impression_de_billets_mlc'],
'amount': 126500,
'currency': CYCLOS_CONSTANTS['currencies']['mlc'],
'from': 'SYSTEM',
'to': 'SYSTEM',
})
logger.info('Impression billets ' + LOCAL_CURRENCY_INTERNAL_NAME + '... Terminé !')
logger.debug(r.json())
#@WARNING : specifique au cairn, à supprimer dans le rendu au mvt Sol
today = datetime.now()
def date_modify(nb_days):
today = datetime.now()
date = today + timedelta(days=nb_days)
return date.strftime("%Y")+ '-' + date.strftime("%m")+'-'+date.strftime("%d")
def credit_numeric_money_safe(amount):
logger.info('Creation de MLC numeriques ...')
r = requests.post(network_web_services + 'payment/perform',
headers={'Authorization': 'Basic {}'.format(base64.standard_b64encode(b'admin_network:@@bbccdd').decode('utf-8'))},
json={
'type': CYCLOS_CONSTANTS['payment_types']['creation_mlc_numeriques'],
'amount': amount,
'currency': CYCLOS_CONSTANTS['currencies']['mlc'],
'from': 'SYSTEM',
'to': 'SYSTEM',
'description': 'creation initiale de ' + LOCAL_CURRENCY_INTERNAL_NAME ,
})
logger.info('Creation de MLC numeriques... Terminé !')
logger.debug(r.json())
def credit_de_compte(member,amount):
logger.info('Change numérique pour ' + member[1] + ' ...')
r = requests.post(network_web_services + 'payment/perform',
headers={'Authorization': 'Basic {}'.format(base64.standard_b64encode(b'admin_network:@@bbccdd').decode('utf-8'))},
json={
'type': CYCLOS_CONSTANTS['payment_types']['credit_du_compte'],
'amount': amount,
'currency': CYCLOS_CONSTANTS['currencies']['mlc'],
'from': 'SYSTEM',
'to': member[0],
'description': 'dépôt ' + LOCAL_CURRENCY_INTERNAL_NAME ,
'customValues': [
{
'field': str(CYCLOS_CONSTANTS['transaction_custom_fields']['bdc']),
'linkedEntityValue': id_bdc # ID de l'utilisateur Bureau de change
},
]
})
logger.info('Change numérique pour ' + member[1] + '... Terminé !')
logger.debug(r.json())
def payment_inter_adherent(debitor, creditor, amount, offset):
logger.info('Virement de ' + str(amount) + ' ' + LOCAL_CURRENCY_INTERNAL_NAME + ' ' + debitor + ' vers ' + creditor + ' ...')
if offset == 0:
cyclos_method = 'payment/perform'
else:
cyclos_method = 'scheduledPayment/perform'
r = requests.post(network_web_services + cyclos_method,
headers={'Authorization': 'Basic {}'.format(base64.standard_b64encode(b'admin_network:@@bbccdd').decode('utf-8'))},
json={
'type': CYCLOS_CONSTANTS['payment_types']['virement_inter_adherent'],
'amount': amount,
'currency': CYCLOS_CONSTANTS['currencies']['mlc'],
'description': 'virement ' + LOCAL_CURRENCY_INTERNAL_NAME ,
'firstInstallmentDate': date_modify(offset),
'installmentsCount': 1,
'from': debitor,
'to': creditor,
})
logger.info('Virement de ' + str(amount) + ' ' + LOCAL_CURRENCY_INTERNAL_NAME + ' ' + debitor + ' vers ' + creditor + ' ... Terminé !')
logger.debug(r.json())
#Creation initiale de MLC numeriques
credit_numeric_money_safe(10000000000)
# Changes numériques afin d'avoir des comptes avec des soldes non nuls + des opérations à injecter dans l'appli CEL
logger.info('Changes numériques en '+ LOCAL_CURRENCY_INTERNAL_NAME +' pour tous les pros à Grenoble...')
logger.debug(str(CYCLOS_CONSTANTS['payment_types']['credit_du_compte']) + "\r\n" +
str(CYCLOS_CONSTANTS['account_types']['compte_de_debit_mlc_numerique']) + "\r\n" +
str(CYCLOS_CONSTANTS['account_types']['compte_d_adherent']))
initial_credit = 1000
for pro in adherents_prestataires:
if pro[2] == 'Grenoble':
credit_de_compte(pro, initial_credit)
for person in adherents_utilisateurs:
credit_de_compte(person, initial_credit)
logger.info('Changes numériques en ' + LOCAL_CURRENCY_INTERNAL_NAME + '... Terminé !')
logger.info('Virements immédiats de compte à compte en '+ LOCAL_CURRENCY_INTERNAL_NAME +' ...')
#trankilou has null account again
logger.info('"Le Trankilou" réalise un virement vers "la Remise" remettant son solde à 0')
payment_inter_adherent('trankilou','la_remise',initial_credit,0)
# for i in range(0,10):
# payment_inter_adherent('DrDBrew','apogee_du_vin',10,0)
logger.info('Virements immédiats de compte à compte en '+ LOCAL_CURRENCY_INTERNAL_NAME +'... Terminé !')
logger.info('Virements programmés en '+ LOCAL_CURRENCY_INTERNAL_NAME +' de La Bonne Pioche vers AlterMag...')
for i in range(0,5):
payment_inter_adherent('labonnepioche','alter_mag',10,2)
logger.info('Virements programmés en '+ LOCAL_CURRENCY_INTERNAL_NAME +' ... Terminé !!')
logger.info('Fin du script !')

120
src/etc/cyclos/script_clean_database.sql

@ -0,0 +1,120 @@
begin;
create table del_users as select id from users where user_group_id in (select id from groups where name <> 'Global administrators' and network_id in (select id from networks where internal_name like :network));
create table del_transactions as select id from transactions where (by_id in (select id from del_users) or from_user_id in (select id from del_users) or to_user_id in (select id from del_users));
create table del_transfers as select id from transfers where (transaction_id in (select id from del_transactions));
create table del_accounts as select id from accounts where user_id in (select id from del_users);
update users set registered_by_id = null where registered_by_id in (select id from del_users);
update transactions set transaction_id = null, original_transfer_id = null, last_occurrence_success_id = null, last_occurrence_failure_id = null, feedback_id = null, access_client_id = null where id in (select id from del_transactions) ;
delete from amount_reservations;
delete from vouchers;
delete from voucher_packs;
delete from transfer_status_logs;
delete from transfers_transfer_status_flows;
delete from failed_payment_occurrences where transfer_id in (select id from del_transfers);
delete from account_balances where transfer_id in (select id from del_transfers);
delete from transfers where id in (select id from del_transfers);
delete from transaction_enum_values;
delete from stored_files where transaction_value_id is not null;
delete from transaction_custom_field_values;
delete from scheduled_payment_installments where id in (select scheduled_payment_installment_id from transfers where id in (select id from del_transfers));
delete from scheduled_payment_installments where scheduled_payment_id in (select id from del_transactions);
delete from failed_payment_occurrences where recurring_payment_id in (select id from del_transactions);
delete from transaction_authorizations;
delete from refs;
delete from transactions where id in (select id from del_transactions);
delete from access_client_logs where access_client_id in (select id from access_clients where user_id in (select id from del_users));
delete from access_clients where user_id in (select id from del_users);
delete from user_account_fee_logs;
delete from closed_account_balances where account_id in (select id from del_accounts);
delete from account_limit_logs where account_id in (select id from del_accounts);
update accounts set account_rates_id = null where id in (select id from del_accounts) ;
delete from account_rates where account_id in (select id from del_accounts);
delete from accounts where id in (select id from del_accounts);
delete from webshop_ads_delivery_methods;
delete from ad_delivery_methods;
delete from ad_history_logs;
delete from ads_categories;
delete from ad_order_products;
delete from notified_ad_interests;
delete from ads_addresses;
update ads set image_id = null;
delete from stored_files where ad_id is not null;
delete from ad_enum_values;
delete from ad_custom_field_values;
delete from ad_questions;
delete from ad_order_logs;
delete from stored_files where contact_info_id is not null;
delete from contact_infos;
update addresses set ad_order_id =null;
delete from ad_orders;
delete from ad_web_shop_settings;
delete from ad_interests;
delete from addresses;
delete from ads;
delete from phones;
delete from entity_property_logs;
delete from entity_logs;
update users set image_id = null;
delete from stored_files where user_id is not null;
delete from agreement_logs;
delete from passwords where user_id in (select id from del_users);
delete from brokering_logs;
delete from brokerings;
delete from login_history_logs where user_id in (select id from del_users);
delete from bulk_actions_users;
delete from user_enum_values;
delete from stored_files where user_value_id is not null;
delete from user_custom_field_values;
delete from notification_type_settings where subclass = 'USER';
delete from notification_settings where subclass = 'USER';
delete from notifications where user_id in (select id from del_users);
delete from operator_group_logs;
delete from operator_groups_restrict_payments_users;
delete from operator_groups_custom_operations;
delete from operator_groups_record_types;
delete from operator_groups_account_types;
delete from operator_groups_payment_types;
update users set operator_group_id = null;
delete from operator_groups;
delete from outbound_sms;
delete from inbound_sms;
delete from stored_files where record_value_id is not null;
delete from record_enum_values where owner_id in (select id from record_custom_field_values where owner_id in (select id from records where user_id in (select id from del_users)));
delete from record_custom_field_values where owner_id in (select id from records where user_id in (select id from del_users));
delete from records where user_id in (select id from del_users);
delete from user_group_logs where user_id in (select id from del_users);
update user_status_logs set by_id = null where by_id in (select id from del_users);
delete from user_status_logs where user_id in (select id from del_users);
update users set operator_user_id = null;
delete from user_activities where user_id in (select id from del_users);
delete from user_regional_settings where user_id in (select id from del_users);
delete from contacts where owner_id in (select id from del_users);
delete from contacts where contact_id in (select id from del_users);
delete from alerts where user_id in (select id from del_users);
delete from failed_action_logs where user_id in (select id from del_users);
delete from tokens where user_id in (select id from del_users);
delete from user_channels where user_id in (select id from del_users);
delete from users_products_logs where user_id in (select id from del_users);
delete from users_products where user_id in (select id from del_users);
delete from messages_to_groups;
delete from messages_to_users;
delete from messages;
delete from mailing_lists_to_groups;
delete from mailing_lists_to_users;
delete from mailings;
delete from mailing_lists;
delete from notifications where related_user_id is not null;
delete from reference_history;
delete from users_dashboard_actions;
delete from documents where user_id in (select id from del_users);
delete from error_logs;
delete from users_ignore_feedbacks;
delete from sessions where user_id in (select id from del_users);
delete from user_registration_account_configuration where user_id in (select id from del_users);
delete from users where id in (select id from del_users);
drop table del_users;
drop table del_transfers;
drop table del_transactions;
drop table del_accounts;
commit;

90
src/etc/cyclos/script_transaction_extensionpoint.groovy

@ -0,0 +1,90 @@
// TRANSACTION
import static groovyx.net.http.ContentType.*
import static groovyx.net.http.Method.*
import groovyx.net.http.HTTPBuilder
import java.util.concurrent.CountDownLatch
import org.cyclos.model.ValidationException
import org.cyclos.entities.banking.ScheduledPayment
import org.cyclos.entities.banking.RecurringPayment
import org.cyclos.model.banking.transactions.RecurringPaymentStatus
import org.cyclos.model.banking.transactions.RecurringPaymentOccurrenceStatus
import org.cyclos.model.banking.transactions.ScheduledPaymentInstallmentStatus
def url = ''
def jsonBody = []
def tx = scriptHelper.wrap(transaction)
if (! ((transaction instanceof RecurringPayment) | (transaction instanceof ScheduledPayment)) ){
return
}
def sendWarning = false
if( transaction instanceof RecurringPayment ){
if(tx.status != RecurringPaymentStatus.CANCELED){
if( tx.lastOccurrence.status == RecurringPaymentOccurrenceStatus.FAILED){
sendWarning = true
url = 'http://172.18.0.2:8000/operations/sync/recurring'
jsonBody = [
paymentID: maskId(tx.lastOccurrence.transferId), //will be null
transactionID: maskId(tx.id),
amount: tx.amount,
description: tx.description,
status: tx.lastOccurrence.status
]
}
}
} else { // scheduled payment
if( tx.firstInstallment.status == ScheduledPaymentInstallmentStatus.FAILED){
sendWarning = true
url = 'http://172.18.0.2:8000/operations/sync/scheduled'
jsonBody = [
paymentID: maskId(tx.firstInstallment.transferId), //will be null
transactionID: maskId(tx.id),
amount: tx.amount,
description: tx.description,
status: tx.firstInstallment.status
]
}
}
if (sendWarning == true){
// Send the POST request
def http = new HTTPBuilder(url)
http.headers["Content-Type"] = "application/json; charset=UTF-8"
def responseJson = null
def responseError = []
scriptHelper.addOnCommit {
CountDownLatch latch = new CountDownLatch(1)
def error = false
http.request(POST, JSON) {
body = jsonBody
response.success = { resp, json ->
responseJson = json
latch.countDown()
}
response.failure = { resp ->
responseError << resp.statusLine.statusCode
responseError << resp.statusLine.reasonPhrase
latch.countDown()
}
}
//Await for the response
latch.await()
if (!responseError.empty) {
throw new RuntimeException("Error making Cyclos sync to ${url}"
+ ", got error code ${responseError[0]}: ${responseError[1]}")
}
return responseJson
}
} else {
return
}

80
src/etc/cyclos/script_transfer_extensionpoint.groovy

@ -0,0 +1,80 @@
// TRANSFER
import static groovyx.net.http.ContentType.*
import static groovyx.net.http.Method.*
import groovyx.net.http.HTTPBuilder
import java.util.concurrent.CountDownLatch
import org.cyclos.model.ValidationException
import org.cyclos.entities.banking.RecurringPaymentTransfer
import org.cyclos.entities.banking.ScheduledPaymentInstallmentTransfer
import org.cyclos.entities.banking.FailedPaymentOccurrence
def url = ''
def jsonBody = []
def tf = scriptHelper.wrap(transfer)
if (! ((transfer instanceof RecurringPaymentTransfer) | (transfer instanceof ScheduledPaymentInstallmentTransfer) | (transfer instanceof FailedPaymentOccurrence)) ){
return
}
if( (transfer instanceof RecurringPaymentTransfer) | (transfer instanceof FailedPaymentOccurrence) ){
url = 'http://front:8000/operations/sync/recurring'
jsonBody = [
paymentID: maskId(tf.transferId),
transactionID: maskId(tf.recurringPayment.id),
amount: tf.amount,
description: tf.recurringPayment.description,
fromAccountNumber: tf.from.number,
toAccountNumber: tf.to.number,
status: tf.status
]
} else {
url = 'http://front:8000/operations/sync/scheduled'
jsonBody = [
paymentID: maskId(tf.installment.transferId),
transactionID: maskId(tf.transactionId),
amount: tf.amount,
description: tf.transaction.description,
fromAccountNumber: tf.from.number,
toAccountNumber: tf.to.number,
status: tf.installment.status
]
}
// Send the POST request
def http = new HTTPBuilder(url)
http.headers["Content-Type"] = "application/json; charset=UTF-8"
def responseJson = null
def responseError = []
scriptHelper.addOnCommit {
CountDownLatch latch = new CountDownLatch(1)
def error = false
http.request(POST, JSON) {
body = jsonBody
response.success = { resp, json ->
responseJson = json
latch.countDown()
}
response.failure = { resp ->
responseError << resp.statusLine.statusCode
responseError << resp.statusLine.reasonPhrase
latch.countDown()
}
}
//Await for the response
latch.await()
if (!responseError.empty) {
throw new RuntimeException("Error making Cyclos sync to ${url}"
+ ", got error code ${responseError[0]}: ${responseError[1]}")
}
return responseJson
}

2878
src/etc/cyclos/setup.py
File diff suppressed because it is too large
View File

43
src/etc/cyclos/setup_cyclos.sh

@ -0,0 +1,43 @@
#!/bin/bash
set -e
WORKDIR=$(pwd)
cd /cyclos
until [ `curl --silent --write-out '%{response_code}' -o /dev/null http://cyclos-app:8080/global/` -eq 200 ];
do
echo '--- waiting for Cyclos to be fully up (10 seconds)'
sleep 10
done
if [ ! -f ./cyclos_constants_$ENV.yml ]; then
read -p "Global Admin Login?" login
read -p "Global Admin password?" password
PASS=`echo -n $login:$password | base64`
python3 setup.py http://cyclos-app:8080/ $PASS
sleep 5
python3 init_test_data.py http://cyclos-app:8080/ $PASS
fi
cd ${WORKDIR}
exec "$@"
# This is how I launch this script (in dev):
# docker-compose exec api bash /cyclos/setup_cyclos.sh
# This cd will do this: cd /cyclos/
#~ cd "${0%/*}"
#~
#~ echo $PWD
#~
#~ rm -f cyclos_constants.yml
#~
#~ # Base64('admin:admin') = YWRtaW46YWRtaW4=
#~ python setup.py http://cyclos-app:8080/ YWRtaW46YWRtaW4=
#~ python init_static_data.py http://cyclos-app:8080/ YWRtaW46YWRtaW4=

162
src/init.sh

@ -0,0 +1,162 @@
#!/bin/sh
ROOT_DIR=$(pwd)
DATA_ONLY=0
for i in "$@"
do
case $i in
-e|--env)
ENV="$2"
shift #past argument
shift #past value
;;
-d|--data-only)
DATA_ONLY=1
shift
;;
-h|--help)
echo "Generates scripts to initialize docker services and containers with a dev/test dataset \n"
echo "WARNING : This script should never be executed in a production context \n"
echo "Usage: --env ENV [--data-only] \n"
echo "Options: \r"
echo " -e, --env Set environment variable. It can be either dev/test. \r"
echo " -d, --data-only Delete then generate dataset only instead of all services and docker containers. \r"
echo " -h, --help Show this prompt with a list of options. \r"
exit 0
;;
esac
done
if [ "$ENV" = "dev" -o "$ENV" = "test" ]; then
#analyse de la commande
#if config to generate
if [ "$DATA_ONLY" = "0" ]; then
if [ "$ENV" = "dev" ]; then
OTHER_ENV="test"
else
OTHER_ENV="dev"
fi
if [ -f ./etc/cyclos/cyclos_constants_$ENV.yml ] || [ ! -f ./etc/cyclos/cyclos_constants_$OTHER_ENV.yml ]; then
read -p "You are about to regenerate all the docker services. Are you sure? (y/n)" response
if [ -z $response ]; then
response="n"
echo "To regenerate dataset only, use -d option"
fi
while [ $response != "y" ] && [ $response != "n" ]; do
read -p "You are about to regenerate all the docker services. Are you sure? (y/n)" response
done
if [ $response = "n" ]; then
exit 0
fi
echo "$(tput setaf 3) Delete cyclos data... $(tput sgr 0)"
rm -rf data/cyclos
rm -f etc/cyclos/cyclos_constants_$ENV.yml
rm -f etc/cyclos/cyclos_constants_$OTHER_ENV.yml
echo "$(tput setaf 2) Delete cyclos data... OK ! "
sleep 2
echo "$(tput setaf 3) Stop and remove containers, networks and volumes... $(tput sgr 0)"
docker-compose down -v
echo "$(tput setaf 2) Stop and remove containers, networks and volumes... OK !"
sleep 2
echo "$(tput setaf 3) (Re)create cyclos database container from cyclos-db service $(tput sgr 0)"
docker-compose up -d cyclos-db
echo "INFO : Wait for cyclos init process to finish initial dump. It should take up to 3mins \n"
echo "HINT : In order to check progression, input sudo docker-compose logs -f cyclos-db in another terminal \n"
docker logs cyclos-db 2>&1 | grep -Pzl '(?s)init process complete.*\n.*ready to accept connections'
while [ $? -ne 0 ]; do
sleep 5;
#this must be the last line of the while loop
docker logs cyclos-db 2>&1 | grep -Pzl '(?s)init process complete.*\n.*ready to accept connections'
done
echo "$(tput setaf 2) (Re)create cyclos database container from cyclos-db service... OK !"
sleep 2
docker-compose up -d cyclos-app
sleep 2
docker-compose up -d odoo
echo "wait for odoo postgres database to finish process after startup"
docker logs postgres_odoo 2>&1 | grep -Pzl '(?s)init process complete'
while [ $? -ne 0 ]; do
sleep 5;
#this must be the last line of the while loop
docker logs postgres_odoo 2>&1 | grep -Pzl '(?s)init process complete'
done
## Update postgres password
docker-compose exec -T postgres bash -c \
'PGUSER=postgres psql <<<"ALTER USER postgres WITH ENCRYPTED password "'\\\''$POSTGRES_ROOT_PASSWORD'\\\'
## Set pg_hba.conf
docker-compose exec -T postgres bash -c '
PG_HBA=/var/lib/postgresql/data/pg_hba.conf
if ! grep -E "^host all all (0.0.0.0/0|all) md5\$" "$PG_HBA" >/dev/null 2>&1; then
if grep -E "^host all all (0.0.0.0/0|all) trust\$" "$PG_HBA" >/dev/null 2>&1; then
sed -ri '\''s%^host all all (0\.0\.0\.0/0|all) trust$%host all all \1 md5%g'\'' \
"$PG_HBA"
echo "Accepting connection from outside."
else
echo "Can'\''t ensure connection from outside." >&2
exit 1
fi
fi
'
if [ "$?" != 0 ]; then
echo "Error: can't update pg_hba.conf" >&2
else
docker-compose restart postgres
fi
sleep 5
docker-compose exec -T postgres bash -c \
'PGUSER=postgres createdb $PG_DATABASE'
docker-compose exec -T postgres bash -c \
'PGUSER=postgres psql $PG_DATABASE -c "CREATE EXTENSION IF NOT EXISTS unaccent;"'
docker-compose exec -T postgres bash -c \
'PGUSER=postgres psql <<<"CREATE USER \"$PG_USER\" WITH PASSWORD '\''$PG_PASS'\'' CREATEDB NOCREATEROLE;"'
docker-compose exec -T postgres bash -c \
'PGUSER=postgres prefix_pg_local_command=" " pgm chown $PG_USER $PG_DATABASE'
fi
echo "$(tput setaf 3) Generate cyclos configuration and initial data... $(tput sgr 0)"
docker-compose exec -e ENV=$ENV cyclos-app sh /cyclos/setup_cyclos.sh
echo "$(tput setaf 2) Generate cyclos configuration and initial data... OK !"
else
if [ -f ./etc/cyclos/cyclos_constants_$ENV.yml ]; then
echo "$(tput setaf 3) Clean cyclos database from all users, payments and accounts data... $(tput sgr 0)"
sleep 2
docker-compose exec -T cyclos-db psql -v network="'%$ENV%'" -U cyclos cyclos < etc/cyclos/script_clean_database.sql
echo "$(tput setaf 2) Clean cyclos database from all users, payments and accounts data... OK !"
sleep 2
echo "$(tput setaf 3) Regenerate cyclos init data : users, accounts credit and payments ... $(tput sgr 0)"
sleep 2
docker-compose exec -T -e ENV=$ENV cyclos-app python3 /cyclos/init_test_data.py http://cyclos-app:8080/ YWRtaW46YWRtaW4=
echo "$(tput setaf 2) Regenerate cyclos init data : users, accounts credit and payments... OK !"
else
echo "Cyclos constants file not found for $ENV mode. The cyclos containers and configuration have not been settled. \n Remove -d option from the command"
exit 0
fi
fi
else
echo "choose dev / test as a script variable"
exit 1
fi
Loading…
Cancel
Save