playbook.yml 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284
  1. ---
  2. - name: Implementation parameters
  3. hosts: 127.0.0.1
  4. connection: local
  5. tasks:
  6. - name: Parameters for base
  7. command: "cp {{ playbook_dir }}/base/app/config/parameters.yml.dist {{ playbook_dir }}/base/app/config/parameters.yml"
  8. - name: "Parameters"
  9. command: "cp {{ playbook_dir }}/{{ item }}/app/config/parameters.yml.dist {{ playbook_dir }}/{{ item }}/app/config/parameters.yml"
  10. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"
  11. - name: Parameters for base
  12. command: "cp {{ playbook_dir }}/kea/1.4.0/kea-ik/conf/kea-dhcp4.conf.dist {{ playbook_dir }}/kea/1.4.0/kea-ik/conf/kea-dhcp4.conf"
  13. - name: Launch docker for mysql database. Tag=start_mysql
  14. hosts: 127.0.0.1
  15. connection: local
  16. tags: start_mysql
  17. tasks:
  18. - name: Docker mysql up
  19. command: "docker-compose up -d --force-recreate mysql"
  20. - name: Configure mysql database. Tag=configure_mysql
  21. hosts: mysql
  22. connection: docker
  23. gather_facts: no
  24. tags: configure_mysql
  25. tasks:
  26. - name: Wait for mysql be ready
  27. wait_for:
  28. host: 127.0.0.1
  29. port: 3306
  30. state: started
  31. delay: 5
  32. connect_timeout: 15
  33. timeout: 360
  34. - name: Create database fd_session
  35. mysql_db:
  36. name: fd_session
  37. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  38. state: present
  39. - name: Create database freeradius
  40. mysql_db:
  41. name: freeradius
  42. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  43. state: present
  44. - name: Create database grafana
  45. mysql_db:
  46. name: grafana
  47. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  48. state: present
  49. - name: Create database statsd_db
  50. mysql_db:
  51. name: statsd_db
  52. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  53. state: present
  54. - name: Create database base
  55. mysql_db:
  56. name: fd3_base
  57. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  58. state: present
  59. - name: Create database ftth
  60. mysql_db:
  61. name: fd3_ftth
  62. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  63. state: present
  64. - name: Create database stats
  65. mysql_db:
  66. name: fd3_stats
  67. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  68. state: present
  69. - name: Create database cablemodem
  70. mysql_db:
  71. name: fd3_cablemodem
  72. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  73. state: present
  74. - name: Create database Radius
  75. mysql_db:
  76. name: fd3_radius
  77. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  78. state: present
  79. - name: Create database dhcp
  80. mysql_db:
  81. name: fd3_dhcp
  82. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  83. state: present
  84. - name: Create database kea
  85. mysql_db:
  86. name: kea
  87. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  88. state: present
  89. - copy:
  90. src: "{{ playbook_dir }}/freeradius_schema.sql"
  91. dest: /tmp/freeradius_schema.sql
  92. - name: Create freeradius MySQL schema
  93. mysql_db:
  94. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  95. state: import
  96. name: freeradius
  97. target: "/tmp/freeradius_schema.sql"
  98. - name: Create user iksop
  99. mysql_user:
  100. name: 'iksop'
  101. password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  102. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  103. priv: '*.*:ALL'
  104. state: present
  105. - copy:
  106. src: "{{ playbook_dir }}/mysql_scripts.sql"
  107. dest: /tmp/mysql_scripts.sql
  108. - name: Replace password mysql_scripts.sql
  109. shell: "sed -i -- 's/#password#/{{ lookup('env', 'MYSQL_PASSWORD') }}/g' /tmp/mysql_scripts.sql"
  110. - name: Run SQL commands against DB to create table
  111. mysql_db:
  112. login_password: "{{ lookup('env', 'MYSQL_PASSWORD') }}"
  113. state: import
  114. name: fd_session
  115. target: "/tmp/mysql_scripts.sql"
  116. - name: Launch docker for amqp. Tag=start_amqp
  117. hosts: 127.0.0.1
  118. connection: local
  119. tags: start_base
  120. tasks:
  121. - name: Docker amqp up
  122. command: "docker-compose up -d amqp"
  123. - name: "Wait for amqp. Timeout: 1 minutes"
  124. pause:
  125. minutes: 1
  126. - name: Launch docker for module base. Tag=start_base
  127. hosts: 127.0.0.1
  128. connection: local
  129. tags: start_base
  130. tasks:
  131. - name: Docker base up
  132. command: "docker-compose up -d --force-recreate base"
  133. - name: Configure module base. Tag=configure_base
  134. hosts: base
  135. connection: docker
  136. tags: configure_base
  137. vars:
  138. uris: ""
  139. tasks:
  140. - name: "Wait for autoload_classmap.php. Timeout: 10 minutes"
  141. wait_for:
  142. path: "/opt/base/vendor/composer/autoload_classmap.php"
  143. state: present
  144. sleep: 30
  145. timeout: 600
  146. - name: Chmod cache
  147. file:
  148. path: /opt/base/var/cache/
  149. recurse: yes
  150. mode: 777
  151. - name: Clean cache
  152. file:
  153. state: absent
  154. path: "/opt/base/var/cache/"
  155. - name: Load redirections
  156. set_fact:
  157. uris: "{{ uris }} --redirect_uri=https://{{ item }}.{{ lookup('env', 'CLIENT') }}.{{ lookup('env', 'DOMAIN') }}/login_check"
  158. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"
  159. - name: Load redirections app_dev
  160. set_fact:
  161. uris: "{{ uris }} --redirect_uri=https://{{ item }}.{{ lookup('env', 'CLIENT') }}.{{ lookup('env', 'DOMAIN') }}/app_dev.php/login_check"
  162. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"
  163. - name: Create oauth client
  164. shell: "bin/console oauth:client:createRedirects {{ uris }} > oauth.data.log"
  165. args:
  166. executable: /bin/bash
  167. - name: Copy file oauth.data.log to host
  168. fetch:
  169. src: /opt/base/oauth.data.log
  170. dest: /tmp/
  171. flat: yes
  172. - name: Configure oauth data for other container. Tag=configure_oauth
  173. hosts: 127.0.0.1
  174. connection: local
  175. tags: configure_oauth
  176. tasks:
  177. - name: "Add outh client id"
  178. shell: "cp /tmp/oauth.data.log {{ item }}.oauth.env"
  179. args:
  180. executable: /bin/bash
  181. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"
  182. - name: "Launch docker's. Tag=launch_dockers"
  183. hosts: 127.0.0.1
  184. connection: local
  185. tags: launch_dockers
  186. tasks:
  187. - name: "Dockers up"
  188. command: "docker-compose up -d --force-recreate {{ item }}"
  189. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"
  190. - name: "Wait to load containers. Timeout: 10 minutes. Tag=run_modules"
  191. hosts: "{{ lookup('env', 'MODULES_INSTALL') }}"
  192. connection: docker
  193. tags: run_modules
  194. tasks:
  195. - name: "Waiting"
  196. wait_for:
  197. path: "./vendor/composer/autoload_classmap.php"
  198. state: present
  199. sleep: 30
  200. timeout: 600
  201. - name: "Run doctrine:schema:update for modules. Tag=dsu_modules"
  202. hosts: "{{ lookup('env', 'MODULES_INSTALL') }}"
  203. connection: docker
  204. tags: dsu_modules
  205. tasks:
  206. - name: "Doctrine schema update"
  207. shell: "bin/console doctrine:schema:update --force"
  208. # Generate self-signed cert files for Nginx (intended for development, please replace with proper ones)
  209. - name: "Generate self-signed cert files for Nginx"
  210. hosts: 127.0.0.1
  211. connection: local
  212. tags: self_cert
  213. tasks:
  214. - name: "Make sure certs dir exists"
  215. shell: "mkdir -p /opt/flowdat/certs"
  216. - name: "Generate self-signed certs for Nginx"
  217. shell: "openssl req -x509 -nodes -batch -days 365 -newkey rsa:2048 -keyout /opt/flowdat/certs/privkey.pem -out /opt/flowdat/certs/fullchain.pem -subj '/C=AR/ST=Santa Fe/L=Rosario/O=Interlink/OU=R&D/CN=*.{{ lookup('env','CLIENT') }}.{{ lookup('env','DOMAIN') }}/emailAddress=idev@interlink.com.ar'"
  218. - name: "Copy certs dir to nginx/certs"
  219. hosts: 127.0.0.1
  220. connection: local
  221. tags: copy_cert
  222. tasks:
  223. - name: "Copy certs directory"
  224. shell: "cp -nr /opt/flowdat/certs/* /opt/flowdat/nginx/certs"
  225. - name: "Run up all. Tag=up_all"
  226. hosts: 127.0.0.1
  227. connection: local
  228. tags: up_all
  229. tasks:
  230. - name: Docker up all modules
  231. command: "docker-compose up -d "
  232. - name: Docker stop nginx
  233. command: "docker-compose stop nginx "
  234. - name: Docker up nginx
  235. command: "docker-compose up -d nginx"
  236. - name: "Clear all cache. Tag=clear_cache_all"
  237. hosts: 127.0.0.1
  238. connection: local
  239. tags: clear_cache_all
  240. tasks:
  241. - name: "Chmod cache"
  242. command: "chmod 777 -R /opt/flowdat/{{ item }}/var/cache"
  243. with_items: "{{ lookup('env', 'MODULES_INSTALL').split(',') }}"