1 package org.collectionspace.services.common.vocabulary;
3 import java.util.regex.Matcher;
4 import java.util.regex.Pattern;
6 import javax.ws.rs.core.Response;
8 import org.collectionspace.services.client.AuthorityClient;
9 import org.collectionspace.services.client.CollectionSpaceClient;
10 import org.collectionspace.services.client.PoxPayloadIn;
11 import org.collectionspace.services.common.api.RefNameUtils.AuthorityTermInfo;
12 import org.collectionspace.services.common.context.MultipartServiceContextImpl;
13 import org.collectionspace.services.common.context.ServiceContext;
14 import org.collectionspace.services.common.vocabulary.RefNameServiceUtils.AuthorityItemSpecifier;
15 import org.collectionspace.services.common.vocabulary.RefNameServiceUtils.Specifier;
16 import org.collectionspace.services.common.vocabulary.RefNameServiceUtils.SpecifierForm;
17 import org.collectionspace.services.common.vocabulary.nuxeo.AuthorityIdentifierUtils;
18 import org.collectionspace.services.nuxeo.client.java.CoreSessionInterface;
19 import org.collectionspace.services.nuxeo.util.NuxeoUtils;
20 import org.dom4j.DocumentException;
21 import org.nuxeo.ecm.core.api.DocumentModel;
22 import org.slf4j.Logger;
23 import org.slf4j.LoggerFactory;
25 public class AuthorityServiceUtils {
26 private static final Logger logger = LoggerFactory.getLogger(AuthorityIdentifierUtils.class);
28 // Used to keep track if an authority item's is deprecated
29 public static final String IS_DEPRECATED_PROPERTY = "IS_DEPRECATED_PROPERTY";
30 public static final Boolean DEPRECATED = true;
31 public static final Boolean NOT_DEPRECATED = !DEPRECATED;
33 // Used to keep track if an authority item's rev number should be updated
34 public static final String SHOULD_UPDATE_REV_PROPERTY = "SHOULD_UPDATE_REV_PROPERTY";
35 public static final boolean UPDATE_REV = true;
36 public static final boolean DONT_UPDATE_REV = !UPDATE_REV;
38 // Used to keep track if an authority item is a locally proposed member of a SAS authority
39 public static final String IS_PROPOSED_PROPERTY = "IS_PROPOSED";
40 public static final Boolean PROPOSED = true;
41 public static final Boolean NOT_PROPOSED = !PROPOSED;
42 public static final Boolean SAS_ITEM = true;
43 public static final Boolean NOT_SAS_ITEM = !SAS_ITEM;
45 public static final Boolean NO_CHANGE = null;
48 * Make a request to the SAS Server for an authority payload.
56 static public PoxPayloadIn requestPayloadIn(ServiceContext ctx, Specifier specifier, Class responseType) throws Exception {
57 PoxPayloadIn result = null;
59 AuthorityClient client = (AuthorityClient) ctx.getClient(CollectionSpaceClient.SAS_CLIENT_PROPERTIES_FILENAME);
60 Response res = client.read(specifier.getURNValue());
62 int statusCode = res.getStatus();
64 // Check the status code of the response: does it match
65 // the expected response(s)?
66 if (logger.isDebugEnabled()) {
67 logger.debug(client.getClass().getCanonicalName() + ": status = " + statusCode);
70 result = new PoxPayloadIn((String)res.readEntity(responseType)); // Get the entire response!
79 // Makes a call to the SAS server for a authority item payload
81 static public PoxPayloadIn requestPayloadIn(AuthorityItemSpecifier specifier, String serviceName, Class responseType, boolean syncHierarchicalRelationships) throws Exception {
82 PoxPayloadIn result = null;
84 ServiceContext parentCtx = new MultipartServiceContextImpl(serviceName);
85 AuthorityClient client = (AuthorityClient) parentCtx.getClient(CollectionSpaceClient.SAS_CLIENT_PROPERTIES_FILENAME);
86 Response res = client.readNamedItemInNamedAuthority(specifier.getParentSpecifier().getURNValue(), specifier.getItemSpecifier().getURNValue(),
87 AuthorityClient.INCLUDE_DELETED_ITEMS, syncHierarchicalRelationships);
90 int statusCode = res.getStatus();
92 // Check the status code of the response: does it match
93 // the expected response(s)?
94 if (logger.isDebugEnabled()) {
95 logger.debug(client.getClass().getCanonicalName() + ": status = " + statusCode);
98 result = new PoxPayloadIn((String)res.readEntity(responseType)); // Get the entire response!
106 static public boolean setAuthorityItemDeprecated(ServiceContext ctx,
107 DocumentModel docModel, String authorityItemCommonSchemaName, Boolean flag) throws Exception {
108 boolean result = false;
110 docModel.setProperty(authorityItemCommonSchemaName, AuthorityItemJAXBSchema.DEPRECATED,
112 CoreSessionInterface repoSession = (CoreSessionInterface) ctx.getCurrentRepositorySession();
113 repoSession.saveDocument(docModel);
120 * The domain name part of refnames on SAS may not match that of local refnames, so we need to update all the payload's
121 * refnames with the correct domain name
123 static public PoxPayloadIn filterRefnameDomains(ServiceContext ctx,
124 PoxPayloadIn payload) throws DocumentException {
125 PoxPayloadIn result = null;
128 String payloadStr = payload.getXmlPayload();
129 Pattern p = Pattern.compile("(urn:cspace:)(([a-z]{1,}\\.?)*)"); // matches the domain name part of a RefName. For example, matches "core.collectionspace.org" of RefName urn:cspace:core.collectionspace.org:personauthorities:name(person):item:name(BigBird1461101206103)'Big Bird'
130 Matcher m = p.matcher(payloadStr);
132 StringBuffer filteredPayloadStr = new StringBuffer();
133 while (m.find() == true) {
134 if (logger.isDebugEnabled()) {
135 logger.debug("Replacing: " + m.group(2));
137 m.appendReplacement(filteredPayloadStr, m.group(1) + ctx.getTenantName());
139 m.appendTail(filteredPayloadStr);
140 result = new PoxPayloadIn(filteredPayloadStr.toString());
142 if (logger.isDebugEnabled()) {
143 logger.debug(String.format("", filteredPayloadStr));
150 * Mark the authority item as deprecated.
156 static public boolean markAuthorityItemAsDeprecated(ServiceContext ctx, String authorityItemCommonSchemaName, AuthorityItemSpecifier authorityItemSpecifier) throws Exception {
157 boolean result = false;
160 DocumentModel docModel = NuxeoUtils.getDocFromSpecifier(ctx, (CoreSessionInterface)ctx.getCurrentRepositorySession(),
161 authorityItemCommonSchemaName, authorityItemSpecifier);
162 result = setAuthorityItemDeprecated(ctx, docModel, authorityItemCommonSchemaName, AuthorityServiceUtils.DEPRECATED);
163 } catch (Exception e) {
164 logger.warn(String.format("Could not mark item '%s' as deprecated.", authorityItemSpecifier.getItemSpecifier().getURNValue()), e);