Interface CategoryBusinessAssignmentSession
- All Superinterfaces:
AutoCloseable, Closeable, OsidSession, OsidSession
This session provides methods to re-assign Categories to
Businesses . A Category may appear in multiple Businesses
and removing the last reference to a Category is the equivalent of
deleting it. Each Business may have its own authorizations
governing who is allowed to operate on it.
Adding a reference of a Category to another Business
is not a copy operation (eg: does not change its Id ).
-
Method Summary
Modifier and TypeMethodDescriptionvoidassignCategoryToBusiness(Id categoryId, Id businessId) Adds an existingCategoryto aBusiness.booleanTests if this user can alter category/business mappings.booleancanAssignCategoryToBusiness(Id businessId) Tests if this user can alter category/business mappings.getAssignableBusinessIds(Id businessId) Gets a list of businesses including and under the given business node in which any category can be assigned.getAssignableBusinessIdsForCategory(Id businessId, Id categoryId) Gets a list of businesses including and under the given business node in which a specific category can be assigned.voidreassignCategoryToBusiness(Id categoryId, Id fromBusinessId, Id toBusinessId) Moves aCategoryfrom oneBusinessto another.voidunassignCategoryFromBusiness(Id categoryId, Id businessId) Removes aCategoryfrom aBusiness.Methods inherited from interface OsidSession
closeMethods inherited from interface OsidSession
getAuthenticatedAgent, getAuthenticatedAgentId, getClockRate, getDate, getEffectiveAgent, getEffectiveAgentId, getFormatType, getLocale, isAuthenticated, startTransaction, supportsTransactionsModifier and TypeMethodDescriptionGets the agent authenticated to this session.Gets theIdof the agent authenticated to this session.Gets the rate of the service clock.getDate()Gets the service date which may be the current date or the effective date in which this session exists.Gets the effective agent in use by this session.Gets theIdof the effective agent in use by this session.Gets theDisplayTextformatTypepreference in effect for this session.Gets the locale indicating the localization preferences in effect for this session.booleanTests if an agent is authenticated to this session.Starts a new transaction for this sesson.booleanTests for the availability of transactions.
-
Method Details
-
canAssignCategories
boolean canAssignCategories()Tests if this user can alter category/business mappings. A return of true does not guarantee successful authorization. A return of false indicates that it is known mapping methods in this session will result in aPERMISSION_DENIED. This is intended as a hint to an application that may opt not to offer assignment operations to unauthorized users.- Returns:
falseif mapping is not authorized,trueotherwise- Compliance:
mandatory- This method must be implemented.
-
canAssignCategoryToBusiness
Tests if this user can alter category/business mappings. A return of true does not guarantee successful authorization. A return of false indicates that it is known mapping methods in this session will result in aPERMISSION_DENIED. This is intended as a hint to an application that may opt not to offer lookup operations to unauthorized users.- Parameters:
businessId- theIdof theBusiness- Returns:
falseif mapping is not authorized,trueotherwise- Throws:
NullArgumentException-businessIdisnull- Compliance:
mandatory- This method must be implemented.
-
getAssignableBusinessIds
Gets a list of businesses including and under the given business node in which any category can be assigned.- Parameters:
businessId- theIdof theBusiness- Returns:
- list of assignable business
Ids - Throws:
NullArgumentException-businessIdisnullOperationFailedException- unable to complete request- Compliance:
mandatory- This method must be implemented.
-
getAssignableBusinessIdsForCategory
IdList getAssignableBusinessIdsForCategory(Id businessId, Id categoryId) throws OperationFailedException Gets a list of businesses including and under the given business node in which a specific category can be assigned.- Parameters:
businessId- theIdof theBusinesscategoryId- theIdof theCategory- Returns:
- list of assignable business
Ids - Throws:
NullArgumentException-businessIdorcategoryIdisnullOperationFailedException- unable to complete request- Compliance:
mandatory- This method must be implemented.
-
assignCategoryToBusiness
void assignCategoryToBusiness(Id categoryId, Id businessId) throws AlreadyExistsException, NotFoundException, OperationFailedException, PermissionDeniedException Adds an existingCategoryto aBusiness.- Parameters:
categoryId- theIdof theCategorybusinessId- theIdof theBusiness- Throws:
AlreadyExistsException-categoryIdis already assigned tobusinessIdNotFoundException-categoryIdorbusinessIdnot foundNullArgumentException-categoryIdorbusinessIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
unassignCategoryFromBusiness
void unassignCategoryFromBusiness(Id categoryId, Id businessId) throws NotFoundException, OperationFailedException, PermissionDeniedException Removes aCategoryfrom aBusiness.- Parameters:
categoryId- theIdof theCategorybusinessId- theIdof theBusiness- Throws:
NotFoundException-categoryIdorbusinessIdnot found orcategoryIdnot assigned tobusinessIdNullArgumentException-categoryIdorbusinessIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-
reassignCategoryToBusiness
void reassignCategoryToBusiness(Id categoryId, Id fromBusinessId, Id toBusinessId) throws AlreadyExistsException, NotFoundException, OperationFailedException, PermissionDeniedException Moves aCategoryfrom oneBusinessto another. Mappings to otherBusinessesare unaffected.- Parameters:
categoryId- theIdof theCategoryfromBusinessId- theIdof the currentBusinesstoBusinessId- theIdof the destinationBusiness- Throws:
AlreadyExistsException-categoryIdalready assigned totoBusinessIdNotFoundException-categoryId, fromBusinessId, ortoBusinessIdnot found orcategoryIdnot mapped tofromBusinessIdNullArgumentException-categoryId, fromBusinessId, ortoBusinessIdisnullOperationFailedException- unable to complete requestPermissionDeniedException- authorization failure- Compliance:
mandatory- This method must be implemented.
-