lab-guides

Delphix lab exercises for use with LabAlchemy hands-on labs

View the Project on GitHub delphix/lab-guides

Table of Contents

Lab Exercises

Part I

Part II

Lab Exercises

Welcome to the Delphix Masking Lab Guide. This guide is a supplement to the Delphix Admin Training for Oracle course, and provides several exercises to perform throughout the class. If you encounter any issues during the exercises, please do not hesitate to ask your instructor for advice.

Your instructor should have provided you with a Class Name and a Student Number. In order to access your lab server, point your web browser to: http://classname.agile.today/studentnumber

For example, if your Class Name is “acmetech” and your Student Number is 5, you would go to the site: http://acmetech.agile.today/5

Important IP Addresses

Host IP
Delphix Masking Engine 10.0.x.10
Linux Source 10.0.x.20
Linux Target 10.0.x.30

In the above IP addresses, the x denotes your Student Number. For example, if your student number is 5 , your Delphix Data Platform will be located at 10.0. 5.10.

Cloud Lab Usernames and Passwords

  Credentials
Initial Delphix Masking Engine Admin user Admin
Initial Delphix Masking Engine Admin password Admin-12
Initial Delphix Virtualization Engine admin password delphix
Source and Target delphix user (via SSH) delphix
Source and Target oracle user (via SSH) delphix

Part I

Exercise 1 - Logging in to the Masking Engine

In this exercise, you will:

Steps

  1. Connect to your Delphix Engine using Google Chrome on your lab server (see the Important IP Addresses section of the Getting Started guide above).

    http://10.0.x.10/masking (replace ‘x’ with your student number)

    Troubleshooting tip: If the above URL doesn’t work, you might need to set up the masking engine first. In this case, you should log into the Delphix engine using the sysadmin user (user and password both = sysadmin and follow the Masking setup wizard).

  2. Enter your User Id and Password

    a. Default Username is Admin

    b. Default Password is Admin-12

  3. Close the Welcome Wizard by clicking on the X on the top right corner of the page. You should now be viewing the Environments page.

In the proceeding exercises we will add an application and associate with an environment.

Exercise 2 - Add an Application

In this exercise, you will:

Steps

  1. On the Environments List/Summary screen click on the Add Application button

  2. Enter “Medical App Dev” for the Application name in the Application pop up box

  3. Click on the Save button

The application should be added successfully.

Exercise 3 - Add an Environment

In this exercise, you will:

Steps

  1. On the Environments List/Summary screen click on the Add Environment button

  2. Select the Application Name from the drop-down list created in the previous exercise

  3. Enter “Oracle Dev DB” for the Environment Name

  4. Select Mask from the Purpose drop-drown list

  5. Click on the Save button

The environment should now be visible in the Environment List/Summary screen.

Exercise 4 - Create a Basic Connector

In this exercise, you will:

Steps

Note: If your class was stopped you will need to manually start it from the Delphix Engine before proceeding with the following exercise. Ask your instructor if you are unable to complete this step.

  1. Log into the Masking Engine

  2. Click on the Oracle Dev DB environment created in the previous exercise

  3. Click on the Connector tab

  4. Click the Create Connection button

  5. Enter Connection Details

    a. Chose Database - Oracle from the Type drop-down list

    b. Verify that the Basic radio button next to the Type

    c. Enter “Oracle 11g Dev” for the connection name

    d. Type DELPHIXDB (in uppercase) in the Schema Name text box

    e. Enter the IP address of TargetA (10.0.x.30 where ‘x’ is your Student Number) in the Host Name/IP field

    f. Enter devdb as the SID

    g. Enter 1521 as the port number for the listener on Linux Target

    h. Enter DELPHIXDB (in uppercase) as the DB login ID

    i. Provide the password: delphix

    j. Click the Test Connection button. A Success message indicates whether the test was successful or not.

k. Save the connection

The connector should now be visible in the Connectors list for the environment.

Exercise 5 - Create a Ruleset

