deploy-playground-playbook.yml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. ---
  2. # Run the docker-compose setup on a new EC2 instance
  3. - name: Setup EC2 instance and start docker-compose services
  4. hosts: all
  5. gather_facts: yes
  6. tasks:
  7. - name: Get code from git repo
  8. include_role:
  9. name: common
  10. tasks_from: get-code-git
  11. - name: Creat bash profile file
  12. command: 'touch /home/ubuntu/.bash_profile'
  13. - name: Run setup script
  14. command: ./setup.sh
  15. args:
  16. chdir: '{{ remote_code_path }}'
  17. - name: Copy bash_profile content
  18. shell: cat ~/.bash_profile
  19. register: bash_data
  20. - name: Copy bash_profile content to bashrc for non-interactive sessions
  21. blockinfile:
  22. block: '{{ bash_data.stdout }}'
  23. path: ~/.bashrc
  24. insertbefore: BOF
  25. - name: Make sure docker is running
  26. command: systemctl start docker
  27. become: yes
  28. - name: Build packages
  29. command: yarn build:packages
  30. args:
  31. chdir: '{{ remote_code_path }}'
  32. async: 3600
  33. poll: 0
  34. register: build_result
  35. - name: Check on build async task
  36. async_status:
  37. jid: '{{ build_result.ansible_job_id }}'
  38. register: job_result
  39. until: job_result.finished
  40. # Max number of times to check for status
  41. retries: 36
  42. # Check for the status every 100s
  43. delay: 100
  44. - name: Build Node image
  45. command: yarn build:node:docker
  46. args:
  47. chdir: '{{ remote_code_path }}'
  48. async: 3600
  49. poll: 0
  50. register: node_build_result
  51. - name: Check on build node image async task
  52. async_status:
  53. jid: '{{ node_build_result.ansible_job_id }}'
  54. register: job_result
  55. until: job_result.finished
  56. # Max number of times to check for status
  57. retries: 36
  58. # Check for the status every 100s
  59. delay: 100
  60. - name: Run docker-compose
  61. command: yarn start
  62. args:
  63. chdir: '{{ remote_code_path }}'
  64. environment:
  65. PERSIST: 'true'
  66. COLOSSUS_1_URL: 'https://{{ inventory_hostname }}.nip.io/colossus-1/'
  67. DISTRIBUTOR_1_URL: 'https://{{ inventory_hostname }}.nip.io/distributor-1/'
  68. SKIP_CHAIN_SETUP: '{{ skip_chain_setup }}'
  69. async: 1800
  70. poll: 0
  71. register: compose_result
  72. - name: Check on yarn start task
  73. async_status:
  74. jid: '{{ compose_result.ansible_job_id }}'
  75. register: job_result
  76. until: job_result.finished
  77. # Max number of times to check for status
  78. retries: 18
  79. # Check for the status every 100s
  80. delay: 100
  81. - name: Set nip.io domain with IP
  82. set_fact:
  83. nip_domain: '{{ inventory_hostname }}.nip.io'
  84. run_once: yes
  85. - name: Install and configure Caddy
  86. include_role:
  87. name: caddy_ansible.caddy_ansible
  88. apply:
  89. become: yes
  90. vars:
  91. caddy_config: "{{ lookup('template', 'templates/Playground-Caddyfile.j2') }}"
  92. caddy_systemd_capabilities_enabled: true
  93. caddy_update: false
  94. - name: Set endpoints
  95. set_fact:
  96. all_services: |
  97. websocket_rpc: wss://{{ nip_domain }}/ws-rpc
  98. http_rpc: https://{{ nip_domain }}/http-rpc
  99. colossus: https://{{ nip_domain }}/colossus-1
  100. distributor: https://{{ nip_domain }}/distributor-1
  101. graphql_server: https://{{ nip_domain }}/query-node/server/graphql
  102. graphql_server_websocket: wss://{{ nip_domain }}/query-node/server/graphql
  103. indexer: https://{{ nip_domain }}/query-node/indexer/graphql
  104. member_faucet: https://{{ nip_domain }}/member-faucet/register
  105. orion: https://{{ nip_domain }}/orion/graphql
  106. run_once: yes
  107. - name: Print endpoints
  108. debug:
  109. msg: '{{ all_services | from_yaml }}'
  110. run_once: yes
  111. - name: Create config.json to serve as Caddy endpoint
  112. copy:
  113. content: '{{ all_services | from_yaml | to_json }}'
  114. dest: '/home/ubuntu/config.json'
  115. - name: Save output as file on local
  116. copy:
  117. content: '{{ all_services | from_yaml | to_json }}'
  118. dest: 'endpoints.json'
  119. delegate_to: localhost