]> git.aero2k.de Git - tmp/jakarta-migration.git/blob
3a92dfa9c46f57fd4949f146845a4231f64538c9
[tmp/jakarta-migration.git] /
1 package org.collectionspace.services.common.vocabulary;
2
3 import java.util.regex.Matcher;
4 import java.util.regex.Pattern;
5
6 import javax.ws.rs.core.Response;
7
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;
24
25 public class AuthorityServiceUtils {
26     private static final Logger logger = LoggerFactory.getLogger(AuthorityIdentifierUtils.class);
27     //
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;
32     
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;
37
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;
44
45     public static final Boolean NO_CHANGE = null;
46
47     /**
48      * Make a request to the SAS Server for an authority payload.
49      * 
50      * @param ctx
51      * @param specifier
52      * @param responseType
53      * @return
54      * @throws Exception
55      */
56     static public PoxPayloadIn requestPayloadIn(ServiceContext ctx, Specifier specifier, Class responseType) throws Exception {
57         PoxPayloadIn result = null;
58         
59         AuthorityClient client = (AuthorityClient) ctx.getClient(CollectionSpaceClient.SAS_CLIENT_PROPERTIES_FILENAME);
60         Response res = client.read(specifier.getURNValue());
61         try {
62                 int statusCode = res.getStatus();
63         
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);
68                 }
69                 
70             result = new PoxPayloadIn((String)res.readEntity(responseType)); // Get the entire response!                
71         } finally {
72                 res.close();
73         }
74         
75         return result;
76     }
77     
78     //
79     // Makes a call to the SAS server for a authority item payload
80     //    
81     static public PoxPayloadIn requestPayloadIn(AuthorityItemSpecifier specifier, String serviceName, Class responseType) throws Exception {
82         PoxPayloadIn result = null;
83         
84         ServiceContext parentCtx = new MultipartServiceContextImpl(serviceName);
85         AuthorityClient client = (AuthorityClient) parentCtx.getClient(CollectionSpaceClient.SAS_CLIENT_PROPERTIES_FILENAME);
86         Response res = client.readItem(specifier.getParentSpecifier().getURNValue(), specifier.getItemSpecifier().getURNValue());
87         try {
88                 int statusCode = res.getStatus();
89         
90                 // Check the status code of the response: does it match
91                 // the expected response(s)?
92                 if (logger.isDebugEnabled()) {
93                     logger.debug(client.getClass().getCanonicalName() + ": status = " + statusCode);
94                 }
95                 
96             result = new PoxPayloadIn((String)res.readEntity(responseType)); // Get the entire response!                
97         } finally {
98                 res.close();
99         }
100         
101         return result;
102     }
103     
104     static public boolean setAuthorityItemDeprecated(ServiceContext ctx,
105                 DocumentModel docModel, String authorityItemCommonSchemaName, Boolean flag) throws Exception {
106         boolean result = false;
107         
108         docModel.setProperty(authorityItemCommonSchemaName, AuthorityItemJAXBSchema.DEPRECATED,
109                         new Boolean(flag));
110         CoreSessionInterface repoSession = (CoreSessionInterface) ctx.getCurrentRepositorySession();
111         repoSession.saveDocument(docModel);
112         result = true;
113         
114         return result;
115     }
116     
117     /*
118      * The domain name part of refnames on SAS may not match that of local refnames, so we need to update all the payload's
119      * refnames with the correct domain name
120      */
121         static public PoxPayloadIn filterRefnameDomains(ServiceContext ctx,
122                         PoxPayloadIn payload) throws DocumentException {
123                 PoxPayloadIn result = null;
124
125                 
126                 String payloadStr = payload.getXmlPayload();
127                 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'
128                 Matcher m = p.matcher(payloadStr);
129
130                 StringBuffer filteredPayloadStr = new StringBuffer();
131                 while (m.find() == true) {
132                         if (logger.isDebugEnabled()) {
133                                 logger.debug("Replacing: " + m.group(2));
134                         }
135                         m.appendReplacement(filteredPayloadStr, m.group(1) + ctx.getTenantName());
136                 }
137                 m.appendTail(filteredPayloadStr);
138                 result = new PoxPayloadIn(filteredPayloadStr.toString());
139
140                 if (logger.isDebugEnabled()) {
141                         logger.debug(String.format("", filteredPayloadStr));
142                 }
143
144                 return result;
145         }
146     
147     /**
148      * Mark the authority item as deprecated.
149      * 
150      * @param ctx
151      * @param itemInfo
152      * @throws Exception
153      */
154     static public boolean markAuthorityItemAsDeprecated(ServiceContext ctx, String authorityItemCommonSchemaName, AuthorityItemSpecifier authorityItemSpecifier) throws Exception {
155         boolean result = false;
156         
157         try {
158                 DocumentModel docModel = NuxeoUtils.getDocFromSpecifier(ctx, (CoreSessionInterface)ctx.getCurrentRepositorySession(),
159                                 authorityItemCommonSchemaName, authorityItemSpecifier);
160                 result = setAuthorityItemDeprecated(ctx, docModel, authorityItemCommonSchemaName, AuthorityServiceUtils.DEPRECATED);
161         } catch (Exception e) {
162                 logger.warn(String.format("Could not mark item '%s' as deprecated.", authorityItemSpecifier.getItemSpecifier().getURNValue()), e);
163                 throw e;
164         }
165         
166         return result;
167     }
168 }