Manage licenses using Graph API
Grant licenses
To an organization:
POST /graph/ProductPackage[@title='DemoPackage']
Content-Type: application/x-www-form-urlencoded
operation=InitializeOrganizationLicenses&licensedItemCount=HOW_MANY_LICENSES&ownerOrganizationId=ORGANIZATION_ID&validFrom=ISO_8601_TIMESTAMP&validUntil=ISO_8601_TIMESTAMP
To an individual user:
POST /graph/ProductPackage[@title='DemoPackage']
Content-Type: application/x-www-form-urlencoded
operation=InitializePersonalLicenses&licensedItemCount=HOW_MANY_LICENSES&initializeForProfileId=PROFILE_ID&validFrom=ISO_8601_TIMESTAMP&validUntil=ISO_8601_TIMESTAMP
Change license validity
For an organization license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=validity&validFrom=ISO_8601_TIMESTAMP&validUntil=ISO_8601_TIMESTAMP&operation=InitializeOrganizationLicenses&ownerOrganizationId=ORGANIZATION_ID
For a personal license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=validity&validFrom=ISO_8601_TIMESTAMP&validUntil=ISO_8601_TIMESTAMP&operation=InitializePersonalLicenses&initializeForProfileId=PROFILE_ID
Change a license’s count or quota
For an organization license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=quota&licensedItemCount=NEW_COUNT&operation=InitializeOrganizationLicenses&ownerOrganizationId=ORGANIZATION_ID
For a personal license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=quota&licensedItemCount=NEW_COUNT&operation=InitializePersonalLicenses&initializeForProfileId=PROFILE_ID
Change a license’s maximum aggregated use time
For an organization license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=aggregateUseTime&maxAggregateUseTime=NEW_TIME_LIMIT_MILLISECONDS&operation=InitializeOrganizationLicenses&ownerOrganizationId=ORGANIZATION_ID
For a personal license:
POST /graph/License[@id='LICENSE_ID']
Content-Type: application/x-www-form-urlencoded
change=aggregateUseTime&maxAggregateUseTime=NEW_TIME_LIMIT_MILLISECONDS&operation=InitializePersonalLicenses&initializeForProfileId=PROFILE_ID
See more information on the AggregateUseConstraint
constraint in the license model.
Note: This API request allows setting the maximum use time after granting the licenses. The convenience is that there’s no need for multiple license models that define different values. The customer-specific time value can be set in a customer-specific way.
License consumption by organization
GET /graph/Organization[@name='Acme Inc']/~OneToMany/Entitlement/~OneToMany/License/~OneToMany/Assignment:LicenseProfileAssignment/~OneToMany/Consumption:LicenseProfileAssignmentConsumption
Who is using an organization’s licenses
GET /graph/Organization/~OneToMany/Entitlement/~OneToMany/License/~Assignment:LicenseProfileAssignment/~ManyToOne/Profile
List an organization’s licenses with names of users
GET /graph/Organization/~OneToMany/Entitlement/~OneToMany/License?/~ManyToOne/LicensedItem&/~Assignment:LicenseProfileAssignment/Profile
Reserve a license seat
If a license uses a named-seat license model, a license seat is reserved for the user by creating a reservation assignment.
A static reservation can be also used with floating licenses to reserve a license seat for critical users.
POST /graph/
Content-Type: application/x-www-form-urlencoded
operation=CreateOrUpdateAssignments&createAssignment=true&profileId=PROFILE_ID&reservationType=reserved&licenseId=LICENSE_ID
Remove a seat reservation
If you need to change the named license seat to another user or otherwise remove a seat reservation from a user, you clear the reservation by resetting the reservation type of an assignment.
This operation doesn’t affect the existing session, that is, the seat’s lease period promised in the last license check. The user can use the same reserved seat until they release it or the lease period expires.
POST /graph/
Content-Type: application/x-www-form-urlencoded
operation=CreateOrUpdateAssignments&createAssignment=true&profileId=PROFILE_ID&reservationType=&licenseId=LICENSE_ID
Deny license consumption
License consumption can be denied from specific users by creating a denial assignment.
After denial, the user can consume the license until the end of the session, that is, the period promised in the last license check.
POST /graph/
Content-Type: application/x-www-form-urlencoded
operation=CreateOrUpdateAssignments&createAssignment=true&profileId=PROFILE_ID&reservationType=denied&licenseId=LICENSE_ID
Remove denial
To clear the denial state, that is, to allow a user to consume a floating license, the reservation type of assignment is reset (the same operation as when clearing a seat reservation).
POST /graph/
Content-Type: application/x-www-form-urlencoded
operation=CreateOrUpdateAssignments&createAssignment=true&profileId=PROFILE_ID&reservationType=&licenseId=LICENSE_ID
Release licenses
POST /authz/?AssignmentConsumptionId&release
To find out AssignmentConsumptionId:
-
If you have the client application that called the license check, you probably have the
jti
field from the token stored. Thejti
field value is the identifier of the consumption, and you can use it in the/authz/?release
call.{ "DemoItem1": true, "iss": "df585c1b-f09d-4c04-87f8-b72a515c6f3e", "exp": 1452750138, "iat": 1452690138, "ibe": 101452690135, "jti": "5e3831d6-352e-48c8-84a7-54ecc651fa0e", "rfr": 1452690738 }
-
If it’s a user or client application you don’t have access to, you can use the following call with the profile id. This reads all consumption lease identifiers that are the result of that specific user consuming the licenses. Using that result set you can iterate over it and call
/authz/?release
with each leaseId:GET /graph/Profile[@id='PROFILE_ID_HERE]/Assignment:LicenseProfileAssignment/~OneToMany/Consumption:LicenseProfileAssignmentConsumption/@leaseId