diff --git a/2.database/01.CreateTables.sql b/2.database/01.CreateTables.sql index 4fb7b45..e810a77 100644 --- a/2.database/01.CreateTables.sql +++ b/2.database/01.CreateTables.sql @@ -129,7 +129,7 @@ CREATE TABLE myhealth.medicalspecialty ) TABLESPACE pg_default; --- Table: myhealth.patient +-- Table: myhealth.patient CREATE TABLE myhealth.patient ( id INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY ( INCREMENT 1 START 1 MINVALUE 1 MAXVALUE 2147483647 CACHE 1 ), @@ -231,4 +231,4 @@ GRANT ALL ON myhealth.question to usrmyhealth; GRANT ALL ON myhealth.medicaltest to usrmyhealth; END; -$$ +$$ \ No newline at end of file diff --git a/4.config/createApplicationUser.sh b/4.config/createApplicationUser.sh new file mode 100755 index 0000000..8712bdc --- /dev/null +++ b/4.config/createApplicationUser.sh @@ -0,0 +1,92 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Wed Dec 18 17:32:33 2019 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 ;# set to 1 to force conservative mode even if + ;# script wasn't run conservatively originally +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + +# +# 2) differing output - Some programs produce different output each time +# they run. The "date" command is an obvious example. Another is +# ftp, if it produces throughput statistics at the end of a file +# transfer. If this causes a problem, delete these patterns or replace +# them with wildcards. An alternative is to use the -p flag (for +# "prompt") which makes Expect only look for the last line of output +# (i.e., the prompt). The -P flag allows you to define a character to +# toggle this mode off and on. +# +# Read the man page for more info. +# +# -Don + + +set timeout -1 +spawn ./add-user.sh +match_max 100000 +expect -exact "\r +What type of user do you wish to add? \r + a) Management User (mgmt-users.properties) \r + b) Application User (application-users.properties)\r +(a): " +send -- "b\r" +expect -exact "b\r +\r +Enter the details of the new user to add.\r +Using realm 'ApplicationRealm' as discovered from the existing property files.\r +Username : " +send -- "USER\r" +expect -exact "USER\r +Password recommendations are listed below. To modify these restrictions edit the add-user.properties configuration file.\r + - The password should be different from the username\r + - The password should not be one of the following restricted values {root, admin, administrator}\r + - The password should contain at least 8 characters, 1 alphabetic character(s), 1 digit(s), 1 non-alphanumeric symbol(s)\r +Password : " +send -- "PASSWORD\r" +expect -exact "\r +WFLYDM0101: Password should have at least 1 digit.\r +Are you sure you want to use the password entered yes/no? " +send -- "Y\r" +expect -exact "Y\r +Re-enter Password : " +send -- "PASSWORD\r" +expect -exact "\r +What groups do you want this user to belong to? (Please enter a comma separated list, or leave blank for none)\[ \]: " +send -- " User,Trainer,Administrator" +expect -exact " User,Trainer,Administrator" +send -- "\r" +expect -exact "\r +About to add user 'USER' for realm 'ApplicationRealm'\r +Is this correct yes/no? " +send -- "Y\r" +expect -exact "Y\r +Added user 'USER' to file '/opt/jboss/wildfly/standalone/configuration/application-users.properties'\r +Added user 'USER' to file '/opt/jboss/wildfly/domain/configuration/application-users.properties'\r +Added user 'USER' with groups User,Trainer,Administrator to file '/opt/jboss/wildfly/standalone/configuration/application-roles.properties'\r +Added user 'USER' with groups User,Trainer,Administrator to file '/opt/jboss/wildfly/domain/configuration/application-roles.properties'\r +Is this new user going to be used for one AS process to connect to another AS process? \r +e.g. for a slave host controller connecting to the master or for a Remoting connection for server to server EJB calls.\r +yes/no? " +send -- "Y\r" +expect eof \ No newline at end of file diff --git a/4.config/createManagementUser.sh b/4.config/createManagementUser.sh new file mode 100755 index 0000000..6003783 --- /dev/null +++ b/4.config/createManagementUser.sh @@ -0,0 +1,92 @@ +#!/usr/bin/expect -f +# +# This Expect script was generated by autoexpect on Wed Dec 18 17:37:57 2019 +# Expect and autoexpect were both written by Don Libes, NIST. +# +# Note that autoexpect does not guarantee a working script. It +# necessarily has to guess about certain things. Two reasons a script +# might fail are: +# +# 1) timing - A surprising number of programs (rn, ksh, zsh, telnet, +# etc.) and devices discard or ignore keystrokes that arrive "too +# quickly" after prompts. If you find your new script hanging up at +# one spot, try adding a short sleep just before the previous send. +# Setting "force_conservative" to 1 (see below) makes Expect do this +# automatically - pausing briefly before sending each character. This +# pacifies every program I know of. The -c flag makes the script do +# this in the first place. The -C flag allows you to define a +# character to toggle this mode off and on. + +set force_conservative 0 ;# set to 1 to force conservative mode even if + ;# script wasn't run conservatively originally +if {$force_conservative} { + set send_slow {1 .1} + proc send {ignore arg} { + sleep .1 + exp_send -s -- $arg + } +} + +# +# 2) differing output - Some programs produce different output each time +# they run. The "date" command is an obvious example. Another is +# ftp, if it produces throughput statistics at the end of a file +# transfer. If this causes a problem, delete these patterns or replace +# them with wildcards. An alternative is to use the -p flag (for +# "prompt") which makes Expect only look for the last line of output +# (i.e., the prompt). The -P flag allows you to define a character to +# toggle this mode off and on. +# +# Read the man page for more info. +# +# -Don + + +set timeout -1 +spawn ./add-user.sh +match_max 100000 +expect -exact "\r +What type of user do you wish to add? \r + a) Management User (mgmt-users.properties) \r + b) Application User (application-users.properties)\r +(a): " +send -- "A\r" +expect -exact "A\r +\r +Enter the details of the new user to add.\r +Using realm 'ManagementRealm' as discovered from the existing property files.\r +Username : " +send -- "USER\r" +expect -exact "USER\r +Password recommendations are listed below. To modify these restrictions edit the add-user.properties configuration file.\r + - The password should be different from the username\r + - The password should not be one of the following restricted values {root, admin, administrator}\r + - The password should contain at least 8 characters, 1 alphabetic character(s), 1 digit(s), 1 non-alphanumeric symbol(s)\r +Password : " +send -- "PASSWORD\r" +expect -exact "\r +WFLYDM0101: Password should have at least 1 digit.\r +Are you sure you want to use the password entered yes/no? " +send -- "Y\r" +expect -exact "Y\r +Re-enter Password : " +send -- "PASSWORD\r" +expect -exact "\r +What groups do you want this user to belong to? (Please enter a comma separated list, or leave blank for none)\[ \]: " +send -- " User,Trainer,Administrator" +expect -exact " User,Trainer,Administrator" +send -- "\r" +expect -exact "\r +About to add user 'USER' for realm 'ManagementRealm'\r +Is this correct yes/no? " +send -- "Y\r" +expect -exact "Y\r +Added user 'USER' to file '/opt/jboss/wildfly/standalone/configuration/mgmt-users.properties'\r +Added user 'USER' to file '/opt/jboss/wildfly/domain/configuration/mgmt-users.properties'\r +Added user 'USER' with groups User,Trainer,Administrator to file '/opt/jboss/wildfly/standalone/configuration/mgmt-groups.properties'\r +Added user 'USER' with groups User,Trainer,Administrator to file '/opt/jboss/wildfly/domain/configuration/mgmt-groups.properties'\r +Is this new user going to be used for one AS process to connect to another AS process? \r +e.g. for a slave host controller connecting to the master or for a Remoting connection for server to server EJB calls.\r +yes/no? " +send -- "Y\r" +expect eof \ No newline at end of file diff --git a/4.config/module.xml b/4.config/module.xml new file mode 100644 index 0000000..eae6534 --- /dev/null +++ b/4.config/module.xml @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/4.config/postgresql-9.4.1209.jar b/4.config/postgresql-9.4.1209.jar new file mode 100755 index 0000000..d0f4923 Binary files /dev/null and b/4.config/postgresql-9.4.1209.jar differ diff --git a/4.config/standalone.xml b/4.config/standalone.xml new file mode 100644 index 0000000..ee2fbea --- /dev/null +++ b/4.config/standalone.xml @@ -0,0 +1,524 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + jdbc:postgresql://postgres:5432/myhealth + org.postgresql.Driver + postgresql + + USER + PASSWORD + + + + jdbc:h2:mem:test;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE + h2 + + sa + sa + + + + + org.postgresql.xa.PGXADataSource + + + org.h2.jdbcx.JdbcDataSource + + + + + + + + + + false + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ${jboss.bind.address:127.0.0.1} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..75e1b4e --- /dev/null +++ b/Dockerfile @@ -0,0 +1,29 @@ +FROM jboss/wildfly:14.0.1.Final + +# User root user to install software +USER root +RUN yum -y install expect +RUN yum -y install postgresql +RUN yum -y install ant + +# Compile and copy .ear to deployments +ADD ./1.sources/ /opt/jboss/ +RUN cd /opt/jboss/MyHealth && ant +RUN mv /opt/jboss/MyHealth/dist/MyHealth.ear /opt/jboss/wildfly/standalone/deployments + +# Switch back to jboss user +USER jboss + +ADD ./4.config/createApplicationUser.sh /opt/jboss/wildfly/bin/ +ADD ./4.config/createManagementUser.sh /opt/jboss/wildfly/bin/ + +RUN cd /opt/jboss/wildfly/bin && ./createApplicationUser.sh +RUN cd /opt/jboss/wildfly/bin && ./createManagementUser.sh + +RUN mkdir /opt/jboss/wildfly/modules/system/layers/base/org/postgresql/ +RUN mkdir /opt/jboss/wildfly/modules/system/layers/base/org/postgresql/main +ADD ./4.config/postgresql-9.4.1209.jar /opt/jboss/wildfly/modules/system/layers/base/org/postgresql/main +ADD ./4.config/module.xml /opt/jboss/wildfly/modules/system/layers/base/org/postgresql/main +ADD ./4.config/standalone.xml /opt/jboss/wildfly/standalone/configuration/standalone.xml + +CMD ["/opt/jboss/wildfly/bin/standalone.sh", "-b", "0.0.0.0", "-bmanagement", "0.0.0.0"] \ No newline at end of file diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..6606486 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,23 @@ +version: '3' +services: + postgres: + image: postgres:10.11-alpine + ports: + - "5432:5432" + environment: + - POSTGRES_USER=USER + - POSTGRES_PASSWORD=PASSWORD + - POSTGRES_DB=myhealth + volumes: + - ./2.database/01.CreateTables.sql:/docker-entrypoint-initdb.d/init.sql + wildfly: + build: . + ports: + - "8080:8080" + environment: + - DB_USER=USER + - DB_PASS=PASSWORD + - JBOSS_HOME=/opt/jboss/wildfly + depends_on: + - postgres +