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

main.java.com.cloudant.client.api.model.DesignDocument Maven / Gradle / Ivy

/*
 * Copyright (C) 2011 lightcouch.org
 * Copyright © 2015, 2019 IBM Corp. All rights reserved.
 *
 * Licensed under 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.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the
 * License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */

package com.cloudant.client.api.model;

import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.annotations.SerializedName;

import java.util.Map;

/**
 * Encapsulates a design document.
 * 

* This is the type of design document objects used by the * {@link com.cloudant.client.api.DesignDocumentManager}. *

*

* This class can be used as a deserialization target for design documents stored in a database. * For example: *

*
 * {@code
 * DesignDocument exampleDDoc = database.find(DesignDocument.class, "_design/exampleDesignDoc");
 * }
 * 
*

* This class can also be used to create or update design documents. * For example: *

*
 * {@code
 * // Create
 * DesignDocument ddoc = new DesignDocument();
 * // Call setters on ddoc to populate document
 * ddoc.setId("_design/exampleDesignDoc");
 * // Save to create the design document
 * database.save(ddoc)
 *
 * // Update
 * DesignDocument ddoc = database.find(DesignDocument.class, "_design/exampleDesignDoc");
 * // Call setters to update values
 * Map updates = new HashMap();
 * updates.put("newUpdateHandler", "function (doc, req) { ... }");
 * ddoc.setUpdates(updates);
 * // Update the design document
 * database.update(ddoc);
 *
 * }
 * 
* * @author Ahmed Yehia * @see com.cloudant.client.api.DesignDocumentManager * @since 0.0.2 */ public class DesignDocument extends com.cloudant.client.org.lightcouch.Document { /** * Encapsulates design document options. */ public static class Options { private boolean partitioned; /** * Get partitioned option for this design document. * * @return partitioned option */ public boolean getPartitioned() { return partitioned; } /** * Set the partitioned option for this design document. * * @param partitioned partitioned option */ public void setPartitioned(boolean partitioned) { this.partitioned = partitioned; } } private static final String LANG_QUERY = "query"; // Default GSON instance for serializing/deserializing JsonElements of views private static final Gson GSON = new Gson(); private String language; private Map views; @SerializedName("validate_doc_update") private String validateDocUpdate; private Map filters; private Map shows; private Map lists; private Map updates; private Options options; private JsonArray rewrites; private JsonObject fulltext; private JsonObject indexes; /** * Get the language used for the views defined in this design document. * * @return typically either "javascript" or "query". */ public String getLanguage() { return language; } /** * Get the views defined in this design document. * * @return a map of view name to {@link MapReduce} * from the view * @see Views */ public Map getViews() { return views; } /** * Get the string of the javascript function set for the design document's {@code * validate_doc_update} property. * * @return string of validate_doc_update function * @see Update validators */ public String getValidateDocUpdate() { return validateDocUpdate; } /** * Get the array of URL rewriting rules set in the design document's {@code rewrites} property. * * @return array of JSON objects each representing a rewrite rule * @see Rewrite rules */ public JsonArray getRewrites() { return rewrites; } /** * @return the design document's {@code fulltext} property */ public JsonObject getFulltext() { return fulltext; } /** * Get a JSON object containing all the indexes defined in the design document. * * @return the JSON object stored in the design document's {@code indexes} property * @see Indexes */ public JsonObject getIndexes() { return indexes; } /** * Get the changes feed filter functions defined in this design document. * * @return map of filter name to function string * @see Filter functions */ public Map getFilters() { return filters; } /** * Get the show functions defined in this design document. * * @return map of show function name to function string * @see Show functions */ public Map getShows() { return shows; } /** * Get the list functions defined in this design document. * * @return map of list function name to function string * @see List functions */ public Map getLists() { return lists; } /** * Get the update handlers defined in this design document. * * @return map of update handler name to function string * @see Update handlers */ public Map getUpdates() { return updates; } /** * Get the options defined in this design document. * * @return design document options, or {@code null} if no options are defined */ public Options getOptions() { return options; } /** * Set the language of the design document. * * @param language typically {@code "javascript"} */ public void setLanguage(String language) { this.language = language; } /** * Set the views defined in this design document's view property. * * @param views map of view name to MapReduce class * @see Views */ public void setViews(Map views) { this.views = views; } /** * Set the javascript function for the design document's {@code validate_doc_update} property. * * @param validateDocUpdate string defining validate_doc_update function * @see Update validators */ public void setValidateDocUpdate(String validateDocUpdate) { this.validateDocUpdate = validateDocUpdate; } /** * Set the array of URL rewriting rules set in the design document's {@code rewrites} property. * * @param rewrites array of JsonObjects each representing a rewrite rule * @see Rewrite rules */ public void setRewrites(JsonArray rewrites) { this.rewrites = rewrites; } /** * @param fulltext JsonObject to set as the design document's {@code fulltext} property */ public void setFulltext(JsonObject fulltext) { this.fulltext = fulltext; } /** * Set a JSON object defining the indexes of this design document. * * @param indexes JsonObject defining the indexes * @see Indexes */ public void setIndexes(JsonObject indexes) { this.indexes = indexes; } /** * Define the changes feed filter functions set in this design document. * * @param filters map of filter name to function string * @see Filter functions */ public void setFilters(Map filters) { this.filters = filters; } /** * Set the show functions defined in this design document. * * @param shows map of show function name to function string * @see Show functions */ public void setShows(Map shows) { this.shows = shows; } /** * Set the list functions defined in this design document. * * @param lists map of list function name to function string * @see List functions */ public void setLists(Map lists) { this.lists = lists; } /** * Set the update handlers defined in this design document. * * @param updates map of update handler name to function string * @see Update handlers */ public void setUpdates(Map updates) { this.updates = updates; } /** * Set design document options. * * @param options design document options */ public void setOptions(Options options) { this.options = options; } @Override public int hashCode() { int result = super.hashCode(); result = 31 * result + (language != null ? language.hashCode() : 0); result = 31 * result + (views != null ? views.hashCode() : 0); result = 31 * result + (validateDocUpdate != null ? validateDocUpdate.hashCode() : 0); result = 31 * result + (filters != null ? filters.hashCode() : 0); result = 31 * result + (shows != null ? shows.hashCode() : 0); result = 31 * result + (lists != null ? lists.hashCode() : 0); result = 31 * result + (updates != null ? updates.hashCode() : 0); result = 31 * result + (rewrites != null ? rewrites.hashCode() : 0); result = 31 * result + (fulltext != null ? fulltext.hashCode() : 0); result = 31 * result + (indexes != null ? indexes.hashCode() : 0); return result; } /** * Compares this design document to the specified object. The result is {@code true} if and only * if the argument is not {@code null} and is a {@link DesignDocument} with the same * {@code _id}, {@code _rev}, and document contents. * * @param o The object to compare this design document to * @return {@code true} if the given object represents a design document equivalent to this * design document, {@code false} otherwise */ @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } if (!super.equals(o)) { return false; } DesignDocument that = (DesignDocument) o; if (language != null ? !language.equals(that.language) : that.language != null) { return false; } if (views != null ? !views.equals(that.views) : that.views != null) { return false; } if (validateDocUpdate != null ? !validateDocUpdate.equals(that.validateDocUpdate) : that .validateDocUpdate != null) { return false; } if (filters != null ? !filters.equals(that.filters) : that.filters != null) { return false; } if (shows != null ? !shows.equals(that.shows) : that.shows != null) { return false; } if (lists != null ? !lists.equals(that.lists) : that.lists != null) { return false; } if (updates != null ? !updates.equals(that.updates) : that.updates != null) { return false; } if (rewrites != null ? !rewrites.equals(that.rewrites) : that.rewrites != null) { return false; } if (fulltext != null ? !fulltext.equals(that.fulltext) : that.fulltext != null) { return false; } return !(indexes != null ? !indexes.equals(that.indexes) : that.indexes != null); } /** * Encapsulates the Map-Reduce function of a view. * *
     * {@code
     *
     * // Javascript view definition in design document
     * "views": {
     *   "exampleView" : {
     *       "map" : "function(doc) { emit(doc.propertyA, doc.propertyB); }"
     *       "reduce" : "_count"
     *   }
     * }
     *
     * // Java example using MapReduce
     *
     * // Get the views from the design document
     * Map views = ddoc.getViews();
     *
     * // Get the MapReduce for the "exampleView"
     * MapReduce exampleView = views.get("exampleView");
     *
     * // Get the strings of the map and reduce functions
     * exampleView.getMap(); // "function(doc) { emit(doc.propertyA, doc.propertyB); }"
     * exampleView.getReduce(); // "_count"
     * }
     * 
* * @author Ahmed Yehia */ public static class MapReduce { private JsonElement map; private JsonElement reduce; private String dbcopy; public MapReduce() { super(); } /** * Get the defined map function. * * @return string of the javascript map function */ public String getMap() { return stringifyMRElement(map); } /** * Get the defined reduce function. * * @return string of the javascript reduce function */ public String getReduce() { return stringifyMRElement(reduce); } /** * Set the map function. * * @param map string of the javascript map function */ public void setMap(String map) { this.map = GSON.toJsonTree(map); } /** * Set the reduce function. * * @param reduce string of the javascript reduce function */ public void setReduce(String reduce) { this.reduce = GSON.toJsonTree(reduce); } /** *

* Set the name of a database to copy the reduced view results into. *

*

* Use of the {@code dbcopy} feature is deprecated and is strongly discouraged. * For more information, see the * Bluemix documentation for this feature. *

* * @param databaseName of the database to store reduced view results in * @see #getDbCopy() */ @Deprecated public void setDbCopy(String databaseName) { this.dbcopy = databaseName; } /** * @return the database name where reduced view results will be stored, or null if unset * @see #setDbCopy(String) */ @Deprecated public String getDbCopy() { return dbcopy; } /** * @param element JSON object or string * @return a string form of the object or the JSON string with leading and trailing " * stripped */ private String stringifyMRElement(JsonElement element) { if (element != null) { String stringifiedElement = element.toString(); if (element.isJsonPrimitive() && element.getAsJsonPrimitive().isString()) { // If the element is a JSON string, strip the leading and trailing " return stringifiedElement.substring(1, stringifiedElement.length() - 1); } else { return stringifiedElement; } } else { return null; } } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } MapReduce other = (MapReduce) obj; if (map == null) { if (other.map != null) { return false; } } else if (!map.equals(other.map)) { return false; } if (reduce == null) { if (other.reduce != null) { return false; } } else if (!reduce.equals(other.reduce)) { return false; } if (dbcopy == null) { if (other.dbcopy != null) { return false; } } else if (!dbcopy.equals(other.dbcopy)) { return false; } return true; } @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((map == null) ? 0 : map.hashCode()); result = prime * result + ((reduce == null) ? 0 : reduce.hashCode()); result = prime * result + ((dbcopy == null) ? 0 : dbcopy.hashCode()); return result; } } // /class MapReduce }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy