All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java.fedora.server.storage.GSearchDOManager Maven / Gradle / Ivy

Go to download

The Fedora Client is a Java Library that allows API access to a Fedora Repository. The client is typically one part of a full Fedora installation.

The newest version!
/*
 * -----------------------------------------------------------------------------
 *
 * 

License and Copyright: The contents of this file are subject to the * Apache License, Version 2.0 (the "License"); you may not use * this file except in compliance with the License. You may obtain a copy of * the License at * http://www.fedora-commons.org/licenses.

* *

Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for * the specific language governing rights and limitations under the License.

* *

The entire file consists of original code.

*

Copyright © 2008 Fedora Commons, Inc.
*

Copyright © 2002-2007 The Rector and Visitors of the University of * Virginia and Cornell University
* All rights reserved.

* * ----------------------------------------------------------------------------- */ package fedora.server.storage; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.net.MalformedURLException; import java.net.URL; import java.net.URLEncoder; import java.util.Map; import org.apache.commons.httpclient.UsernamePasswordCredentials; import org.apache.log4j.Logger; import fedora.common.http.HttpInputStream; import fedora.common.http.WebClient; import fedora.server.Context; import fedora.server.Server; import fedora.server.errors.ModuleInitializationException; import fedora.server.errors.ServerException; import fedora.server.storage.types.DigitalObject; /** * DefaultDOManager extension that updates a GSearch (Fedora * Generic Search) service as object changes are committed. * *

To use, simply change fedora.fcfg, replacing "DefaultDOManager" * with "GSearchDOManager", and add the following xml param elements:

* *

Required: *

    *
  • <param name="gSearchRESTURL" * value="http://localhost:8080/fedoragsearch/rest"/>
  • *
*

* *

Optional (only needed if basic auth is required for GSearch REST access): *

    *
  • <param name="gSearchUsername" value="exampleUsername"/>
  • *
  • <param name="gSearchPassword" value="examplePassword"/>
  • *
*

* * @author [email protected] */ public class GSearchDOManager extends DefaultDOManager { /** Logger for this class. */ private static final Logger LOG = Logger.getLogger( GSearchDOManager.class.getName()); /** Required param: URL of GSearch REST interface. */ public static final String GSEARCH_REST_URL = "gSearchRESTURL"; /** Optional param: User to authenticate to GSearch as. */ public static final String GSEARCH_USERNAME = "gSearchUsername"; /** Optional param: Password to use for GSearch authentication. */ public static final String GSEARCH_PASSWORD = "gSearchPassword"; /** Configured value for GSEARCH_REST_URL parameter. */ private String _gSearchRESTURL; /** Credentials we'll use for GSearch authentication, if enabled. */ private UsernamePasswordCredentials _gSearchCredentials; /** HTTP client we'll use for sending GSearch update signals. */ private WebClient _webClient; /** * Delegates construction to the superclass. */ public GSearchDOManager(Map moduleParameters, Server server, String role) throws ModuleInitializationException { super(moduleParameters, server, role); } // // Overrides of DefaultDOManager methods // /** * Performs superclass post-initialization, then completes initialization * using GSearch-specific parameters. */ public void postInitModule() throws ModuleInitializationException { super.postInitModule(); // validate required param: GSEARCH_REST_URL _gSearchRESTURL = getParameter(GSEARCH_REST_URL); if (_gSearchRESTURL == null) { throw new ModuleInitializationException("Required parameter, " + GSEARCH_REST_URL + " was not specified", getRole()); } else { try { new URL(_gSearchRESTURL); LOG.debug("Configured GSearch REST URL: " + _gSearchRESTURL); } catch (MalformedURLException e) { throw new ModuleInitializationException("Malformed URL given " + "for " + GSEARCH_REST_URL + " parameter: " + _gSearchRESTURL, getRole()); } } // validate credentials: if GSEARCH_USERNAME is given, GSEARCH_PASSWORD // should also be. String user = getParameter(GSEARCH_USERNAME); if (user != null) { LOG.debug("Will authenticate to GSearch service as user: " + user); String pass = getParameter(GSEARCH_PASSWORD); if (pass != null) { _gSearchCredentials = new UsernamePasswordCredentials(user, pass); } else { throw new ModuleInitializationException(GSEARCH_PASSWORD + " must be specified because " + GSEARCH_USERNAME + " was specified", getRole()); } } else { LOG.debug(GSEARCH_USERNAME + " unspecified; will not attempt " + "to authenticate to GSearch service"); } // finally, init the http client we'll use _webClient = new WebClient(); } /** * Commits the changes to the given object as usual, then attempts * to propagate the change to the GSearch service. */ public void doCommit(boolean cachedObjectRequired, Context context, DigitalObject obj, String logMessage, boolean remove) throws ServerException { super.doCommit(cachedObjectRequired, context, obj, logMessage, remove); // determine the url we need to invoke StringBuffer url = new StringBuffer(); url.append(_gSearchRESTURL + "?operation=updateIndex"); String pid = obj.getPid(); url.append("&value=" + urlEncode(pid)); if (remove) { LOG.info("Signaling removal of " + pid + " to GSearch"); url.append("&action=deletePid"); } else { if (LOG.isInfoEnabled()) { if (obj.isNew()) { LOG.info("Signaling add of " + pid + " to GSearch"); } else { LOG.info("Signaling mod of " + pid + " to GSearch"); } } url.append("&action=fromPid"); } // send the signal sendRESTMessage(url.toString()); } // // Private utility methods // /** * Performs the given HTTP request, logging a warning if we don't * get a 200 OK response. */ private void sendRESTMessage(String url) { HttpInputStream response = null; try { LOG.debug("Getting " + url); response = _webClient.get(url, false, _gSearchCredentials); int code = response.getStatusCode(); if (code != 200) { LOG.warn("Error sending update to GSearch service (url=" + url + "). HTTP response code was " + code + ". " + "Body of response from GSearch follows:\n" + getString(response)); } } catch (Exception e) { LOG.warn("Error sending update to GSearch service via URL: " + url, e); } finally { if (response != null) { try { response.close(); } catch (Exception e) { LOG.warn("Error closing GSearch response", e); } } } } /** * Read the remainder of the given stream as a String and return it, * or an error message if we encounter an error. */ private static String getString(InputStream in) { try { StringBuffer out = new StringBuffer(); BufferedReader reader = new BufferedReader( new InputStreamReader(in)); String line = reader.readLine(); while (line != null) { out.append(line + "\n"); line = reader.readLine(); } return out.toString(); } catch (Exception e) { return "[Error reading response body: " + e.getClass().getName() + ": " + e.getMessage() + "]"; } } /** * URL-encode the given string using UTF-8 encoding. */ private static final String urlEncode(String s) { try { return URLEncoder.encode(s, "UTF-8"); } catch (Exception e) { LOG.warn("Failed to encode '" + s + "'", e); return s; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy