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

org.lockss.util.Constants Maven / Gradle / Ivy

There is a newer version: 1.14.1
Show newest version
/*
 * $Id$
 */

/*

Copyright (c) 2000-2012 Board of Trustees of Leland Stanford Jr. University,
all rights reserved.

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
STANFORD UNIVERSITY BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR
IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Except as contained in this notice, the name of Stanford University shall not
be used in advertising or otherwise to promote the sale, use or other dealings
in this Software without prior written authorization from Stanford University.

*/

package org.lockss.util;

import java.util.*;

import org.lockss.util.lang.EncodingUtil;
import org.lockss.util.time.TimeUtil;
import org.lockss.util.time.TimeZoneUtil;

/**
 * Constants of general use
 */
public interface Constants {

  /** The number of milliseconds in a second */
  public static final long SECOND = TimeUtil.SECOND;
  /** The number of milliseconds in a minute */
  public static final long MINUTE = TimeUtil.MINUTE;
  /** The number of milliseconds in an hour */
  public static final long HOUR = TimeUtil.HOUR;
  /** The number of milliseconds in a day */
  public static final long DAY = TimeUtil.DAY;
  /** The number of milliseconds in a week */
  public static final long WEEK = TimeUtil.WEEK;
  /** The number of milliseconds in a (non-leap) year */
  public static final long YEAR = TimeUtil.YEAR;

  /** List delimiter in strings */
  public static String LIST_DELIM = ";";
  /** List delimiter char in strings */
  public static char LIST_DELIM_CHAR = ';';

  /** The default timezone, GMT */
  public static final TimeZone DEFAULT_TIMEZONE = TimeZoneUtil.TIMEZONE_GMT;

  /** The line separator string on this system */
  public static String EOL = System.getProperty("line.separator");

  /** Carriage-return linefeed */
  public static final String CRLF = "\r\n";

  /** Separator for polling groups */
  public static String GROUP_SEPARATOR = ";";

