|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectcom.ibm.itim.apps.provisioning.AccountManager
public class AccountManager
Provides aggregate account management capabilities. These capabilities include the creation of accounts, the validation of accounts, and the resolution of what services are available for an individual within the provisioning platform. Before creating an account, there should be (1) a person (account owner) who will own the account, (2) a service that will host this account, and (3) a provisioning policy for the service entitiled to the account owner. Account creation and modification are tied to the system's provisioning policies in a number of ways. For example, an account is "compliant" if it conforms with a provisioning policy. If the account does not conform with a provisioning policy, then it is a "non-compliant account". If there is no provisioning policy defined for the account, then it is marked "disallowed". Depending on the compliance status of the account and the policy enforcement of an account's host service, some account operations are not allowed. For example, if the account being created is "non-compliant" and the enforcement setting for the host service is set to "Suspend" or "Correct", then the account can not be created. In such case, ApplicationException will be thrown by the createAccount method.
AccountMO
Constructor Summary | |
---|---|
AccountManager(PlatformContext platform,
javax.security.auth.Subject subject)
Constructs the manager with a platform context and a subject. |
Method Summary | |
---|---|
void |
adopt(DistinguishedName ownerDN,
java.util.Collection accounts)
Adopts multiple accounts, or assigns the same owner (given) to all the accounts submitted. |
void |
adopt(DistinguishedName ownerDN,
java.lang.String ownershipType,
java.util.Collection accounts)
Adopts multiple accounts, or assigns the same owner (given) to all the accounts submitted. |
Compliance |
checkAccountCompliance(PersonMO owner,
ServiceMO service,
AttributeValues params)
Checks the account compliance on the given service with the given parameters for the given owner. |
Compliance |
checkAccountCompliance(PersonMO owner,
ServiceMO service,
java.lang.String ownershipType,
AttributeValues params)
This method checks the account compliance on the service with the parameters for the owner. |
Request |
createAccount(PersonMO owner,
ServiceMO service,
Account subject,
java.util.Date scheduledTime)
Creates an account in the provisioning platform with the specified attributes for the given person. |
Request |
createAccount(PersonMO owner,
ServiceMO service,
java.lang.String ownershipType,
Account subject,
java.util.Date scheduledTime)
This method creates an account in the provisioning platform with the specified attributes for the given person. |
AccountMO |
getAccountByURI(OrganizationalContainerMO container,
java.lang.String uri)
Returns the account for the given Uniform Resource Identifier (URI) within the specified parent container. |
AttributeValues |
getAccountParameters(PersonMO owner,
ServiceMO service)
Returns the auto-generated parameters used to define the potential owner's individual account on the given service. |
AttributeValues |
getAccountParameters(PersonMO owner,
ServiceMO service,
java.lang.String ownershipType)
Returns the auto-generated parameters used to define the potential owner's account of the specified ownership type on the given service. |
java.util.Collection |
getAccounts(PersonMO person,
java.util.Locale locale)
Returns the account(s) for the given person. |
java.util.Collection |
getAccounts(PersonMO person,
java.lang.String ownershipType,
java.util.Locale locale)
Returns the accounts for the person. |
java.util.Collection |
getAccounts(ServiceMO service,
java.lang.String uid)
Returns the account(s) with the uid hosted on the given service. |
java.util.Collection |
getAccounts(ServiceMO service,
java.lang.String attributeName,
java.lang.Object attributeValue)
Returns the account(s) matching the given attribute hosted on the given service. |
void |
getAccounts(ServiceMO service,
java.lang.String attributeName,
java.lang.Object attributeValue,
SearchResultsMO results)
Returns the account(s) matching the given attribute hosted on the given service. |
java.util.Collection |
getAuthorizedOwnershipTypes(ServiceMO service,
PersonMO person)
Returns the authorized ownership types for the person on the given service |
java.util.Collection |
getAuthorizedServices(PersonMO subject,
java.util.Locale locale)
Returns the services the given person is authorized to have access to. |
java.util.Collection |
getAuthorizedServices(PersonMO subject,
java.util.Locale locale,
java.lang.String pattern,
java.lang.String type)
Returns the services the given person is authorized to have access to. |
java.util.Map<Account,java.util.Collection<java.lang.String>> |
getMandatoryGroupNames(java.util.Collection<Account> accounts)
Provides the names of the mandatory groups for the given accounts. |
void |
getNonCompliantAccounts(SearchResultsMO results)
Returns all accounts that are currently tracked as non-compliant by the provisioning system through the results parameter. |
void |
getNonCompliantAccounts(ServiceMO service,
SearchResultsMO results)
Returns all accounts on the given service that are currently tracked as non-compliant by the provisioning system through the results parameter. |
java.util.Collection<Account> |
getRequiredAccounts(PersonMO owner,
java.util.Collection<Account> accounts)
Determines which of the given accounts are required by provisioning policy for the specified account owner. |
boolean |
isAccountCompliant(AccountMO subject,
java.util.Collection errors)
Deprecated. Please use checkAccountCompliance method. |
boolean |
isAccountCompliant(PersonMO owner,
ServiceMO service,
AttributeValues params,
java.util.Collection errors)
Deprecated. Please use checkAccountCompliance method. |
void |
orphan(DistinguishedName userDN,
java.util.Collection accounts)
Orphans multiple accounts, or changes the account owner to unknown. |
void |
recertifyAccessOverride(java.util.Collection<com.ibm.itim.apps.provisioning.access.UserAccess> accesses,
java.lang.String justification)
Recertifies the given accesses by immediately overriding their recertification status. |
void |
recertifyOverride(java.util.Collection accounts,
java.lang.String justification)
Audits the collection of accounts passed in. |
Request |
remove(java.util.Collection accounts,
java.util.Date scheduledTime)
Removes multiple accounts from the provisioning platform. |
Request |
restore(java.util.Collection accounts,
java.util.Date scheduledTime)
Restores multiple accounts. |
Request |
restore(java.util.Collection accounts,
java.lang.String password,
java.util.Date scheduledTime)
Restores multiple accounts with the password specified. |
Request |
submitAdoptionRequest(DistinguishedName ownerDN,
java.lang.String ownershipType,
java.util.Collection accounts)
Adopts multiple accounts, or assigns the same owner (given) to all the accounts submitted. |
Request |
suspend(java.util.Collection accounts,
java.util.Date scheduledTime)
Suspends multiple accounts. |
Methods inherited from class java.lang.Object |
---|
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public AccountManager(PlatformContext platform, javax.security.auth.Subject subject)
platform
- PlatformContext holding platform connection information.subject
- Subject representing the authenticated caller.Method Detail |
---|
public Request createAccount(PersonMO owner, ServiceMO service, Account subject, java.util.Date scheduledTime) throws java.rmi.RemoteException, AuthorizationException, SchemaViolationException, ApplicationException
owner
- PersonMO who will own the account. If owner is null than an
IllegalArgumentException will be thrown.service
- ServiceMO the account will be provisioned on. If service is
null than an IllegalArgumentException will be thrown.subject
- Account value object defining the attributes the account will
have.scheduledTime
- The scheduled starting time of the process. If null, the
process will start immediately. In case this method is invoked
remotely, passing this parameter as the current date/time of
the client machine is not a safe technique to use, since the
date/time of the client machine may not be the same as the
date/time of the ITIM server machine.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to create an account for
the given person or the client is unauthorized to write
any of account attributes.
SchemaViolationException
- Thrown if any of the attributes in the value object
violates the managed object's schema. This may be caused
by an invalid attribute or if a required attribute is
missing entirely.
ApplicationException
- Thrown if unable to submit the request. This may possibly
be caused by 1. If the owner is removed by another client
previous to this call. 2. If the password is not valid.
(The actual exception will be the instance of
InvalidPasswordException.) 3. If the account being created
is non-compliant (or unauthorized) and the enforcement
setting of the hosting service is set to "Suspend" or
"Correct".public Request createAccount(PersonMO owner, ServiceMO service, java.lang.String ownershipType, Account subject, java.util.Date scheduledTime) throws java.rmi.RemoteException, AuthorizationException, SchemaViolationException, ApplicationException
owner
- PersonMO Specifies who owns the account. If the owner is null, an
IllegalArgumentException is thrown.service
- ServiceMO Specifies the service that the account is provisioned on. If the service is
null, an IllegalArgumentException is thrown.ownershipType
- Specifies the ownership type for the account.
These following values are already defined:
subject
- Specifies the account value object that defines the attributes that the account has.scheduledTime
- Specifies the scheduled starting time of the process. If null, the
process starts immediately. If this method is invoked
remotely, do not pass this parameter as the current date/time or time of
the client machine. The date or time of the client machine may not be the same as the
date or time of the IBM Security Identity Server server machine.
java.rmi.RemoteException
- if call to a remote method cannot be executed.
AuthorizationException
- Thrown if the client is unauthorized to create an account for
the given person or if the client is unauthorized to write
any of the account attributes.
SchemaViolationException
- Thrown if any of the attributes in the value object
violates the schema of the managed object. This exception might be caused
by an incorrect attribute or a missing required attribute.
ApplicationException
- Thrown the system is unable to submit the request. This error might be caused
InvalidPasswordException
.RemoteException
public java.util.Collection getAuthorizedOwnershipTypes(ServiceMO service, PersonMO person) throws java.rmi.RemoteException, ApplicationException
service
- ServiceMO representing the service.person
- PersonMO representing the person.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the
authorized ownership types. This error might
be caused by the service or the person being removed
by another client previous to this call.
This error might also be caused by a failure in
processing policies to obtain the authorized ownership types.
java.lang.IllegalArgumentException
- Thrown if the service or person parameter is null.public java.util.Collection getAuthorizedServices(PersonMO subject, java.util.Locale locale) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
subject
- PersonMO representing the person in question.locale
- optional Locale used to sort the results by
Service name. If null, Locale.getDefault() (server JVM)
is used.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
view (search) the subject person.
ApplicationException
- Thrown if unable to obtain the
authorized services. This may possibly
be caused by the subject being removed
by another client previous to this call.
This may be also caused by a fault in
processing policies in order to
obtain the authorized services.
java.lang.IllegalArgumentException
- Thrown if the subject is null.public java.util.Collection getAuthorizedServices(PersonMO subject, java.util.Locale locale, java.lang.String pattern, java.lang.String type) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
subject
- PersonMO representing the person in question.locale
- optional Locale used to sort the results by
Service name. If null, Locale.getDefault() (server JVM)
is used.pattern
- String pattern that must be present in the Service name or
Service description for a match to occur, indicating possible
matches for services. If pattern is "*", implies all authorized
services based on Service Profile type will be returned.type
- Service Profile name of the authorized services to be searched.
If null, all types of services, the person has access to, are returned.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
view (search) the subject person.
ApplicationException
- Thrown if unable to obtain the
authorized services. This may possibly
be caused by the subject being removed
by another client previous to this call.
This may be also caused by a fault in
processing policies in order to
obtain the authorized services.
java.lang.IllegalArgumentException
- Thrown if the subject is null.public AttributeValues getAccountParameters(PersonMO owner, ServiceMO service) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
owner
- PersonMO representing the person in question. If owner is null
an IllegalArgumentException will be thrown.service
- ServiceMO representing the service in question. If service is
null an IllegalArgumentException will be thrown.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to view (search) the
subject person, accounts of this type, and/or service.
ApplicationException
- Thrown if unable to generate the parameters. This may
possibly be caused by the owner or service being removed
by another client previous to this call. This may be also
caused by a fault in processing policies in order to
generate the parameters or there is no policy defined for
the owner and service.public AttributeValues getAccountParameters(PersonMO owner, ServiceMO service, java.lang.String ownershipType) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
owner
- PersonMO representing the person in question. If owner is null
an IllegalArgumentException will be thrown.service
- ServiceMO representing the service in question. If service is
null an IllegalArgumentException will be thrown.ownershipType
- Valid ownership type configured at system level
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to view (search) the
subject person, accounts of this type, and/or service.
ApplicationException
- Thrown if unable to generate the parameters. This may
possibly be caused by the owner or service being removed
by another client previous to this call. This may be also
caused by a fault in processing policies in order to
generate the parameters or there is no policy defined for
the owner and service.public void getNonCompliantAccounts(SearchResultsMO results) throws java.rmi.RemoteException, ApplicationException
results
- SearchResultsMO to hold the results of the search.
The SearchResultsMO is used to support the paging and sorting
for the presentation layer. The
object will be filled with Account value objects that
represent non-compliant accounts. Note, if the
SearchResultsMO object was constructed using a different
user context, that context will be changed to match the
context of this object.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to retrieve the accounts.
This may be also caused by a fault in data services area.
java.lang.IllegalArgumentException
- Thrown if the results is null.SearchResultsMO
public void getNonCompliantAccounts(ServiceMO service, SearchResultsMO results) throws java.rmi.RemoteException, ApplicationException
service
- ServiceMO constraining the search.results
- SearchResultsMO to hold the results of the search.
The SearchResultsMO is used to support the paging and sorting
for the presentation layer. The
object will be filled with Account value objects that
represent non-compliant accounts. Note, if the
SearchResultsMO object was constructed using a different
user context, that context will be changed to match the
context of this object.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to retrieve the accounts.
java.lang.IllegalArgumentException
- Thrown if the service or the results is null.SearchResultsMO
public boolean isAccountCompliant(AccountMO subject, java.util.Collection errors) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
subject
- AccountMO representing the account in question.errors
- If non-null, will be filled with detected errors. The
errors are represented as Strings.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
view (search) the subject account.
ApplicationException
- Thrown if unable to generate the
parameters. This may possibly be caused
by the account being removed
by another client previous to this call.
This may be also caused by a fault in
processing policies in order to
evaluate compliance.checkAccountCompliance(PersonMO, ServiceMO, AttributeValues)
public boolean isAccountCompliant(PersonMO owner, ServiceMO service, AttributeValues params, java.util.Collection errors) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
owner
- PersonMO representing the person in question.service
- ServiceMO representing the service in question.params
- AttributeValues holding the parameters of the (potential)
account.errors
- If non-null, will be filled with detected errors. The
errors are represented as Strings.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
view (search) the subject person
and/or service.
ApplicationException
- Thrown if unable to generate the
parameters. This may possibly be caused
by the owner and/or service being removed
by another client previous to this call.
This may be also caused by a fault in
processing policies in order to
evaluate compliance.checkAccountCompliance(PersonMO, ServiceMO, AttributeValues)
public Compliance checkAccountCompliance(PersonMO owner, ServiceMO service, AttributeValues params) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
owner
- PersonMO representing the person in question. If owner is null
an IllegalArgumentException will be thrown.service
- ServiceMO representing the service in question.If service is
null an IllegalArgumentException will be thrown.params
- AttributeValues holding the parameters of the (potential)
account.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to view (search) the
subject person and/or service.
ApplicationException
- Thrown if unable to check the account compliance. This may
possibly be caused by (1) the owner and/or service being
removed by another client previous to this call, or (2)an
error in processing policies in order to evaluate
compliance.Compliance
public Compliance checkAccountCompliance(PersonMO owner, ServiceMO service, java.lang.String ownershipType, AttributeValues params) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
owner
- PersonMO Specifies the person being evaluated. If the owner is null,
an IllegalArgumentException is thrown.service
- ServiceMO Specifies the service being evaluated. If the service is
null, an IllegalArgumentException is thrown.ownershipType
- Specifies the ownership type of the account. If the value is specified,
the ownership type attribute in the attribute list is overwritten.
These following values are already defined:
params
- Holds the attribute values of the (potential)
account.
Compliance
object has the compliance status and the
required AttributeChanges
),
if the account is not compliant.
java.rmi.RemoteException
- if call to a remote method cannot be executed.
AuthorizationException
- Thrown if the client is unauthorized to view or search
the subject person or service.
ApplicationException
- Thrown the system is unable to check the account compliance.
This error might be caused:
Compliance
,
RemoteException
public java.util.Collection getAccounts(PersonMO person, java.util.Locale locale) throws java.rmi.RemoteException, ApplicationException
person
- PersonMO representing the person to scope the search.locale
- optional Locale used to do a locale-sensitive sort
of the results by user id. If null, Locale.getDefault()
is used (server JVM).
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the
accounts. This may possibly
be caused by the service being removed
by another client previous to this call.
java.lang.IllegalArgumentException
- Thrown if the person is null.public java.util.Collection getAccounts(PersonMO person, java.lang.String ownershipType, java.util.Locale locale) throws java.rmi.RemoteException, ApplicationException
AuthorizationException
is thrown.
person
- PersonMO Specifies the person that is the scope of the search.ownershipType
- Specifies the ownership type of the account.
These following values are already defined:
locale
- Specifies to perform a locale-sensitive sort
of the results found for the specified person and ownership type.
If null is specified, java.util.Locale.getDefault()
is used (server JVM).
AccountMO
that contains the matching accounts.
java.rmi.RemoteException
- if call to a remote method cannot be executed.
ApplicationException
- if a list of account cannot be obtained.
This error might be caused if another client removes the person
before this call.
java.lang.IllegalArgumentException
- if the person is null.RemoteException
public java.util.Collection getAccounts(ServiceMO service, java.lang.String uid) throws java.rmi.RemoteException, ApplicationException
service
- ServiceMO representing the service to scope the search.uid
- User id of the account to retrieve.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the
accounts. This may possibly
be caused by the service being removed
by another client previous to this call.
java.lang.IllegalArgumentException
- Thrown if the service is null.public java.util.Collection getAccounts(ServiceMO service, java.lang.String attributeName, java.lang.Object attributeValue) throws java.rmi.RemoteException, ApplicationException
service
- ServiceMO representing the service to scope the search.attributeName
- Name of attribute to match with.attributeValue
- Value of the attribute to match with. A * can be
used as the first and/or last character of a
String value if a "contains" expression is wished.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the
accounts. This may possibly
be caused by the service being removed
by another client previous to this call.
java.lang.IllegalArgumentException
- Thrown if the service is null.public void getAccounts(ServiceMO service, java.lang.String attributeName, java.lang.Object attributeValue, SearchResultsMO results) throws java.rmi.RemoteException, ApplicationException
service
- ServiceMO representing the service to scope the search.attributeName
- Name of attribute to match with.attributeValue
- Value of the attribute to match with. A * can be
used as the first and/or last character of a
String value if a "contains" expression is wished.results
- SearchResultsMO to hold the results of the search. The
object will be filled with Account value objects that
match the given criteria. Note, if the SearchResultsMO
object was constructed using a different user context,
that context will be changed to match the context of this
object.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the
accounts. This may possibly
be caused by the service being removed
by another client previous to this call.
java.lang.IllegalArgumentException
- Thrown if the service is null.public AccountMO getAccountByURI(OrganizationalContainerMO container, java.lang.String uri) throws java.rmi.RemoteException, ApplicationException
container
- OrganizationalContainerMO representing the parent container to
scope the search.uri
- String representing the account URI.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
ApplicationException
- Thrown if unable to obtain the account. This might
be caused by the container being removed by
another client previous to this call. This exception might also be thrown
if the container object is null or represents the tenant,
no account is found for the given URI within the container,
or more than one account is found for the given URI
within the container.public void adopt(DistinguishedName ownerDN, java.util.Collection accounts) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
ownerDN
- DistinguishedName of the new account owner.accounts
- Collection of Account DirectoryObject to assign
an owner to.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
modify any of the account or owner attribute of the account.
ApplicationException
- Thrown if unable to adopt any of the accounts.
This may possibly be caused by
the account or owner being removed by
another client previous to this call.
Also thrown if the account is disallowed and the hosting
service's enforcement action is set to "Correct".
java.lang.IllegalArgumentException
- Thrown if the ownerDN is null.
Also thrown if the accounts is null or the empty collection.public void adopt(DistinguishedName ownerDN, java.lang.String ownershipType, java.util.Collection accounts) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
ownerDN
- Specifies the DistinguishedName
of the new account owner.ownershipType
- The new ownership type for the adopted account.
These following values are already defined:
accounts
- Collection of Account
objects that
an owner is assigned to.
java.rmi.RemoteException
- if call to a remote method cannot be executed.
AuthorizationException
- if the client is unauthorized to
modify any of the account or owner attribute of the account.
ApplicationException
- if the account cannot be adopted.
This error might be caused if another
client removes the account or owner before this call.
This exception is also thrown if the account is disallowed and the hosting enforcement action of the service is set to "Correct".
java.lang.IllegalArgumentException
- if the ownerDN parameter is null.
This exception is also thrown if the list of accounts is empty or null.
RemoteException
public void orphan(DistinguishedName userDN, java.util.Collection accounts) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
userDN
- DistinguishedName identifies an
authenticated SystemUser.accounts
- Collection of Account DirectoryObjects to orphan.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
orphan any of the accounts.
ApplicationException
- Thrown if unable to orphan the accounts.
This may possibly be caused by
(1) the account being removed by another client previous to
this call, (2) the one of account is an ITIM account.public Request suspend(java.util.Collection accounts, java.util.Date scheduledTime) throws java.rmi.RemoteException, ApplicationException, AuthorizationException
accounts
- Collection of Account DirectoryObjects to suspend.scheduledTime
- The scheduled starting time of the process.
If null, the process will start immediately.
In case this method is invoked remotely, passing this parameter as the current
date/time of the client machine is not a safe technique to use, since the
date/time of the client machine may not be the same as the date/time of the
ITIM server machine.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
suspend any of the accounts.
ApplicationException
- Thrown if unable to submit the request.public Request restore(java.util.Collection accounts, java.util.Date scheduledTime) throws java.rmi.RemoteException, ApplicationException, AuthorizationException
accounts
- Collection of Account DirectoryObjects to restore.scheduledTime
- The scheduled starting time of the process.
If null, the process will start immediately.
In case this method is invoked remotely, passing this parameter as the current
date/time of the client machine is not a safe technique to use, since the
date/time of the client machine may not be the same as the date/time of the
ITIM server machine.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
restore any of the accounts.
ApplicationException
- Thrown if unable to submit the request.
Also thrown if one of accounts is disallowed or non-compliant
and the enforcement action of hosting service is set to
"Suspend" or "Correct".public Request restore(java.util.Collection accounts, java.lang.String password, java.util.Date scheduledTime) throws java.rmi.RemoteException, ApplicationException, AuthorizationException
accounts
- Collection of Account
objects to restore.password
- Password to be used to restore the accounts under the following conditions:
ServiceMO
for details.
scheduledTime
- The scheduled starting time of the process.
If null, the process will start immediately.
In case this method is invoked remotely, passing
this parameter as the current data/time of the
client machine is not a safe technique to use,
since the date/time of the client machine may not be
the same as the date/time of the ITIM server
machine.
java.rmi.RemoteException
- Thrown if there is a communication failure.
AuthorizationException
- Thrown if client is unauthorized to
restore any of the accounts.
ApplicationException
- Thrown if business rules are violated,
while performing requested operation,
for example when any one of the accounts
in the collection is an orphan account. This
exception may be thrown if any account
in the collection is a non-compliant or
disallowed account governed by a service with
policy enforcement set to "Suspend" or "Correct".public Request remove(java.util.Collection accounts, java.util.Date scheduledTime) throws java.rmi.RemoteException, ApplicationException, AuthorizationException
accounts
- Collection of Account DirectoryObjects to remove.scheduledTime
- The scheduled starting time of the process.
If null, the process will start immediately.
In case this method is invoked remotely, passing this parameter as the current
date/time of the client machine is not a safe technique to use, since the
date/time of the client machine may not be the same as the date/time of the
ITIM server machine.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
remove any of the accounts.
ApplicationException
- Thrown if unable to submit the request.
This may caused by (1) if the account was already removed
by another client prevous to this call, or
(2) if the accounts being removed are required by the
automatic provisioning policy.public void recertifyOverride(java.util.Collection accounts, java.lang.String justification) throws ApplicationException, java.rmi.RemoteException
accounts
- A collection of Account objects to audit for recertification.justification
- The comments provided by the requester while recertifying the
accounts.
ApplicationException,
- RemoteException An exception will be thrown on any failure.
ApplicationException
java.rmi.RemoteException
public void recertifyAccessOverride(java.util.Collection<com.ibm.itim.apps.provisioning.access.UserAccess> accesses, java.lang.String justification) throws ApplicationException, java.rmi.RemoteException
accesses
- A collection of UserAccess objects to audit for recertification.justification
- The comments provided by the requester while recertifying the
accesses.
ApplicationException
- Thrown if unable to set the recertification
status of an access.
java.rmi.RemoteException
- An exception will be thrown on any failure.public java.util.Collection<Account> getRequiredAccounts(PersonMO owner, java.util.Collection<Account> accounts) throws ApplicationException, java.rmi.RemoteException
owner
- owner of the given accounts. An IllegalArgumentException
is thrown if this paramter is null.accounts
- accounts owned by specified owner. An
IllegalArgumentException
is thrown if this parameter is null.
ApplicationException
- if the specified owner is not the account
owner of all of the given accounts, or if
an error occurs while checking policy or
communicating with the datastore.
java.rmi.RemoteException
- if unable to communicate with the platform.public java.util.Map<Account,java.util.Collection<java.lang.String>> getMandatoryGroupNames(java.util.Collection<Account> accounts) throws ApplicationException, java.rmi.RemoteException
SystemUser
accounts, the group names represent
SystemRole
distinguished names.
accounts
- accounts whose mandatory groups to determine. An
IllegalArgumentException
is thrown if this
paramter is null.
ApplicationException
- if an error occurs while checking policy
or retrieving profile information.
java.rmi.RemoteException
- if unable to communicate with the platform.public Request submitAdoptionRequest(DistinguishedName ownerDN, java.lang.String ownershipType, java.util.Collection accounts) throws java.rmi.RemoteException, AuthorizationException, ApplicationException
ownerDN
- DistinguishedName of the new account owner.accounts
- Collection of Account DirectoryObject to assign
an owner to.
java.rmi.RemoteException
- Thrown if unable to communicate with platform.
AuthorizationException
- Thrown if client is unauthorized to
modify any of the account or owner attribute of the account.
ApplicationException
- Thrown if unable to adopt any of the accounts.
This may possibly be caused by
the account or owner being removed by
another client previous to this call.
Also thrown if the account is disallowed and the hosting
service's enforcement action is set to "Correct".
java.lang.IllegalArgumentException
- Thrown if the ownerDN is null.
Also thrown if the accounts is null or the empty collection.
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |