Skip to main content

Authorizing a Sample Java App from Oracle Entitlement Server

Create a simple authorization policy from OES and invoke authorization decision using Standard API from a Java application to allow or deny the access.


  1. Create New Application (go to Authorization management > Application > click new Application)
  2. Create New Security Module (go to System Configuration > Security Module > click New) And add Newly Created Application to it. 
  3. Create New Resource Type (go to Newly Created Application > Resource Types > Click new)
  4. Create New Resource (go to Newly Created Application > Default Policy Domain > Resources Catalog > Resources > Create New)
  5. Create New Permit Authorization Policy (go to Newly Created Application > Default Policy Domain > Application Policies > Create New)


  1. 6.      Create New Deny Authorization Policy (go to Newly Created Application > Default Policy Domain > Application Policies > Create New)



    1.     Edit the following file: OES_CLIENT_HOME/oessm/SMConfigTool/smconfig.java.controlled.prp

    oracle.security.jps.runtime.pd.client.sm_name=SM_WB_JAVA
    NOTE: same name as created using OES Admin Console
    #  Policy dustribution mode is controlled-push
    oracle.security.jps.runtime.pd.client.policyDistributionMode=controlled-push

    #  -------- Policy Distributor connectivity information - required for controlled-push distribution mode
    oracle.security.jps.runtime.pd.client.RegistrationServerHost=localhost
    oracle.security.jps.runtime.pd.client.RegistrationServerPort=7002

    Note- SSL Port of OES Server

    # >>>>>>>>>>>>OPTIONAL PARAMETERS<<<<<<<<<<<<<<<<<
    # ------------ Only for Java SM, WS SM, and RMI SM in controlled-push mode --------------------
    #  port to listen for policy distribution. Picked automatically by SM config tool if not specified
    oracle.security.jps.runtime.pd.client.DistributionServicePort=

    oracle.security.jps.runtime.pd.client.sm_type=java


    8.  Run the config.sh (OES_CLIENT_HOME/oessm/bin)
    config.sh –smConfigId <SM_NAME_AS _IN_PRP_FILE> -prpFileName
    OES_CLIENT_HOME/oessm/SMConfigTool/smconfig.java.controlled.prp



    9.      This will create a directory in OES_CLIENT_HOME /oes_sm_instances/< SM_NAME_AS _IN_PRP_FILE >

    10.      Create a sample application to validate the authorization request. Code Snippet is as follows-

    1.  public class HelloWBworld {
    2.   
    3.     public static void main(String[] args) {
    4.   
    5.        // user initiating Authorization request
    6.        Principal p = new WLSUserImpl("weblogic_wc");
    7.                System.out.println("HelloWBworld :: principal :: "+p);
    8.        Subject user = new Subject();
    9.        System.out.println("HelloWBworld :: Subject :: "+user);
    10.  
    11.       user.getPrincipals().add(p);
    12.               System.out.println("HelloWBworld :: Subject after add :: "+user);
    13.  
    14.       // Resource being accessed AppName/ResourceType/ResouceName
    15.       String resourceString = "HelloWBWorld/MyWBResourceType/MyWBResource";
    16. System.out.println("HelloWBworld :: resourceString :: "+resourceString);
    17.  
    18.       // Action initiated by the user
    19.       String action = "write";
    20. System.out.println("HelloWBworld :: action :: "+action);
    21.       // Environmental/Context attributes
    22.  
    23.       while (true)
    24.       {
    25.                 System.out.println("HelloWBworld :: while start ");
    26.          try {
    27.             // get Authorization response from OES
    28.             PepResponse response =
    29.                 PepRequestFactoryImpl.getPepRequestFactory()
    30.                         .newPepRequest(
    31.                                 user,
    32.                                 action,
    33.                                 resourceString,
    34.                                 null).decide();
    35.  
    36.             System.out.println("Request: {" + user + " " + action + " " + resourceString
    37.                      + "} \nResult: " + response.allowed());
    38.  
    39. //         } catch (PepException e) {
    40.          } catch (PepException e) {
    41.  
    42.             System.out.println("***** Caught exception: "
    43.                                 + e.getMessage());
    44.             e.printStackTrace();
    45.             System.exit(1);
    46.          }
    47.       }
    48.    };
    49. };
    11.      Run the program to check that it is authorizing the user initiating the resource request.




Comments

Popular posts from this blog

Adding UDF (User Defined Field) on create user page OIM 11g R2 PS1:-

    Login to Sysadmin console and create a Sandbox and activate it. Click on Form Designer and search for user form. 2.      Create a new field of desired type. 3.      Provide the Required Values for UDF creation and click save and close. UDF field will be added then publish the sand box. 4.      Login to Identity console now and create another sandbox and activate it. After sandbox is activated click on users link and the click on create user. 5.      Provide the mandatory values on the form and then click the customize button on top. Select source from the view. 6.      Select the panel where the field has to be added. Select panel form lay out click add content. Select Data component Catalog from the box. 7.      Select UserVO from the bottom. ...

OIM Tuning

Application Module tuning is a critical setting which will affect the UI performance. Following are the recommended application module settings for OIM and these are already set out-of-box (OOB) in later releases of OIM 11g R2. Ensure that these settings are implemented as recommended in your environment. -Djbo.ampool.doampooling=true -Djbo.ampool.minavailablesize=1 -Djbo.ampool.maxavailablesize=120 -Djbo.recyclethreshold=60 - Djbo.ampool.timetolive=-1 -Djbo.load.components.lazily=true - Djbo.doconnectionpooling=true -Djbo.txn.disconnect_level=1 - Djbo.connectfailover=false -Djbo.max.cursors=5 - Doracle.jdbc.implicitStatementCacheSize=5 - Doracle.jdbc.maxCachedBufferSize=19 open DOMAIN_HOME/bin/setDomainEnv.sh file for the WebLogic Server instance.find these lines: JAVA_OPTIONS="${JAVA_OPTIONS}" export JAVA_OPTIONS and change it to: JAVA_OPTIONS="-Djbo.ampool.doampooling=true -Djbo.ampool.minavailablesize=1 -Djbo.ampool.maxavailablesize=120 -D...

OIM Reports : PS3

Oracle Business Intelligence Publisher is Oracle's primary reporting tool for authoring, manag-ing, and delivering all your highly formatted reports. BI Publisher is shipped with Oracle Identity Manager 11g Release 2 PS3. BI Publisher is deployed and configured as a separate managed server within the same Oracle Identity Manager domain. You have the choice of either leveraging the embedded BI Publisher or a standalone BI Publisher. It is recommended that you use the embedded BI Publisher if there are no other reporting requirements and you only need reporting for Oracle Identity Manager. After BI Publisher configuration, you can take advantage of the standard features of BI Publisher, such as:  Access Policy Reports  Request and Approval Reports  Password Reports  Resource and Entitlement Reports  User Reports  Certification Reports  Identity Audit Reports  Exception Reports The Screenshot of all the reports can be seen below: Every Report uses a Da...