In this exercise, you will:

Note: A “rule set” points to a collection of tables or flat files that the masking engine uses for profiling, provisioning, and masking, and certifying data. For mainframe systems, the rule set represents a copybook definition for a file.

Steps

  1. On the Environment List/Summary screen, click on the Environment Name created in the previous exercise

  2. Click on the Rule Set tab

  3. Click on the Create Rule Set button

  4. Provide the details for the rule set as follows:

    a. Enter “Patient Rule Set” in the name field for the Rule Set

    b. Select Oracle 11g Dev from the Connector drop-down list

    c. Check the boxes next to MEDICAL_RECORDS, PATIENT and PATIENT_DETAILS tables

  1. Click on the Save button

You will see the newly created Rule Set in the list for the environment.

Exercise 6 - Manage the Inventory

In this exercise, you will:

Steps

  1. On the Environment List/Summary screen, click on the Environment Name created in the previous exercise

  2. Click on the Inventory tab

  3. From the Select Rule Set drop-down menu choose the Patient Rule Set created previously

  4. A list of tables will be displayed under the Contents section. Clicking on the name of each table will allow you to view the table metadata.

    a. Click on the PATIENT table

    b. Verify if there are any primary keys, foreign keys or indexes identified

    c. Validate the Data Type of each Column

  5. Edit the ADDRESS column by clicking on the corresponding pencil icon

  6. Change properties of the column

    d. Set Domain to ADDRESS

    e. Choose the ADDRESS LINE SL algorithm

    f. Select User for ID Method

g. Click Save

Exercise 7 - Create a Profiling Job

In this exercise, you will:

Steps

  1. Click on the Settings tab

  2. Click on Profiler under Domains in the left margin of the settings page

  3. View the profiler expressions

    a. Domain & Expression

    b. Name

    c. Level

  1. Click on the Add Profiler Set button to view the default Profile Sets

  2. Click Cancel and navigate back to the Environment List/Summary screen

In the next part of the exercise we will create and execute a profiling job.

  1. Click on the Oracle Dev DB Environment

  2. Click on the Profile button

  3. On the Create Profile Job screen enter the details as follows:

    d. Select Patient Rule Set from the Rule Set drop-down list

    e. Enter Profile Patient Job for the job name

    f. Choose HIPAA from the Profile Sets drop-down list

    g. Set No. of Streams to 1

    h. Leave other fields at their default values

    i. Click the Save button

  4. The newly created profiling job will be displayed at the bottom of the Environment Overview screen with a status of Created

  5. Click on the blue play button under Action to execute the job. The status should change to Running and the stop Action button will be enabled.

  6. Click on the Monitor tab to see the list of jobs and their progress

  7. Click on the job name to view the job details

  1. View the Completed, Processing, Waiting and Results tabs for the job

Note that the Results tab displays the number of sensitive columns and tables discovered by the profiler

In the next part of the exercise, we will review the Inventory after running the profile job.

  1. Go to the Environment List/Summary screen by clicking on the Environments tab and choose the Oracle Dev DB environment

  2. Click on the Inventory tab for the environment

  3. Select the Patients Rule Set from the Rule Set drop-down list

  4. Click on the MEDICAL_RECORDS table

    Note that the Algorithm column has been populated for sensitive columns identified during profiling

  1. Click on the PATIENT and PATIENT_DETAILS tables, and note the Algorithms for the sensitive columns

Exercise 8 - Create a Masking Job

In this exercise, you will:

Steps

  1. On the Environment List/Summary screen, click on the Oracle Dev DB Environment Name created in the previous exercise

  2. Click on the Mask button

  1. Enter Details in the Create Masking Job dialog

    a. Job Name: Patient Masking

    b. Masking Method: In-Place

    c. Rule Set: Patient Rule Set

    d. No. of Streams: 1

    e. Update Threads 1

    f. Leave other fields at the default values

The Create Masking Job dialog should look like the screenshot shown below.

g.  Click on the Save button
  1. The Masking job will appear on the Environment summary screen with astatus of Created

  1. Before executing our masking job, we need to check the values of the PATIENT table before running our masking job, and again after to verify that the data has indeed been masked.

  2. Open the Terminal app on the lab desktop

  3. Type the following commands in the terminal window to run the script to query the PATIENT table

Note: You may need to widen your terminal window to prevent the output from wrapping. After typing in each command press the Enter or Return key on your keyboard.

a. cd Scripts/Masking602 (Note: the number after masking could be different if you are using a more up-to-date classrooom; confirm with your lab instructor should you have difficult here, or ls to find the correct selection.)

b. ./check_patient_devdb.sh

NOTE: Oracle SQL Developer is also available on the desktop to view the tables

Do not close the terminal window as you will need to validate that the data has changed after successfully executing the masking job.

  1. Click on the blue play button under the Action column that corresponds to the newly created Masking job to execute it

The job status will change to Running

  1. Click on the Monitor tab to view the progress and status of the job

  1. Click on the name of the job to view its details

  1. Click on the Completed, Process and Waiting tabs in the job details screen and note the results once the job has completed

  1. Click on the environment name to go back to the Environment summary screen. The status of the masking job should now be Succeeded

  1. Open a new terminal window on the lab desktop and execute the following script:

    ~/Scripts/Masking602/check_patient_devdb.sh

Note: The values for the Firstname, Lastname, Address, Zipcode, Phone_number, and Email have been masked using the secure lookup algorithm while the values for the City column have been set to NULL.

Part II

Exercise 9 - Create a Secure Lookup algorithm 

In this exercise, you will:

Steps

  1. Open the text editor on the desktop (mousepad)

  2. Enter several names in the editor, one value per line, and save to desktop as FN2.txt

  1. Navigate to SETTINGS -> ALGORITHMS in the masking UI

  2. Select

  3. With Secure Lookup Algorithm radial button selected enter Algorithm Name: Name2SL, a Description as shown below, and click Select to select the file you created in step 2 from your desktop

  1. Save the algorithm and navigate to the Inventory of the Patient Rule Set

  2. Select the Patient table from the table list on the left hand margin

  3. On the Algorithm drop down select the new First Name2 SL algorithm (you will need to click on the Edit pencil next to the FIRSTNAME column to get here) and click Save

Exercise 10 - Create a Segmented Mapping algorithm

In this exercise, you will:

Steps

  1. Navigate to Settings -> Algorithm

  2. Select Add Algorithm

  3. With the Segmented Mapping Algorithm radio button selected

    a. Name the algorithm SSN SM

    b. Define 3 alpha numeric segments of 3, 2, and 4 length

    c. Click the Ignore comma checkbox

    d. Define ignore characters of “-“,” “,”/” (dash, space, forward slash)

    e. Save the algorithm

  1. Navigate to your Environments

  2. Click the Oracle DEV DB environment then choose the Inventory tab

  3. Select the Patient table from the table list on the left hand margin

  4. Click the edit pencil next to the SOCIAL_SECURITY_NUMBER column

  5. From the domain drop down select the SSN domain

  6. From the algorithm drop down select your SSN algorithm and save the changes

  7. Navigate to the Overview tab and select the blue play button to run the Patient Masking job

  8. When the job completes, view the Patient table data (with the check_patient_devdb.sh script from terminal session or SQL Developer)

  9. Note that the FIRST_NAME column now contains values from our lookup file

  10. Note that the SOCIAL_SECURITY_NUMBER column has now been masked

This concludes the exercise.

Exercise 11 - Export an Inventory

In this exercise, you will:

Steps

  1. On the Environment List/Summary screen, click on the Environment Name created in the previous exercise

  2. Click on the Inventory tab

  3. From the Select Rule Set drop-down menu choose the Patient Rule Set created previously

  4. Click on the Export button

  5. Accept the default inventory name and file name

  6. Click the Save button

Note that a pop-up window should appear with a link to Download the inventory file. If the pop-up window does not appear, check the browser to see if it was blocked and allow it to display pop-ups.

  1. Right-click on the link that appears on the pop-up window and select “Save link as…”

  2. Save the file to the Desktop

This concludes the exercise.

Exercise 12 - Modify an Inventory using the exported CSV file

In this exercise, you will:

Note: You should have completed the “Export an Inventory” exercise before proceeding.

Steps

  1. Open the exported CSV file from the previous exercise (opens with LibreOffice Calc by default)

    NOTE: LibreOffice is the open source equivalent for MS Office Excel

    Uncheck the Tab and Semicolon checkboxes under Separator options in the Import dialog box. Only the comma box should be checked.

  2. Remove a column from the masking inventory

    a. Note that columns H, I, J contain a domain, algorithm and “true” for sensitive columns

    b. Note that columns H, I, J contain ‘-‘, ‘-‘, ‘false’ for columns that are not sensitive

    c. For Patient table, DOB column, copy a dash into column H and I and copy false from another row into column J.

    d. Save the changes

    Note: A confirmation dialog box will pop up asking to confirm the file format. Click the “Use Text CSV Format” button.

  1. Switch back to the Masking UI in the web browser and navigate to the Inventory for the Patient Rule Set and press the Import button

  2. Select the modified CSV file from your desktop (Note: you may need to scroll down on the import dialog box to see the Save button)

  3. Refresh the masking UI browser session

  4. DOB should no longer be selected for masking

Note: This method of modifying an inventory can be used to speed up a large number of changes as compared to making inventory changes via the UI

Exercise 13 - Refresh a Rule Set

In this exercise, you will:

Steps

  1. Using SQL Developer add a new column called BIRTHDAY to the PATIENT_DETAILS table, data type is date

  1. Navigate to the Inventory tab in the Masking UI and select our Patient Rule Set

  2. Select the PATIENT_DETAILS table in the table list on the left

    Note: The new column is not shown in the inventory

  3. Click the Rule Set tab and select the blue Refresh icon

  4. Click the Inventory tab and note that the new column now appears in the Inventory

Note: This method is used to bring schema changes into the masking inventory

Exercise 14 - Copy a Rule Set

In this exercise, you will:

Steps

  1. Navigate to the Rule Set tab in the UI

  2. Click the Copy icon

  1. Name the new Rule Set Patient Copy and click Save

  2. Click the Inventory tab, select the new Rule Set from the Select Rule Set drop down

  1. Confirm that the Masking Inventory is copied along with column definitions

Note: This method is used to duplicate an inventory

Exercise 15 - Export an Environment

In this exercise, you will:

  1. Log into the Masking Engine

  2. Click on the Export icon corresponding to the Oracle Dev DB environment

  1. On the Export Environment dialog box accept the default Environment Name and File Name

  1. Click the Export button

Note: A pop-up window should appear with a link to Download the environment XML file. If the pop-up window does not appear, check the browser to see if it was blocked and allow it to display pop-ups.

  1. Right-click on the link that appears on the pop-up window and select “Save link as…”

  1. Save the file to the Desktop

Exercise 16 - Import an Environment

In this exercise, you will:

**Note: You will need to perform the exercise “Export an Environment” before proceeding **

  1. Add a new application for QA

    a. Click the Add Application button

    b. Enter the name Medical App QA

  2. On the Environments List/Summary screen click on the Import Environment button

  3. On the Import Environment dialog box, select Medical App QA from the Application Name drop down

  1. Enter “Oracle QA DB” for the environment name

  2. Click on the Select button and browse to the location of the previously exported file

  1. Click on the Save button.

The Oracle QA DB environment will be displayed on the Environment list/Summary screen

Note: You may need to navigate to another tab and click Environments tab again to see the imported environment.

Note: This function is used to replicate a Masking environment and jobs for another copy of the schema

This completes the lab session