playbook_v2.yml 8.9 KB

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