Name | Date | Size | |
---|---|---|---|
.. | 2015-11-12 23:01:10 | 5 | |
conf | 2015-10-16 09:14:04 | 3 | |
README.md | 2015-11-12 23:01:10 | 34.1 KiB |
README.md
/**
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2015 ForgeRock AS. All rights reserved.
*
* The contents of this file are subject to the terms
* of the Common Development and Distribution License
* (the License). You may not use this file except in
* compliance with the License.
*
* You can obtain a copy of the License at
* See the License for the specific language governing
* permission and limitations under the License.
*
* When distributing Covered Code, include this CDDL
* Header Notice in each file and include the License file
* If applicable, add the following below the CDDL Header,
* with the fields enclosed by brackets [] replaced by
* your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*/
Roles Sample: Roles and Provisioning
=====================================
One of the great features of OpenIDM Roles is the ability to provision a set of attributes based on role membership.
Let's take a concrete example and continue with our Employee and Contractor roles example that was provided in the
_crudops_ sample. This example will also build on _sample2b_ to provision user entries from Managed User to OpenDJ.
As an employee of the company a worker should be added to a couple of groups in OpenDJ (presumably to get access to some
internal applications): the Employees group and the Chat Users group. But as a Contractor, workers will be added to the
Contractors group only. We also want the type of employee to be set properly in OpenDJ, based on the role allocated to
each user.
Pre-requisites: we assume that you are familiar with _sample2b_ and already have installed OpenDJ according to the
instructions and configuration provided in that sample. We also assume here that you have reconciled the entries as
explained in that sample's section 2 & 4, but for this current sample.
Note: the Example.ldif provided with this sample should be loaded to OpenDJ, if that wasn't done previously.
$ opendj/bin/ldapmodify -a -c --bindDN "cn=Directory Manager" --bindPassword password --hostname localhost --port 1389 --filename openidm/samples/roles/provrole/data/Example.ldif
To run this sample, use the following command:
$ ./startup.sh -p samples/roles/provrole
Then create the Employee and Contractor roles, as you learned in the previous (crudops) sample. You can use the Admin
UI or the REST interface to do this.
When you have created the roles, reconcile the managed user repository with the external system (OpenDJ). The easiest
way to do this is by using the Admin UI. From the Dashboard, click Select a Mapping. Click on the first mapping
(System/Ldap/Account --> Managed User) and click Reconcile Now. This populates the managed user repository with the
entries in OpenDJ.
This sample provides all the information you need to cover the following use cases:
* Update a role with an assignment (sometimes called an entitlement)
* Assign a role to a user and observe the assignments for that user
* Specify how assignments will be propagated to an external system (OpenDJ)
* Deallocate a role from a user and observe how the assignments are withdrawn from the external system
1. Update the Employee role to add the correct groups and employee type
Let's take a look at the roles we created in the _crudops_ sample first:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
{
"result": [
{
"_id": "336b53d8-e17a-4693-b422-e3c0aace025c",
"_rev": "1",
"name": "Employee",
"description": "Role assigned to workers on the payroll."
},
{
"_id": "e9a3aa84-350c-48f1-bee7-17bb47e1c303",
"_rev": "1",
"name": "Contractor",
"description": "Role assigned to contract workers."
}
],
"resultCount": 2,
"pagedResultsCookie": null,
"totalPagedResultsPolicy": "NONE",
"totalPagedResults": -1,
"remainingPagedResults": -1
}
Now, according to our company's policy, we need to make sure that every employee will have the correct _employeeType_
attribute in OpenDJ (corporate directory).
This is achieved in several steps. The first one is the create a new managed assignment:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request POST \
--data '{
"name" : "Employee",
"description": "Assignment for employees.",
"mapping" : "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "employeeType",
"value": "Employee",
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
}
]
}' \
{"_id":"5d6dda22-20f2-491f-a9c1-6c3cffb2460e","_rev":"1","name":"Employee","description":"Assignment for employees.","mapping" : "managedUser_systemLdapAccounts","attributes":[{"name":"employeeType","value":"Employee","assignmentOperation":"mergeWithTarget","unassignmentOperation":"removeFromTarget"}]}
The next step is to add the assignment to the Employee role. Since we already have that role we will just patch that
entry:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "add",
"field" : "/assignments/-",
"value" : { "_ref": "managed/assignment/5d6dda22-20f2-491f-a9c1-6c3cffb2460e" }
}
]' \
{
"_id": "Employee",
"_rev": "2",
"name": "Employee",
"description": "Role assigned to workers on the payroll."
}
2. Allocate the Employee role to bjensen
In order to fully leverage _sample2b_ we will use Barbara Jensen as the employee. Let's take a look at the roles we
should have right now:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
{
"result": [
{
"_id": "Employee",
"_rev": "2",
"name": "Employee",
"description": "Role assigned to workers on the payroll."
},
{
"_id": "Contractor",
"_rev": "1",
"name": "Contractor",
"description": "Role assigned to contract workers."
}
],
"resultCount": 2,
"pagedResultsCookie": null,
"totalPagedResultsPolicy": "NONE",
"totalPagedResults": -1,
"remainingPagedResults": -1
}
When you have both roles listed, you just need to assign the Employee role to bjensen. But first you need to find out
what the identifier is for bjensen's entry:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/managed/user?_queryFilter=/userName+eq+"bjensen"&_fields=_id&_prettyPrint=true'
{
"result" : [ {
"_id" : "8ff9639f-2a89-48a2-a0fd-9df4d5297eeb"
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"remainingPagedResults" : -1
}
Therefore you can assign the Employee role by using:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "add",
"field" : "/roles/-",
"value" : { "_ref": "managed/role/Employee" }
}
]' \
{
"_id": "8ff9639f-2a89-48a2-a0fd-9df4d5297eeb",
"_rev": "2",
"displayName": "Barbara Jensen",
"description": "Created for OpenIDM",
"givenName": "Barbara",
"mail": "bjensen@example.com",
"telephoneNumber": "1-360-229-7105",
"sn": "Jensen",
"userName": "bjensen",
"accountStatus": "active",
"effectiveRoles": [
{
"_ref": "managed/role/Employee"
}
],
"effectiveAssignments": [
{
"name": "Employee",
"description": "Assignment for employees.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "employeeType",
"value": "Employee",
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
}
],
"_id": "e9901373-60f4-4d86-b928-a6cd19449d50",
"_rev": "1"
}
],
"roles": [
{
"_ref": "managed/role/Employee",
"_refProperties": {
"_id": "06b5b119-e450-4ee7-9559-d3d2a0cdf76f",
"_rev": "1"
}
}
]
}
Let's take a closer look at bjensen's entry for what we're really interested in, i.e. the roles, effective roles and
effective assignments:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/managed/user?_queryFilter=/userName+eq+"bjensen"&_fields=_id,userName,roles,effectiveRoles,effectiveAssignments&_prettyPrint=true'
{
"result" : [ {
"_id" : "8ff9639f-2a89-48a2-a0fd-9df4d5297eeb",
"userName" : "bjensen",
"roles" : [ {
"_ref" : "managed/role/Employee",
"_refProperties" : {
"_id" : "193a60b6-7b2e-467e-a8fc-a59d67fca858",
"_rev" : "1"
}
} ],
"effectiveRoles" : [ {
"_ref" : "managed/role/Employee",
"_refProperties" : {
"_id" : "193a60b6-7b2e-467e-a8fc-a59d67fca858",
"_rev" : "1"
}
} ],
"effectiveAssignments" : [ {
"name" : "Contractor",
"description": "Role assigned to contract workers.",
"mapping" : "managedUser_systemLdapAccounts",
"attributes" : [ {
"name" : "employeeType",
"value" : "Employee",
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget",
"assignedThrough" : "managed/role/Employee"
} ]
} ]
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"totalPagedResultsPolicy" : "NONE",
"totalPagedResults" : -1,
"remainingPagedResults" : -1
}
We can now clearly see the impact of the new property we added to the role. The user now has a new (calculated) property
which includes the set of assignments (or entitlements) that pertain to the user with that role. Currently this only
lists the _employeeType_ attribute.
3. Pushing assignments out to OpenDJ (external system)
If you take a look at bjensen directly in the directory you should see the attribute _employeeType_ being populated
properly:
$ ldapsearch -p 1389 -h localhost -b "dc=example,dc=com" -D "cn=Directory Manager" -w - -s sub uid=bjensen dn uid employeeType
# bjensen, People, example.com
dn: uid=bjensen,ou=People,dc=example,dc=com
uid: bjensen
employeeType: Employee
Now let's make this a little more interesting by adding the groups that an Employee should have in the corporate
directory (OpenDJ).
We just need to update the Employee role with the appropriate assignments. First, look at the current assignments of the
Employee role:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
{
"_id" : "Employee",
"_rev" : "2",
"name" : "Employee",
"description" : "Role assigned to workers on the payroll.",
"assignments": [
{
"_ref": "managed/assignment/5d6dda22-20f2-491f-a9c1-6c3cffb2460e",
"_refProperties": {
"_id": "6f3e22ae-c4a6-4422-a4f2-ac13458bf1c4",
"_rev": "1"
}
}
]
}
We simply need to add the attribute for groups to the assignment 5d6dda22-20f2-491f-a9c1-6c3cffb2460e:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "add",
"field" : "/attributes/-",
"value" : {
"name": "ldapGroups",
"value": [
"cn=Employees,ou=Groups,dc=example,dc=com",
"cn=Chat Users,ou=Groups,dc=example,dc=com"
],
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
}
}
]' \
{
"_id": "5d6dda22-20f2-491f-a9c1-6c3cffb2460e",
"_rev": "2",
"name": "Employee",
"description": "Assignment for employees.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "employeeType",
"value": "Employee",
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
},
{
"name": "ldapGroups",
"value": [
"cn=Employees,ou=Groups,dc=example,dc=com",
"cn=Chat Users,ou=Groups,dc=example,dc=com"
],
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
}
]
}
After adding this new attribute to the assignment, bjensen should be added to the Chat Users and Employees groups.
$ ldapsearch -p 1389 -h localhost -b "dc=example,dc=com" -D "cn=Directory Manager" -w - -s sub uid=bjensen dn uid employeeType isMemberOf
# bjensen, People, example.com
dn: uid=bjensen,ou=People,dc=example,dc=com
uid: bjensen
employeeType: Employee
isMemberOf: cn=Chat Users,ou=Groups,dc=example,dc=com
isMemberOf: cn=Employees,ou=Groups,dc=example,dc=com
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/system/ldap/account?_queryFilter=/uid+sw+"bjensen"&_fields=dn,uid,employeeType,ldapGroups&_prettyPrint=true'
{
"result" : [ {
"dn" : "uid=bjensen,ou=People,dc=example,dc=com",
"uid" : "bjensen",
"employeeType" : "Employee",
"ldapGroups" : [ "cn=Chat Users,ou=Groups,dc=example,dc=com", "cn=Employees,ou=Groups,dc=example,dc=com", ]
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"remainingPagedResults" : -1
}
Let's continue with adding the appropriate attribute to the Contractor assignment and allocating that role to jdoe, who
is a contractor and therefore not entitled to access the internal chat application.
First create the Contractor assignment:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-None-Match: *" \
--request PUT \
--data '{
"name" : "Contractor",
"description": "Contractor assignment for contract workers.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "ldapGroups",
"value": [
"cn=Contractors,ou=Groups,dc=example,dc=com"
],
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
},
{
"name": "employeeType",
"value": "Contractor",
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
}
]
}' \
{
"_id": "Contractor",
"_rev": "1",
"name": "Contractor",
"description": "Contractor assignment for contract workers.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "ldapGroups",
"value": [
"cn=Contractors,ou=Groups,dc=example,dc=com"
],
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
},
{
"name": "employeeType",
"value": "Contractor",
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
}
]
}
Now add the Contractor assignment to the Contractor role:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "add",
"field" : "/assignments/-",
"value" : {
"_ref" : "managed/assignment/Contractor"
}
}
]' \
{
"_id": "Contractor",
"_rev": "2",
"name": "Contractor",
"description": "Role assigned to contract workers."
}
Now we just need to allocate the Contractor role to jdoe and he should be automatically added to the Contractors group
in OpenDJ. Let's first take a look at jdoe's entry to make sure we know the value of the identifier:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/managed/user?_queryFilter=/userName+eq+"jdoe"&_fields=_id&_prettyPrint=true'
{
"result" : [ {
"_id" : "3f9ada28-2809-4909-aadf-815567b00a4d"
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"remainingPagedResults" : -1
}
Now we can update jdoe's entry with the Contractor role:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "add",
"field" : "/roles/-",
"value" : {
"_ref": "managed/role/Contractor"
}
}
]' \
{
"_id": "3f9ada28-2809-4909-aadf-815567b00a4d",
"_rev": "2",
"displayName": "John Doe",
"description": "Created for OpenIDM",
"givenName": "John",
"mail": "jdoe@example.com",
"telephoneNumber": "1-415-599-1100",
"sn": "Doe",
"userName": "jdoe",
"accountStatus": "active",
"effectiveRoles": [
{
"_ref": "managed/role/Contractor"
}
],
"effectiveAssignments": [
{
"name": "Contractor",
"description": "Contractor assignment for contract workers.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "ldapGroups",
"value": [
"cn=Contractors,ou=Groups,dc=example,dc=com"
],
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
},
{
"name": "employeeType",
"value": "Contractor",
"assignmentOperation": "mergeWithTarget",
"unassignmentOperation": "removeFromTarget"
}
],
"_id": "Contractor",
"_rev": "1"
}
],
"roles": [
{
"_ref": "managed/role/Contractor",
"_refProperties": {
"_id": "e8295a1f-f367-489d-9573-f4ccbb2822d1",
"_rev": "1"
}
}
]
}
Let's now take a look at jdoe's entry in order to make sure that the proper employee type has been set and that jdoe has
been added to the Contractors group.
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/system/ldap/account?_queryFilter=/uid+sw+"jdoe"&_prettyPrint=true'
{
"result" : [ {
"sn" : "Doe",
"telephoneNumber" : "1-415-599-1100",
"employeeType" : "Contractor",
"dn" : "uid=jdoe,ou=People,dc=example,dc=com",
"cn" : "John Doe",
"uid" : "jdoe",
"ldapGroups" : [ "cn=openidm,ou=Groups,dc=example,dc=com", "cn=Contractors,ou=Groups,dc=example,dc=com" ],
"givenName" : "John",
"mail" : "jdoe@example.com",
"description" : "Created for OpenIDM",
"_id" : "uid=jdoe,ou=People,dc=example,dc=com"
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"remainingPagedResults" : -1
}
4. Removing a role from a user
Now we know what happens with entitlements when a role is assigned to a user, let's take a look at what happens when a
role is deallocated from a user entry.
Again, we take a look at jdoe's entry to find out about its state:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/managed/user?_queryFilter=/userName+eq+"jdoe"&_fields=_id,roles&_prettyPrint=true'
{
"result" : [ {
"_id" : "3f9ada28-2809-4909-aadf-815567b00a4d",
"roles" : [ {
"_ref" : "managed/role/Contractor",
"_refProperties" : {
"_id" : "e8295a1f-f367-489d-9573-f4ccbb2822d1",
"_rev" : "1"
}
} ]
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"totalPagedResultsPolicy" : "NONE",
"totalPagedResults" : -1,
"remainingPagedResults" : -1
}
We therefore need to remove the 1st element of the roles array (index = 0) in order to remove the Contractor role --
also please note the entry's identifier that is used in the request's URL:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-Match: *" \
--request PATCH \
--data '[
{
"operation" : "remove",
"field" : "/roles/0"
}
]' \
{
"_id": "3f9ada28-2809-4909-aadf-815567b00a4d",
"_rev": "3",
"displayName": "John Doe",
"description": "Created for OpenIDM",
"givenName": "John",
"mail": "jdoe@example.com",
"telephoneNumber": "1-415-599-1100",
"sn": "Doe",
"userName": "jdoe",
"accountStatus": "active",
"effectiveRoles": [],
"effectiveAssignments": [],
"roles": []
}
This results in jdoe's entry in OpenDJ not belonging to the Contractors group anymore and in his employee type being
undefined. Check that with a query on his entry in OpenDJ:
$ curl --insecure \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--request GET \
'https://localhost:8443/openidm/system/ldap/account?_queryFilter=/uid+sw+"jdoe"&_prettyPrint=true'
{
"result" : [ {
"sn" : "Doe",
"telephoneNumber" : "1-415-599-1100",
"employeeType" : null,
"dn" : "uid=jdoe,ou=People,dc=example,dc=com",
"cn" : "John Doe",
"uid" : "jdoe",
"ldapGroups" : [ "cn=openidm,ou=Groups,dc=example,dc=com" ],
"givenName" : "John",
"mail" : "jdoe@example.com",
"description" : "Created for OpenIDM",
"_id" : "uid=jdoe,ou=People,dc=example,dc=com"
} ],
"resultCount" : 1,
"pagedResultsCookie" : null,
"remainingPagedResults" : -1
}
Note: some additional samples might be provided to demonstrate the different assignment operations (merge, replace,
remove, etc.).
This is pretty much everything you need to know about roles, assignments and entitlements and how to manipulate them via
the REST API.
Appendix
--------
If you need to reload the Employee and Contractor roles and assignments entirely without going through each step in the
samples, here are the REST requests to do just that:
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-None-Match: *" \
--request PUT \
--data '{
"name" : "Employee",
"description": "Employee assignment for workers on the payroll.",
"mapping": "managedUser_systemLdapAccounts",
"attributes": [
{
"name": "ldapGroups",
"value": [
"cn=Employees,ou=Groups,dc=example,dc=com",
"cn=Chat Users,ou=Groups,dc=example,dc=com"
],
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
},
{
"name": "employeeType",
"value": "Employee",
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
}
]
}' \
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-None-Match: *" \
--request PUT \
--data '{
"name" : "Contractor",
"description": "Contractor assignment for contract workers.",
"attributes": [
{
"name": "ldapGroups",
"value": [
"cn=Contractors,ou=Groups,dc=example,dc=com"
],
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
},
{
"name": "employeeType",
"value": "Contractor",
"assignmentOperation" : "mergeWithTarget",
"unassignmentOperation" : "removeFromTarget"
}
]
}' \
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-None-Match: *" \
--request PUT \
--data '{
"name" : "Employee",
"description": "Role assigned to workers on the payroll.",
"assignments": [
{
"_ref": "managed/assignment/Employee"
}
]
}' \
$ curl --insecure \
--header "Content-type: application/json" \
--header "X-OpenIDM-Username: openidm-admin" \
--header "X-OpenIDM-Password: openidm-admin" \
--header "If-None-Match: *" \
--request PUT \
--data '{
"name" : "Contractor",
"description": "Role assigned to contract workers.",
"assignments": [
{
"_ref": "managed/assignment/Contractor"
}
]
}' \