Skip to content

Latest commit

 

History

History
326 lines (213 loc) · 15 KB

README.md

File metadata and controls

326 lines (213 loc) · 15 KB

ThinkLab-2257

IBM WebSphere Automation Think 2021 Lab instructions

Lab Environment


  • Once you login you will see 10 VMs (virtual machines)
    • 3 are for lab infrastructure
    • 3 for OCP (OpenShift) controllers
    • 3 for OCP workers
    • 1 for the lab (Student VM)
  • WebSphere Automation is pre-installed in the OCP cluster hosted on the VMs.
  • You will be working on the Student VM only.
    • This VM is installed with OCP client (oc) and all thee scripts and files you need for the lab.

General VM (Virtual Machine) usage instructions


Once you login into the Student VM you will see the Desktop which contains all the programs that you will be using (browsers, terminal etc)  need to add a screen shot here (??) You can always come to the desktop view by clicking ?? The best way to copy and paste is by using the clipboard at the top middle Keyboard keys (like Ctrl ^C, Ctrl ^V) are not supported so have to highlight the text to copy and paste. You can use either use the instructions from these slides for the lab or from the text file on the desktop. If using the text file from the VM for lab instructions, it is recommended that you open 2 terminals to make copy and paste easier. Anything else ??

High Level Steps

Step 1: Login into WebSphere Automation GUI and configure your email to receive vulnerability notifications. Step 2: Login as root on the Student VM and also to OpenShift client (oc) Step 3: Get the usageMetering configuration parameters (api-key, URL, server cert). Step 4: Register Liberty Server version 200012 to WebSphere Automation. Step 5: Register Liberty Server version 20009 to WebSphere Automation. Step 6: Register tWAS server version 9056 to WebSphere Automation. Step 7: Register tWAS server version 9057 to WebSphere Automation. Step 8: Update Liberty server version 20009 to get rid of the vulnerabilities. Step 9: Update tWAS server version 9057 to get rid of vulnerabilities Step 10: Update tWAS server version 9057 to introduce the vulnerability back (optional)

Step 1 – Check access to GUI (1 of 2)

WebSphere Automation is pre-installed on an OCP cluster. Each of you have access to your individual WebSphere Automation install Click on the Student VM. Open a browser and enter the following URL https://cpd-websphere-automation.apps.ocp.ibm.edu Accept all the warnings and certificates. Depending on your browser you might have to scroll down to permit accesss. This is the initial landing page for IBM automation Under Log in to IBM Automation -> Select your authentication type: click on OpenShift authentication Enter the following credentials UserName : ocadmin Password :

Check access to GUI and setup up email notification (optional)(2 of 2)

Click on the Navigation/Hamburger Menu on the left. Expand Operate. You should now see Application Runtimes. Click on that. It will take you to the WebSphere Automation GUI. There should be no data since no WebSphere servers are registered/configured yet. On the console, go to Notification Configuration and enter your email address where you want to be notified about CVEs by clicking on add email address button The mail server is pre-configured for this lab. You only need to enter your email address to get notified.

Step 2 – OC login

Open 2 terminals and login as root in both. The terminal window will be on the desktop. If you can’t see it, try minimizing the windows (browser etc). su root Password : 1bm2021rhjb Login to the OCP cluster (in each terminal) oc login --username=ocadmin --password=ibmocp46 --insecure-skip-tls-verify=true --server=https://api.ocp.ibm.edu:6443 Make sure that project you are working in is websphere-automation oc project websphere-automation Copy to clipboard instructions Use the clipboard icon to help with copy and paste in VM.image

Step 3 – Get usageMetering configuration parameters (url, api-key, cert)

Get the URL for usage-metering and save it in a file. echo https://$(oc get route cpd -n websphere-automation -o jsonpath='{.spec.host}')/websphereauto/meteringapi > /opt/IBM/WebSphere/metering-url.txt Get the api-key and store it in a file. oc -n websphere-automation get secret automation-secure-metering-apis-encrypted-tokens -o jsonpath='{.data.automation-secure-metering-apis-sa}' | base64 -d > /opt/IBM/WebSphere/api-key.txt; echo >> /opt/IBM/WebSphere/api-key.txt Get the Server certificate oc get secret external-tls-secret -n websphere-automation -o jsonpath='{.data.cert.crt}' | base64 -d > /opt/IBM/WebSphere/cacert.pem

Step 4 – Configure Liberty Server version 200012 to register to WebSphere Automation (part 1 of 2)

Create the Liberty server version 200012 /opt/IBM/WebSphere/Liberty200012/bin/server create Liberty_200012_server Configure the server to use TLS/SSL using the provided server_tls.xml file. Press Yes (Y) to overwrite the existing file. cp /home/ibmuser/Desktop/lab_backup/liberty200012/server_tls.xml /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/server.xml Start the Liberty server /opt/IBM/WebSphere/Liberty200012/bin/server start Liberty_200012_server Update the DefaultKeyStore with the server certificate to trust the server for https connections keytool -import -trustcacerts -file /opt/IBM/WebSphere/cacert.pem -keystore /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/resources/security/key.p12 -storetype PKCS12 -storepass th1nkpassword -noprompt Edit the server.xml file (using vi, vim, or gedit) to configure the usageMetering feature. vi /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/server.xml usageMetering-1.0

Step 4 – Configure Liberty Server version 200012 to register to WebSphere Automation (part 2 of 2)

Add the usageMetering element and replace the url and the api-key values as shown below <usageMetering url="" apiKey="" sslRef="defaultSSL”/> Replace above with the output of the following cat command cat /opt/IBM/WebSphere/metering-url.txt Replace above with the output of the following cat command cat /opt/IBM/WebSphere/api-key.txt Confirm that the Liberty server is registered to WebSphere Automation https://cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/ This version of Liberty server is not vulnerable to any known CVEs. image

Open a browser and visit the console at the following url

cpd-websphere-automation.apps.ocp.ibm.edu

Login using the openshift authentication with the following username and password

ocadmin ibmocp46

Go to the application runtime under the hamburger menu on the top left corner

You should see the console with no data entries

Next we'll add the liberty and tWAS servers

Open 2 terminal session and login as root on both of them.

Login as root

su root 1bm2021rhjb

Login to the OCP cluster

oc login --username=ocadmin --password=ibmocp46 --insecure-skip-tls-verify=true --server=https://api.ocp.ibm.edu:6443

Change the project to websphere-automation

oc project websphere-automation

Liberty 200012

/opt/IBM/WebSphere/Liberty200012/bin/server create Liberty_200012_server

?? Backup original server.xml

Copy server_tls.xml to server.xml

cp /home/ibmuser/Desktop/lab_backup/liberty200012/server_tls.xml /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/server.xml

Start the server

/opt/IBM/WebSphere/Liberty200012/bin/server start Liberty_200012_server

Getting the usage metering url

echo https://$(oc get route cpd -n websphere-automation -o jsonpath='{.spec.host}')/websphereauto/meteringapi > /opt/IBM/WebSphere/metering-url.txt

Getting the api key

oc -n websphere-automation get secret automation-secure-metering-apis-encrypted-tokens -o jsonpath='{.data.automation-secure-metering-apis-sa}' | base64 -d > /opt/IBM/WebSphere/api-key.txt; echo >> /opt/IBM/WebSphere/api-key.txt

Get server certificate

oc get secret external-tls-secret -n websphere-automation -o jsonpath='{.data.cert.crt}' | base64 -d > /opt/IBM/WebSphere/cacert.pem

Update the keystore

keytool -import -trustcacerts -file /opt/IBM/WebSphere/cacert.pem -keystore /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/resources/security/key.p12 -storetype PKCS12 -storepass th1nkpassword -noprompt

?? encoded password: {xor}KzduMTQvPiwsKDAtOw==

Edit the server.xml, gedit will hold your terminal

gedit /opt/IBM/WebSphere/Liberty200012/usr/servers/Liberty_200012_server/server.xml

Add usage-metering feature like below

usageMetering-1.0 jsp-2.3 transportSecurity-1.0

On your second terminal, run the following cat commands

Add usageMetering element

Get url value and replace it in the above element

cat /opt/IBM/WebSphere/metering-url.txt

Get api key and replace it in the above element

cat /opt/IBM/WebSphere/api-key.txt

Save the server.xml file, close the editor and the second terminal.

Visit the console at the following url and you should see a Liberty Server entry

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/

LIBERTY 20009

Liberty

/opt/IBM/WebSphere/Liberty20009/bin/server create Liberty_20009_server

?? Backup original server.xml

Copy server_tls.xml to server.xml

cp /home/ibmuser/Desktop/lab_backup/liberty20009/server_tls.xml /opt/IBM/WebSphere/Liberty20009/usr/servers/Liberty_20009_server/server.xml

Start the server

/opt/IBM/WebSphere/Liberty20009/bin/server start Liberty_20009_server

Update the keystore

keytool -import -trustcacerts -file /opt/IBM/WebSphere/cacert.pem -keystore /opt/IBM/WebSphere/Liberty20009/usr/servers/Liberty_20009_server/resources/security/key.p12 -storetype PKCS12 -storepass th1nkpassword -noprompt

?? encoded password: {xor}KzduMTQvPiwsKDAtOw==

Edit the server.xml, gedit will hold you terminal.

gedit /opt/IBM/WebSphere/Liberty20009/usr/servers/Liberty_20009_server/server.xml

Add usage-metering feature like below

usageMetering-1.0 jsp-2.3 transportSecurity-1.0

Add usageMetering element

Visit the console at the following url and you should see both Liberty Server entries

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/

tWAS 9056

Start the server

/opt/IBM/WebSphere/AppServer9056/bin/startServer.sh tWAS_9056_server

Configure usage metering

/opt/IBM/WebSphere/AppServer9056/bin/wsadmin.sh -f /api-usagemetering/scripts/configuretWasUsageMetering.py url=$(cat /opt/IBM/WebSphere/metering-url.txt) apiKey=$(cat /opt/IBM/WebSphere/api-key.txt) trustStorePassword=th1nkpassword

Visit the console at the following url and you should see 2 Liberty Server entries and 1 tWAS entry

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/

tWAS 9057

Start the server

/opt/IBM/WebSphere/AppServer9057/bin/startServer.sh tWAS_9057_server

Configure usage metering

/opt/IBM/WebSphere/AppServer9057/bin/wsadmin.sh -f /api-usagemetering/scripts/configuretWasUsageMetering.py url=$(cat /opt/IBM/WebSphere/metering-url.txt) apiKey=$(cat /opt/IBM/WebSphere/api-key.txt) trustStorePassword=password

Visit the console at the following url and you should see 2 Liberty Server entries and 2 tWAS entries

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/

Demo (applying fix packs, removing features etc)

Liberty 20.0.0.9 demo

Let's add a feature:

Edit the server.xml file, adding the following feature

gedit /opt/IBM/WebSphere/Liberty20009/usr/servers/Liberty_20009_server/server.xml

beanValidation-2.0

Now check the console for a change.

If email notification is set up, you will also receive an email about this CVE.

Demo for tWAS 9057

Notice in the console there is 1 CVE (CVE-2021-26296) under the tWAS 9057 server, we are about to fix that.

First, stop the server, wait until it has stopped.

/opt/IBM/WebSphere/AppServer9057/bin/stopServer.sh tWAS_9057_server

Run the following script to install the iFix

/iFix/PH34711/imcl_ifix_install.sh 9057

Start the server back up once the installation was completed.

/opt/IBM/WebSphere/AppServer9057/bin/startServer.sh tWAS_9057_server

Go back to the console. Notice that there are no more CVEs under tWAS 9057.

Also, you can see on the right under "Applied iFixes" there are 4 applied fixes.

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/

Now, stop the server and uninstall the ifix.

/opt/IBM/WebSphere/AppServer9057/bin/stopServer.sh tWAS_9057_server /iFix/PH34711/imcl_ifix_uninstall.sh 9057

Start the server back up

/opt/IBM/WebSphere/AppServer9057/bin/startServer.sh tWAS_9057_server

Go back to the console. Notice that there is now again 1 CVE under the tWAS 9057 server.

cpd-websphere-automation.apps.ocp.ibm.edu/websphereauto/secvul/