  /**
   * 

The US ASCII encoding.

*/ public static final String ENCODING_US_ASCII = "US-ASCII"; /** *

The UTF-8 encoding.

*/ public static final String ENCODING_UTF_8 = EncodingUtil.ENCODING_UTF_8; /** *

The ISO-8859-1 encoding.

*/ public static final String ENCODING_ISO_8859_1 = EncodingUtil.ENCODING_ISO_8859_1; /** The default encoding used when none is detected */ public static String DEFAULT_ENCODING = EncodingUtil.ENCODING_ISO_8859_1; /** *

The encoding of URLs.

*/ public static final String URL_ENCODING = ENCODING_US_ASCII; /** LOCKSS home page */ public static String LOCKSS_HOME_URL = "http://www.lockss.org/"; /** Resource dir */ public static String RESOURCE_PATH = "org/lockss/htdocs/"; /** LOCKSS HTTP header, can have multiple values */ public static String X_LOCKSS = "X-Lockss"; /** X-LOCKSS value representing the time the file was originally fetched * from the orign server. (This is unrelated to the Date: header from * the server. The property name is highly misleading and inconsistent * but difficult to change as it already appears in many places.) */ public static String X_LOCKSS_FETCH_TIME = "X_Lockss-server-date"; /** X-LOCKSS value indicating this is a repair request */ public static String X_LOCKSS_REPAIR = "Repair"; /** X-LOCKSS value indicating this response comes from the cache */ public static String X_LOCKSS_FROM_CACHE = "from-cache"; /** Header used in props fetches to supply version info */ public static String X_LOCKSS_INFO = "X-Lockss-Info"; /** Header used with proxy to request content from publisher or cache */ public static String X_LOCKSS_SOURCE = "X-Lockss-Source"; /** Value of {@value #X_LOCKSS_SOURCE} header that requests content only * from the publisher */ public static String X_LOCKSS_SOURCE_PUBLISHER = "publisher"; /** Value of {@value #X_LOCKSS_SOURCE} header that requests content only * from the cache */ public static String X_LOCKSS_SOURCE_CACHE = "cache"; /** Header used with proxy to request content from a specific AU */ public static String X_LOCKSS_AUID = "X-Lockss-Auid"; /** Header in ServeContent response when it serves content from an AU */ public static String X_LOCKSS_FROM_AUID = "X-Lockss-From-Auid"; /** Header in ServeContent response when it serves content from the * publisher, which has been rewritten because it logically belongs to * the AU, but wasn't actually served from the cache (because it's * missing or the publisher has more recent content */ public static String X_LOCKSS_REWRITTEN_FOR_AUID = "X-Lockss-Rewritten-For-Auid"; /** The local address to which to the proxy should bind the socket for * outgoing requests */ public static String X_LOCKSS_LOCAL_ADDRESS = "X-Lockss-Local-Addr"; /** The real identity of a repairer sending a request to localhost, for * testing */ public static String X_LOCKSS_REAL_ID = "X-Lockss-Id"; /** The real identity of a repairer sending a request to localhost, for * testing */ public static String HTTP_REFERER = "Referer"; // Cookie policies. /** Cookie policy: ignore cookies */ public static String COOKIE_POLICY_IGNORE = "ignore"; /** Cookie policy: Netscape draft policy */ public static String COOKIE_POLICY_NETSCAPE = "netscape"; /** Cookie policy: Common browser compatibility */ public static String COOKIE_POLICY_COMPATIBILITY = "compatibility"; /** Cookie policy: RFC 2109 */ public static String COOKIE_POLICY_RFC_2109 = "rfc2109"; // Colors public static final String COLOR_WHITE = "#ffffff"; public static final String COLOR_BLACK = "#000000"; public static final String COLOR_RED = "#ff0000"; public static final String COLOR_ORANGE = "#ff6600"; // Exit codes /** Exit code - normal exit */ public static int EXIT_CODE_NORMAL = 0; /** Exit code - thread hung */ public static int EXIT_CODE_THREAD_HUNG = 101; /** Exit code - thread died */ public static int EXIT_CODE_THREAD_EXIT = 102; /** Exit code - unsupported Java version */ public static int EXIT_CODE_JAVA_VERSION = 103; /** Exit code - exception thrown in main loop */ public static int EXIT_CODE_EXCEPTION_IN_MAIN = 104; /** Exit code - required resource unavailable */ public static int EXIT_CODE_RESOURCE_UNAVAILABLE = 105; /** Exit code - critical keystore missing or not loadable (wrong * password, missing password file) */ public static int EXIT_CODE_KEYSTORE_MISSING = 106; /** Exit code - invalid time zone data */ public static int EXIT_INVALID_TIME_ZONE_DATA = 107; /** Exit code - invalid command line */ public static int EXIT_INVALID_COMMAND_LINE = 108; /** Regexp contexts. Depending on the type of string a regexp will be * used to match against, printf arguments substituted into a pattern * template may need custom escaping. * @see org.lockss.plugin.PrintfConverter */ enum RegexpContext { /** Regexp wil be used to match against unencoded strings */ String, /** Regexp will be used to match against URL-encoded URLs */ Url, }; /** The MIME type string for HTML ({@value}). */ public static final String MIME_TYPE_HTML = "text/html"; /** The MIME type string for JSON ({@value}) */ public static final String MIME_TYPE_JSON = "application/json"; /** The MIME type string for PDF ({@value}). */ public static final String MIME_TYPE_PDF = "application/pdf"; /** The MIME type string for XML ({@value}). */ public static final String MIME_TYPE_XML = "text/xml"; /** The MIME type string for browser PAC files ({@value}). */ public static final String MIME_TYPE_PAC = "application/x-ns-proxy-autoconfig"; /** The MIME type string for RealAudio Media ({@value}). */ public static String MIME_TYPE_RAM = "audio/x-pn-realaudio"; /** The MIME type string for RIS citation files ({@value}). */ public static String MIME_TYPE_RIS = "application/x-research-info-systems"; /** The Form Encoding type string for a "get" or "post" as url ({@value}). */ public static String FORM_ENCODING_URL = "application/x-www-form-urlencoded"; /** The Form Encoding type string for binary "post" ({@value}). */ public static String FORM_ENCODING_DATA = "multipart/form-data"; /** Form Encoding type string for plain "post" ({@value}). */ public static String FORM_ENCODING_PLAIN = "text/plain"; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy