diff --git a/.github/workflows/camunda.yml b/.github/workflows/camunda.yml index 28ced578..593cc46f 100644 --- a/.github/workflows/camunda.yml +++ b/.github/workflows/camunda.yml @@ -20,7 +20,7 @@ jobs: WORKERS: 1 services: - mdb103: + mdb106: image: mariadb:10.6 ports: - 3306:3306 @@ -28,7 +28,7 @@ jobs: MYSQL_DATABASE: cws_dev MYSQL_ROOT_PASSWORD: adminpw options: >- - --name mdb103 + --name mdb106 steps: - uses: actions/checkout@v4 @@ -38,7 +38,14 @@ jobs: with: java-version: '17' distribution: 'temurin' - cache: maven + + - name: Cache Maven packages + uses: actions/cache@v4 + with: + path: ~/.m2/repository + key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }} + restore-keys: | + ${{ runner.os }}-m2- - name: Create open-source certs run: | @@ -54,11 +61,8 @@ jobs: chmod 600 ~/.cws/creds - name: Download Logstash - uses: carlosperate/download-file-action@v2 - with: - file-url: https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - file-name: logstash-8.12.0.zip - location: install/logging/ + run: | + curl -o install/logging/logstash-8.12.0.zip https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - name: Check for Logstash run: | @@ -90,8 +94,8 @@ jobs: - name: Set up Google Chrome run: | - sudo apt-get update - sudo apt-get --only-upgrade install google-chrome-stable + sudo apt update + sudo apt install -y google-chrome-stable - name: Display Google Chrome version run: google-chrome --version @@ -150,7 +154,7 @@ jobs: WORKERS: 2 services: - mdb103: + mdb106: image: mariadb:10.6 ports: - 3306:3306 @@ -158,7 +162,7 @@ jobs: MYSQL_DATABASE: cws_dev MYSQL_ROOT_PASSWORD: adminpw options: >- - --name mdb103 + --name mdb106 steps: - uses: actions/checkout@v4 @@ -168,7 +172,14 @@ jobs: with: java-version: '17' distribution: 'temurin' - cache: maven + + - name: Cache Maven packages + uses: actions/cache@v4 + with: + path: ~/.m2/repository + key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }} + restore-keys: | + ${{ runner.os }}-m2- - name: Create open-source certs run: | @@ -184,11 +195,8 @@ jobs: chmod 600 ~/.cws/creds - name: Download Logstash - uses: carlosperate/download-file-action@v2 - with: - file-url: https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - file-name: logstash-8.12.0.zip - location: install/logging/ + run: | + curl -o install/logging/logstash-8.12.0.zip https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - name: Check for Logstash run: | @@ -220,8 +228,8 @@ jobs: - name: Set up Google Chrome run: | - sudo apt-get update - sudo apt-get --only-upgrade install google-chrome-stable + sudo apt update + sudo apt install -y google-chrome-stable - name: Display Google Chrome version run: google-chrome --version @@ -271,10 +279,10 @@ jobs: - name: Check out the repo uses: actions/checkout@v4 - - name: Set up JDK 11 + - name: Set up JDK 17 uses: actions/setup-java@v4 with: - java-version: '11' + java-version: '17' distribution: 'temurin' cache: maven diff --git a/.github/workflows/ldap.yml b/.github/workflows/ldap.yml index 291e0284..91eb5243 100644 --- a/.github/workflows/ldap.yml +++ b/.github/workflows/ldap.yml @@ -20,7 +20,7 @@ jobs: WORKERS: 1 services: - mdb103: + mdb106: image: mariadb:10.6 ports: - 3306:3306 @@ -28,7 +28,7 @@ jobs: MYSQL_DATABASE: cws_dev MYSQL_ROOT_PASSWORD: adminpw options: >- - --name mdb103 + --name mdb106 steps: - uses: actions/checkout@v4 @@ -38,7 +38,14 @@ jobs: with: java-version: '17' distribution: 'temurin' - cache: maven + + - name: Cache Maven packages + uses: actions/cache@v4 + with: + path: ~/.m2/repository + key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }} + restore-keys: | + ${{ runner.os }}-m2- - name: Create open-source certs run: | @@ -54,11 +61,8 @@ jobs: chmod 600 ~/.cws/creds - name: Download Logstash - uses: carlosperate/download-file-action@v2 - with: - file-url: https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - file-name: logstash-8.12.0.zip - location: install/logging/ + run: | + curl -o install/logging/logstash-8.12.0.zip https://artifacts.elastic.co/downloads/logstash/logstash-8.12.0-windows-x86_64.zip - name: Check for Logstash run: | @@ -94,9 +98,9 @@ jobs: ls -al - name: Set up Google Chrome - run: | - sudo apt-get update - sudo apt-get --only-upgrade install google-chrome-stable + run: | + sudo apt update + sudo apt install -y google-chrome-stable - name: Display Google Chrome version run: google-chrome --version diff --git a/install/docker/console-db-es-ls-kibana/README.md b/install/docker/console-db-es-ls-kibana/README.md index 594468aa..24336c19 100755 --- a/install/docker/console-db-es-ls-kibana/README.md +++ b/install/docker/console-db-es-ls-kibana/README.md @@ -1,6 +1,6 @@ # Docker Setup -### Quickly run common-workflow-service on a single machine with all required services running on the same machine. +### Quickly run common-workflow-service on a single machine with all required services running on the same machine. #### It will deploy the following services in Docker: - db (MariaDb) @@ -14,10 +14,11 @@ 2. Build `common-workflow-service` Docker Image using the `build.sh` script in the cws-image dir 1. Update the version in the `build.sh` script if necessary 3. Update the `config.properties` and `docker-compose.yml` accordingly. -4. Run the command `docker network create cws-network` to create a shared network space for other workers to join +4. Create a creds file on your machine in path `~/.cws/creds` and set the file permission with `chmod 700 ~/.cws/creds` +5. Run the command `docker network create cws-network` to create a shared network space for other workers to join To run use the command: - + docker-compose up ## Adding more workers @@ -31,4 +32,4 @@ To run use the command: 3. If you want to add even more workers you'll need to do the following: 1. Copy the `worker-ls` directory to a new location 2. Modify those `config.properites` and `docker-compose.yml` accordingly. - 3. Run `docker-compose up` in each new worker directory \ No newline at end of file + 3. Run `docker-compose up` in each new worker directory diff --git a/install/docker/console-db-es-ls-kibana/config.properties b/install/docker/console-db-es-ls-kibana/config.properties index 885d7665..bcb88fcf 100644 --- a/install/docker/console-db-es-ls-kibana/config.properties +++ b/install/docker/console-db-es-ls-kibana/config.properties @@ -1,14 +1,14 @@ # --------------------------------------------------------------------------- # This is an example properties file that can be used when configuring CWS # for the first time. -# +# # To use: # # 1) Fill in the correct values where you see [YourXXX] below, for example # [YourHostname]. # The hard-coded values are suggested to be used, but can be changed if # desired. -# +# # 2) Run CWS configuration program with this properties file: # ./configure.sh config.properties # @@ -50,8 +50,8 @@ database_password=test # The LDAP username for the user that will be the CWS Administrator. # This User will have the initial permissions in CWS, and will have the ability # to add users and modify permissions. -admin_user=cws - +admin_user=cwsci + # The first and last name, and email address of the CWS Administrator. # These fields are only required if using CAMUNDA security admin_firstname=CWS @@ -79,7 +79,7 @@ amq_port=31616 cws_amq_jmx_port=37099 cws_jmx_port=31099 identity_plugin_type=CAMUNDA -cws_ldap_url=ldaps://ldap.localhost:636 +cws_ldap_url=ldap://ldapsearch:389 notify_users_email=y email_subject=[CWS] You have been assigned a task (CWS_TASK_NAME) email_body=fn:CWS_USER_FIRSTNAME
ln:CWS_USER_LASTNAME,
tn:(CWS_TASK_NAME), em:CWS_USER_EMAIL diff --git a/install/docker/console-db-es-ls-kibana/docker-compose.yml b/install/docker/console-db-es-ls-kibana/docker-compose.yml index 40f35cfb..57368754 100644 --- a/install/docker/console-db-es-ls-kibana/docker-compose.yml +++ b/install/docker/console-db-es-ls-kibana/docker-compose.yml @@ -17,6 +17,8 @@ services: interval: 3s timeout: 1s retries: 5 + networks: + - external-network es: labels: com.example.service: "es" @@ -32,6 +34,8 @@ services: - cluster.name=docker-cluster - xpack.security.enabled=false - "ES_JAVA_OPTS=-Xms512m -Xmx512m" + networks: + - external-network healthcheck: test: ["CMD-SHELL", "curl --silent --fail localhost:9200/_cluster/health || exit 1"] interval: 5s @@ -93,6 +97,7 @@ services: depends_on: - db - es + - ldapsearch # - logstash # - kibana ports: @@ -116,6 +121,8 @@ services: - ./config.properties:/home/cws_user/config.properties:ro - ~/.cws/creds:/root/.cws/creds:ro - console-logs-volume:/home/cws_user/cws/server/apache-tomcat-9.0.75/logs + networks: + - external-network cws-worker: container_name: cws-worker1 labels: @@ -126,6 +133,7 @@ services: - db - es - cws + - ldapsearch hostname: cws-worker1 environment: - DB_HOST=db @@ -138,11 +146,22 @@ services: - ./worker-config.properties:/home/cws_user/config.properties:ro - ~/.cws/creds:/root/.cws/creds:ro - worker1-logs-volume:/home/cws_user/cws/server/apache-tomcat-9.0.75/logs + networks: + - external-network + ldapsearch: + container_name: ldapsearch_container + image: ghcr.io/nasa-ammos/common-workflow-service/openldap:v2.6 + ports: + - 389:389 + networks: + - external-network + volumes: console-logs-volume: worker1-logs-volume: networks: - cws-network: - external: true + external-network: + external: + name: cws-network diff --git a/install/docker/console-db-es-ls-kibana/worker-config.properties b/install/docker/console-db-es-ls-kibana/worker-config.properties index fabc25e9..f2eca87e 100644 --- a/install/docker/console-db-es-ls-kibana/worker-config.properties +++ b/install/docker/console-db-es-ls-kibana/worker-config.properties @@ -1,14 +1,14 @@ # --------------------------------------------------------------------------- # This is an example properties file that can be used when configuring CWS # for the first time. -# +# # To use: # # 1) Fill in the correct values where you see [YourXXX] below, for example # [YourHostname]. # The hard-coded values are suggested to be used, but can be changed if # desired. -# +# # 2) Run CWS configuration program with this properties file: # ./configure.sh config.properties # @@ -50,8 +50,8 @@ database_password=test # The LDAP username for the user that will be the CWS Administrator. # This User will have the initial permissions in CWS, and will have the ability # to add users and modify permissions. -admin_user=cws - +admin_user=cwsci + # The first and last name, and email address of the CWS Administrator. # These fields are only required if using CAMUNDA security admin_firstname=CWS @@ -78,7 +78,7 @@ amq_port=31616 cws_jmx_port=31096 identity_plugin_type=CAMUNDA -cws_ldap_url=ldaps://ldap.localhost:636 +cws_ldap_url=ldap://ldapsearch:389 notify_users_email=y email_subject=[CWS] You have been assigned a task (CWS_TASK_NAME) email_body=fn:CWS_USER_FIRSTNAME
ln:CWS_USER_LASTNAME,
tn:(CWS_TASK_NAME), em:CWS_USER_EMAIL