gluu
公開メンバ関数 | 静的公開メンバ関数 | 静的公開変数類 | 限定公開メンバ関数 | 関数 | 変数 | 非公開変数類 | 全メンバ一覧
org.gluu.oxtrust.ws.rs.scim2.UserWebService クラス
org.gluu.oxtrust.ws.rs.scim2.UserWebService の継承関係図
Inheritance graph
org.gluu.oxtrust.ws.rs.scim2.UserWebService 連携図
Collaboration graph

公開メンバ関数

Response createUser ( @ApiParam(value="User", required=true) UserResource user, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response getUserById ( @PathParam("id") String id, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response updateUser ( @ApiParam(value="User", required=true) UserResource user, @PathParam("id") String id, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response deleteUser (@PathParam("id") String id)
 
Response searchUsers ( @QueryParam(QUERY_PARAM_FILTER) String filter, @QueryParam(QUERY_PARAM_START_INDEX) Integer startIndex, @QueryParam(QUERY_PARAM_COUNT) Integer count, @QueryParam(QUERY_PARAM_SORT_BY) String sortBy, @QueryParam(QUERY_PARAM_SORT_ORDER) String sortOrder, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response searchUsersPost (@ApiParam(value="SearchRequest", required=true) SearchRequest searchRequest)
 
Response patchUser (PatchRequest request, @PathParam("id") String id, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
void setup ()
 
String getEndpointUrl ()
 
Response createUser (UserResource user, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response updateUser (UserResource user, @PathParam("id") String id, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
 
Response searchUsersPost (SearchRequest searchRequest)
 

静的公開メンバ関数

static Response getErrorResponse (Response.Status status, String detail)
 
static Response getErrorResponse (Response.Status status, ErrorScimType scimType, String detail)
 
static Response getErrorResponse (int statusCode, ErrorScimType scimType, String detail)
 

静的公開変数類

static final String SEARCH_SUFFIX = ".search"
 

限定公開メンバ関数

void assignMetaInformation (BaseScimResource resource)
 
void executeDefaultValidation (BaseScimResource resource) throws SCIMException
 
void executeValidation (BaseScimResource resource, boolean skipRequired) throws SCIMException
 
Response prepareSearchRequest (List< String > schemas, String filter, String sortBy, String sortOrder, Integer startIndex, Integer count, String attrsList, String excludedAttrsList, SearchRequest request)
 
Response inspectPatchRequest (PatchRequest patch, Class<? extends BaseScimResource > cls)
 

関数

int getMaxCount ()
 
String getValueFromHeaders (HttpHeaders headers, String name)
 
String translateSortByAttribute (Class<? extends BaseScimResource > cls, String sortBy)
 
String getListResponseSerialized (int total, int startIndex, List< BaseScimResource > resources, String attrsList, String excludedAttrsList, boolean ignoreResults) throws IOException
 

変数

Logger log
 
AppConfiguration appConfiguration
 
ScimResourceSerializer resourceSerializer
 
ExtensionService extService
 
String endpointUrl
 

非公開変数類

IPersonService personService
 
Scim2UserService scim2UserService
 
Scim2PatchService scim2PatchService
 

詳解

Implementation of /Users endpoint. Methods here are intercepted and/or decorated. Class org.gluu.oxtrust.service.scim2.interceptor.UserWebServiceDecorator is used to apply pre-validations on data. Filter org.gluu.oxtrust.filter.AuthorizationProcessingFilter secures invocations

著者
Rahat Ali Date: 05.08.2015 Updated by jgomer on 2017-09-12.

関数詳解

◆ assignMetaInformation()

void org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.assignMetaInformation ( BaseScimResource  resource)
inlineprotectedinherited
102  {
103 
104  //Generate some meta information (this replaces the info client passed in the request)
105  long now=new Date().getTime();
106  String val= ISODateTimeFormat.dateTime().withZoneUTC().print(now);
107 
108  Meta meta=new Meta();
109  meta.setResourceType(ScimResourceUtil.getType(resource.getClass()));
110  meta.setCreated(val);
111  meta.setLastModified(val);
112  //For version attritute: Service provider support for this attribute is optional and subject to the service provider's support for versioning
113  //For location attribute: this will be set after current user creation in LDAP
114  resource.setMeta(meta);
115 
116  }

◆ createUser() [1/2]

Response org.gluu.oxtrust.ws.rs.scim2.IUserWebService.createUser ( UserResource  user,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inherited

Service method that allows creating a User resource via POST (as per section 3.3 of RFC 7644).

引数
userAn object that represents the User to create
attrsListSee notes about attributes query param
excludedAttrsListSee notes about excludedAttributes query param
戻り値
An object abstracting the response obtained from the server to this request. A succesful response for this operation should contain a status code of 201 (created) and a UserResource in the entity body (the resource just created)

◆ createUser() [2/2]

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.createUser ( @ApiParam(value="User", required=true) UserResource  user,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inline
99  {
100 
101  Response response;
102  try {
103  log.debug("Executing web service method. createUser");
105  String json=resourceSerializer.serialize(user, attrsList, excludedAttrsList);
106  response=Response.created(new URI(user.getMeta().getLocation())).entity(json).build();
107  }
108  catch (Exception e){
109  log.error("Failure at createUser method", e);
110  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
111  }
112  return response;
113 
114  }
ScimResourceSerializer resourceSerializer
Definition: BaseScimWebService.java:62
String serialize(BaseScimResource resource, String attributes, String exclusions)
Definition: ScimResourceSerializer.java:203
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
void createUser(UserResource user, String url)
Definition: Scim2UserService.java:419
Scim2UserService scim2UserService
Definition: UserWebService.java:81

◆ deleteUser()

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.deleteUser ( @PathParam("id") String  id)
inline

org.gluu.oxtrust.ws.rs.scim2.IUserWebServiceを実装しています。

192  {
193 
194  Response response;
195  try {
196  log.debug("Executing web service method. deleteUser");
197  GluuCustomPerson person=personService.getPersonByInum(id); //person cannot be null (check associated decorator method)
199  response=Response.noContent().build();
200  }
201  catch (Exception e){
202  log.error("Failure at deleteUser method", e);
203  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
204  }
205  return response;
206 
207  }
Logger log
Definition: BaseScimWebService.java:56
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
abstract GluuCustomPerson getPersonByInum(String inum)
IPersonService personService
Definition: UserWebService.java:78
void deleteUser(GluuCustomPerson gluuPerson)
Definition: Scim2UserService.java:497
Scim2UserService scim2UserService
Definition: UserWebService.java:81

◆ executeDefaultValidation()

void org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.executeDefaultValidation ( BaseScimResource  resource) throws SCIMException
inlineprotectedinherited
118  {
119  executeValidation(resource, false);
120  }
void executeValidation(BaseScimResource resource, boolean skipRequired)
Definition: BaseScimWebService.java:122

◆ executeValidation()

void org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.executeValidation ( BaseScimResource  resource,
boolean  skipRequired 
) throws SCIMException
inlineprotectedinherited
122  {
123 
124  ResourceValidator rv=new ResourceValidator(resource, extService.getResourceExtensions(resource.getClass()));
125  if (!skipRequired){
126  rv.validateRequiredAttributes();
127  rv.validateSchemasAttribute();
128  }
129  rv.validateValidableAttributes();
130  //By section 7 of RFC 7643, we are not forced to constrain attribute values when they have a list of canonical values associated
131  //rv.validateCanonicalizedAttributes();
132  rv.validateExtendedAttributes();
133 
134  }
List< Extension > getResourceExtensions(Class<? extends BaseScimResource > cls)
Definition: ExtensionService.java:46
ExtensionService extService
Definition: BaseScimWebService.java:65

◆ getEndpointUrl()

String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getEndpointUrl ( )
inlineinherited
71  {
72  return endpointUrl;
73  }
String endpointUrl
Definition: BaseScimWebService.java:69

◆ getErrorResponse() [1/3]

static Response org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getErrorResponse ( Response.Status  status,
String  detail 
)
inlinestaticinherited
75  {
76  return getErrorResponse(status.getStatusCode(), null, detail);
77  }
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75

◆ getErrorResponse() [2/3]

static Response org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getErrorResponse ( Response.Status  status,
ErrorScimType  scimType,
String  detail 
)
inlinestaticinherited
79  {
80  return getErrorResponse(status.getStatusCode(), scimType, detail);
81  }
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75

◆ getErrorResponse() [3/3]

static Response org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getErrorResponse ( int  statusCode,
ErrorScimType  scimType,
String  detail 
)
inlinestaticinherited
83  {
84 
85  ErrorResponse errorResponse = new ErrorResponse();
86  errorResponse.setStatus(String.valueOf(statusCode));
87  errorResponse.setScimType(scimType);
88  errorResponse.setDetail(detail);
89 
90  return Response.status(statusCode).entity(errorResponse).build();
91  }

◆ getListResponseSerialized()

String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getListResponseSerialized ( int  total,
int  startIndex,
List< BaseScimResource resources,
String  attrsList,
String  excludedAttrsList,
boolean  ignoreResults 
) throws IOException
inlinepackageinherited
203  {
204 
205  ListResponse listResponse = new ListResponse(startIndex, resources.size(), total);
206  listResponse.setResources(resources);
207 
208  ObjectMapper mapper = new ObjectMapper();
209  SimpleModule module = new SimpleModule("ListResponseModule", Version.unknownVersion());
210  module.addSerializer(ListResponse.class, new ListResponseJsonSerializer(resourceSerializer, attrsList, excludedAttrsList, ignoreResults));
211  mapper.registerModule(module);
212 
213  return mapper.writeValueAsString(listResponse);
214 
215  }
ScimResourceSerializer resourceSerializer
Definition: BaseScimWebService.java:62

◆ getMaxCount()

int org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getMaxCount ( )
inlinepackageinherited
93  {
94  return appConfiguration.getScimProperties().getMaxCount();
95  }
AppConfiguration appConfiguration
Definition: BaseScimWebService.java:59

◆ getUserById()

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.getUserById ( @PathParam("id") String  id,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inline

org.gluu.oxtrust.ws.rs.scim2.IUserWebServiceを実装しています。

127  {
128 
129  Response response;
130  try {
131  log.debug("Executing web service method. getUserById");
132  UserResource user=new UserResource();
133  GluuCustomPerson person=personService.getPersonByInum(id); //person is not null (check associated decorator method)
135 
136  String json=resourceSerializer.serialize(user, attrsList, excludedAttrsList);
137  response=Response.ok(new URI(user.getMeta().getLocation())).entity(json).build();
138  }
139  catch (Exception e){
140  log.error("Failure at getUserById method", e);
141  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
142  }
143  return response;
144 
145  }
ScimResourceSerializer resourceSerializer
Definition: BaseScimWebService.java:62
String serialize(BaseScimResource resource, String attributes, String exclusions)
Definition: ScimResourceSerializer.java:203
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
void transferAttributesToUserResource(GluuCustomPerson person, UserResource res, String url)
Definition: Scim2UserService.java:254
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
abstract GluuCustomPerson getPersonByInum(String inum)
IPersonService personService
Definition: UserWebService.java:78
Scim2UserService scim2UserService
Definition: UserWebService.java:81

◆ getValueFromHeaders()

String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.getValueFromHeaders ( HttpHeaders  headers,
String  name 
)
inlinepackageinherited
97  {
98  List<String> values=headers.getRequestHeaders().get(name);
99  return (values==null || values.size()==0) ? null : values.get(0);
100  }

◆ inspectPatchRequest()

Response org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.inspectPatchRequest ( PatchRequest  patch,
Class<? extends BaseScimResource cls 
)
inlineprotectedinherited
217  {
218 
219  Response response=null;
220  List<String> schemas=patch.getSchemas();
221 
222  if (schemas!=null && schemas.size()==1 && schemas.get(0).equals(PATCH_REQUEST_SCHEMA_ID)) {
223  List<PatchOperation> ops = patch.getOperations();
224 
225  if (ops != null) {
226  //Adjust paths if they came prefixed
227 
228  String defSchema=ScimResourceUtil.getDefaultSchemaUrn(cls);
229  List<String> urns=extService.getUrnsOfExtensions(cls);
230  urns.add(defSchema);
231 
232  for (PatchOperation op : ops){
233  if (op.getPath()!=null)
234  op.setPath(ScimResourceUtil.adjustNotationInPath(op.getPath(), defSchema, urns));
235  }
236 
237  for (PatchOperation op : ops) {
238 
239  if (op.getType() == null)
240  response = getErrorResponse(BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, "Operation '" + op.getOperation() + "' not recognized");
241  else {
242  String path = op.getPath();
243 
244  if (StringUtils.isEmpty(path) && op.getType().equals(PatchOperationType.REMOVE))
245  response = getErrorResponse(BAD_REQUEST, ErrorScimType.NO_TARGET, "Path attribute is required for remove operation");
246  else
247  if (op.getValue() == null && !op.getType().equals(PatchOperationType.REMOVE))
248  response = getErrorResponse(BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, "Value attribute is required for operations other than remove");
249  }
250  if (response != null)
251  break;
252  }
253  }
254  else
255  response = getErrorResponse(BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, "Patch request MUST contain the attribute 'Operations'");
256  }
257  else
258  response = getErrorResponse(BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, "Wrong schema(s) supplied in Search Request");
259 
260  log.info("inspectPatchRequest. Preprocessing of patch request {}", response==null ? "passed" : "failed");
261  return response;
262 
263  }
Logger log
Definition: BaseScimWebService.java:56
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
ExtensionService extService
Definition: BaseScimWebService.java:65
List< String > getUrnsOfExtensions(Class<? extends BaseScimResource > cls)
Definition: ExtensionService.java:86

◆ patchUser()

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.patchUser ( PatchRequest  request,
@PathParam("id") String  id,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inline

org.gluu.oxtrust.ws.rs.scim2.IUserWebServiceを実装しています。

285  {
286 
287  Response response;
288  try{
289  log.debug("Executing web service method. patchUser");
290  UserResource user=new UserResource();
291  GluuCustomPerson person=personService.getPersonByInum(id); //person is not null (check associated decorator method)
292 
293  //Fill user instance with all info from person
295 
296  //Apply patches one by one in sequence
297  for (PatchOperation po : request.getOperations()) {
298  //Handle special case: https://github.com/GluuFederation/oxTrust/issues/800
299  if (po.getType().equals(REMOVE) && po.getPath().equals("pairwiseIdentitifers")){
300  //If this block weren't here, the implementation will throw error because read-only attribute cannot be altered
301  //Note the path is intentionally mistyped, see class member in UserResource
302  person.setOxPPID(null);
303  user.setPairwiseIdentitifers(null);
304  scim2UserService.removePPIDsBranch(person.getDn());
305  }
306  else
307  user = (UserResource) scim2PatchService.applyPatchOperation(user, po);
308  }
309 
310  //Throws exception if final representation does not pass overall validation
311  log.debug("patchUser. Revising final resource representation still passes validations");
313  ScimResourceUtil.adjustPrimarySubAttributes(user);
314 
315  //Update timestamp
316  String now=ISODateTimeFormat.dateTime().withZoneUTC().print(System.currentTimeMillis());
317  user.getMeta().setLastModified(now);
318 
319  //Replaces the information found in person with the contents of user
321 
322  String json=resourceSerializer.serialize(user, attrsList, excludedAttrsList);
323  response=Response.ok(new URI(user.getMeta().getLocation())).entity(json).build();
324  }
325  catch (InvalidAttributeValueException e){
326  log.error(e.getMessage(), e);
327  response=getErrorResponse(Response.Status.BAD_REQUEST, ErrorScimType.MUTABILITY, e.getMessage());
328  }
329  catch (SCIMException e){
330  response=getErrorResponse(Response.Status.BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, e.getMessage());
331  }
332  catch (Exception e){
333  log.error("Failure at patchUser method", e);
334  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
335  }
336  return response;
337 
338  }
Scim2PatchService scim2PatchService
Definition: UserWebService.java:84
void removePPIDsBranch(String dn)
Definition: Scim2UserService.java:547
ScimResourceSerializer resourceSerializer
Definition: BaseScimWebService.java:62
void executeDefaultValidation(BaseScimResource resource)
Definition: BaseScimWebService.java:118
String serialize(BaseScimResource resource, String attributes, String exclusions)
Definition: ScimResourceSerializer.java:203
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
void transferAttributesToUserResource(GluuCustomPerson person, UserResource res, String url)
Definition: Scim2UserService.java:254
BaseScimResource applyPatchOperation(BaseScimResource resource, PatchOperation operation)
Definition: Scim2PatchService.java:58
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
abstract GluuCustomPerson getPersonByInum(String inum)
void replacePersonInfo(GluuCustomPerson gluuPerson, UserResource user, String url)
Definition: Scim2UserService.java:473
IPersonService personService
Definition: UserWebService.java:78
Scim2UserService scim2UserService
Definition: UserWebService.java:81

◆ prepareSearchRequest()

Response org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.prepareSearchRequest ( List< String >  schemas,
String  filter,
String  sortBy,
String  sortOrder,
Integer  startIndex,
Integer  count,
String  attrsList,
String  excludedAttrsList,
SearchRequest  request 
)
inlineprotectedinherited
167  {
168 
169  Response response=null;
170 
171  if (schemas!=null && schemas.size()==1 && schemas.get(0).equals(SEARCH_REQUEST_SCHEMA_ID)) {
172  count = count == null ? getMaxCount() : count;
173  //Per spec, a negative value SHALL be interpreted as "0" for count
174  if (count<0)
175  count=0;
176 
177  if (count <= getMaxCount()) {
178  startIndex = (startIndex == null || startIndex < 1) ? 1 : startIndex;
179 
180  if (StringUtils.isEmpty(sortOrder) || !sortOrder.equals(SortOrder.DESCENDING.getValue()))
181  sortOrder = SortOrder.ASCENDING.getValue();
182 
183  request.setSchemas(schemas);
184  request.setAttributes(attrsList);
185  request.setExcludedAttributes(excludedAttrsList);
186  request.setFilter(filter);
187  request.setSortBy(sortBy);
188  request.setSortOrder(sortOrder);
189  request.setStartIndex(startIndex);
190  request.setCount(count);
191  }
192  else
193  response = getErrorResponse(BAD_REQUEST, ErrorScimType.TOO_MANY, "Maximum number of results per page is " + getMaxCount());
194  }
195  else
196  response = getErrorResponse(BAD_REQUEST, ErrorScimType.INVALID_SYNTAX, "Wrong schema(s) supplied in Search Request");
197 
198  return response;
199 
200  }
int getMaxCount()
Definition: BaseScimWebService.java:93
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75

◆ searchUsers()

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.searchUsers ( @QueryParam(QUERY_PARAM_FILTER) String  filter,
@QueryParam(QUERY_PARAM_START_INDEX) Integer  startIndex,
@QueryParam(QUERY_PARAM_COUNT) Integer  count,
@QueryParam(QUERY_PARAM_SORT_BY) String  sortBy,
@QueryParam(QUERY_PARAM_SORT_ORDER) String  sortOrder,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inline

org.gluu.oxtrust.ws.rs.scim2.IUserWebServiceを実装しています。

222  {
223 
224  Response response;
225  try {
226  log.debug("Executing web service method. searchUsers");
227  sortBy=translateSortByAttribute(UserResource.class, sortBy);
228  PagedResult<BaseScimResource> resources = scim2UserService.searchUsers(filter, sortBy, SortOrder.getByValue(sortOrder),
229  startIndex, count, endpointUrl, getMaxCount());
230 
231  String json = getListResponseSerialized(resources.getTotalEntriesCount(), startIndex, resources.getEntries(), attrsList, excludedAttrsList, count==0);
232  response=Response.ok(json).location(new URI(endpointUrl)).build();
233  }
234  catch (SCIMException e){
235  log.error(e.getMessage(), e);
236  response=getErrorResponse(Response.Status.BAD_REQUEST, ErrorScimType.INVALID_FILTER, e.getMessage());
237  }
238  catch (Exception e){
239  log.error("Failure at searchUsers method", e);
240  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
241  }
242  return response;
243 
244  }
String getListResponseSerialized(int total, int startIndex, List< BaseScimResource > resources, String attrsList, String excludedAttrsList, boolean ignoreResults)
Definition: BaseScimWebService.java:202
int getMaxCount()
Definition: BaseScimWebService.java:93
PagedResult< BaseScimResource > searchUsers(String filter, String sortBy, SortOrder sortOrder, int startIndex, int count, String url, int maxCount)
Definition: Scim2UserService.java:520
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
String translateSortByAttribute(Class<? extends BaseScimResource > cls, String sortBy)
Definition: BaseScimWebService.java:137
Scim2UserService scim2UserService
Definition: UserWebService.java:81

◆ searchUsersPost() [1/2]

Response org.gluu.oxtrust.ws.rs.scim2.IUserWebService.searchUsersPost ( SearchRequest  searchRequest)
inherited

Sends a search query for User resources using POST (see section 3.4.3 of RFC 7644).

引数
searchRequestAn object containing the parameters for the query to execute. These are the same parameters passed in the URL for searches, for example in searchDevices
戻り値
An object abstracting the response obtained from the server to this request. A succesful response for this request should contain a status code of 200 and a ListResponse in the entity body (holding a collection of SCIM resources)

org.gluu.oxtrust.service.scim2.interceptor.UserWebServiceDecoratorで実装されています。

◆ searchUsersPost() [2/2]

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.searchUsersPost ( @ApiParam(value="SearchRequest", required=true) SearchRequest  searchRequest)
inline
254  {
255 
256  log.debug("Executing web service method. searchUsersPost");
257 
258  //Calling searchUsers here does not provoke that method's interceptor/decorator being called (only this one's)
259  URI uri=null;
260  Response response = searchUsers(searchRequest.getFilter(),searchRequest.getStartIndex(), searchRequest.getCount(),
261  searchRequest.getSortBy(), searchRequest.getSortOrder(), searchRequest.getAttributesStr(), searchRequest.getExcludedAttributesStr());
262 
263  try {
264  uri = new URI(endpointUrl + "/" + SEARCH_SUFFIX);
265  }
266  catch (Exception e){
267  log.error(e.getMessage(), e);
268  }
269  return Response.fromResponse(response).location(uri).build();
270 
271  }
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
Response searchUsers( @QueryParam(QUERY_PARAM_FILTER) String filter, @QueryParam(QUERY_PARAM_START_INDEX) Integer startIndex, @QueryParam(QUERY_PARAM_COUNT) Integer count, @QueryParam(QUERY_PARAM_SORT_BY) String sortBy, @QueryParam(QUERY_PARAM_SORT_ORDER) String sortOrder, @QueryParam(QUERY_PARAM_ATTRIBUTES) String attrsList, @QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String excludedAttrsList)
Definition: UserWebService.java:215
static final String SEARCH_SUFFIX
Definition: BaseScimWebService.java:67

◆ setup()

void org.gluu.oxtrust.ws.rs.scim2.UserWebService.setup ( )
inline
341  {
342  //Do not use getClass() here... a typical weld issue...
343  endpointUrl=appConfiguration.getBaseEndpoint() + UserWebService.class.getAnnotation(Path.class).value();
344  }
String endpointUrl
Definition: BaseScimWebService.java:69
AppConfiguration appConfiguration
Definition: BaseScimWebService.java:59

◆ translateSortByAttribute()

String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.translateSortByAttribute ( Class<? extends BaseScimResource cls,
String  sortBy 
)
inlinepackageinherited
137  {
138 
139  String type=ScimResourceUtil.getType(cls);
140  if (StringUtils.isEmpty(sortBy) || type==null)
141  sortBy=null;
142  else {
143  if (extService.extensionOfAttribute(cls, sortBy)==null) { //It's not a custom attribute...
144 
145  sortBy=ScimResourceUtil.stripDefaultSchema(cls, sortBy);
146  Field f=IntrospectUtil.findFieldFromPath(cls, sortBy);
147 
148  if (f==null){ //Not recognized!
149  log.warn("SortBy parameter value '{}' was not recognized as a SCIM attribute for resource {} - sortBy will be ignored.", sortBy, type);
150  sortBy=null;
151  //return getErrorResponse(Response.Status.BAD_REQUEST, ErrorScimType.INVALID_PATH, "sortBy parameter value not recognized");
152  }
153  else {
154  sortBy = FilterUtil.getLdapAttributeOfResourceAttribute(sortBy, cls).getFirst();
155  if (sortBy==null)
156  log.warn("There is no LDAP attribute mapping to sortBy attribute provided - sortBy will be ignored.");
157  }
158  }
159  else
160  sortBy = sortBy.substring(sortBy.lastIndexOf(":")+1);
161  }
162  return sortBy;
163 
164  }
Extension extensionOfAttribute(Class<? extends BaseScimResource > cls, String attribute)
Definition: ExtensionService.java:147
Logger log
Definition: BaseScimWebService.java:56
ExtensionService extService
Definition: BaseScimWebService.java:65

◆ updateUser() [1/2]

Response org.gluu.oxtrust.ws.rs.scim2.IUserWebService.updateUser ( UserResource  user,
@PathParam("id") String  id,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inherited

Service method that allows updating a User resource via PUT (as per section 3.5.1 of RFC 7644).

This operation is not suitable to delete/remove/nullify attributes. For this purpose you can use the PATCH operation instead. PUT is intended to do replacements using the (not-null) values supplied in fidoDeviceResource parameter.

To learn more about how the update works, read the replacement rules found at ScimResourceUtil#transferToResourceReplace.

引数
userAn object that contains the data to update on a destination resource. There is no need to supply a full resource, just provide one with the attributes which are intended to be replaced in the destination
idThe "id" attribute of the resource to update (destination)
attrsListSee notes about attributes query param
excludedAttrsListSee notes about excludedAttributes query param
戻り値
An object abstracting the response obtained from the server to this request. A succesful response for this operation should contain a status code of 200 and a UserResource in the entity body (the resource after the update took place)

◆ updateUser() [2/2]

Response org.gluu.oxtrust.ws.rs.scim2.UserWebService.updateUser ( @ApiParam(value="User", required=true) UserResource  user,
@PathParam("id") String  id,
@QueryParam(QUERY_PARAM_ATTRIBUTES) String  attrsList,
@QueryParam(QUERY_PARAM_EXCLUDED_ATTRS) String  excludedAttrsList 
)
inline

This implementation differs from spec in the following aspects:

  • Passing a null value for an attribute, does not modify the attribute in the destination, however passing an empty array for a multivalued attribute does clear the attribute. Thus, to clear single-valued attribute, PATCH operation should be used
165  {
166 
167  Response response;
168  try {
169  log.debug("Executing web service method. updateUser");
170  UserResource updatedResource=scim2UserService.updateUser(id, user, endpointUrl);
171  String json=resourceSerializer.serialize(updatedResource, attrsList, excludedAttrsList);
172  response=Response.ok(new URI(updatedResource.getMeta().getLocation())).entity(json).build();
173  }
174  catch (InvalidAttributeValueException e){
175  log.error(e.getMessage());
176  response=getErrorResponse(Response.Status.BAD_REQUEST, ErrorScimType.MUTABILITY, e.getMessage());
177  }
178  catch (Exception e){
179  log.error("Failure at updateUser method", e);
180  response=getErrorResponse(Response.Status.INTERNAL_SERVER_ERROR, "Unexpected error: " + e.getMessage());
181  }
182  return response;
183 
184  }
ScimResourceSerializer resourceSerializer
Definition: BaseScimWebService.java:62
String serialize(BaseScimResource resource, String attributes, String exclusions)
Definition: ScimResourceSerializer.java:203
String endpointUrl
Definition: BaseScimWebService.java:69
Logger log
Definition: BaseScimWebService.java:56
UserResource updateUser(String id, UserResource user, String url)
Definition: Scim2UserService.java:456
static Response getErrorResponse(Response.Status status, String detail)
Definition: BaseScimWebService.java:75
Scim2UserService scim2UserService
Definition: UserWebService.java:81

メンバ詳解

◆ appConfiguration

AppConfiguration org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.appConfiguration
packageinherited

◆ endpointUrl

String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.endpointUrl
packageinherited

◆ extService

ExtensionService org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.extService
packageinherited

◆ log

Logger org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.log
packageinherited

◆ personService

IPersonService org.gluu.oxtrust.ws.rs.scim2.UserWebService.personService
private

◆ resourceSerializer

ScimResourceSerializer org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.resourceSerializer
packageinherited

◆ scim2PatchService

Scim2PatchService org.gluu.oxtrust.ws.rs.scim2.UserWebService.scim2PatchService
private

◆ scim2UserService

Scim2UserService org.gluu.oxtrust.ws.rs.scim2.UserWebService.scim2UserService
private

◆ SEARCH_SUFFIX

final String org.gluu.oxtrust.ws.rs.scim2.BaseScimWebService.SEARCH_SUFFIX = ".search"
staticinherited

このクラス詳解は次のファイルから抽出されました: