// --- BEGIN COPYRIGHT BLOCK --- // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation; version 2 of the License. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License along // with this program; if not, write to the Free Software Foundation, Inc., // 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. // // (C) 2007 Red Hat, Inc. // All rights reserved. // --- END COPYRIGHT BLOCK --- package com.netscape.certsrv.request; /** * The RequestStatus class represents the current state of a request in a * request queue. The state of the request changes as actions are performed on * it. * * The request is created in the BEGIN state, then general progresses through * the PENDING, APPROVED, SVC_PENDING, and COMPLETE states. Some requests may * bypass the PENDING state if no agent action is required. * * Requests may be CANCELED (not implemented) or REJECTED. These are error * conditions, and usually result because the request was invalid or was not * approved by an agent. * * @version $Revision$ $Date$ */ public final class RequestStatus { public static String BEGIN_STRING = "begin"; public static String PENDING_STRING = "pending"; public static String APPROVED_STRING = "approved"; public static String SVC_PENDING_STRING = "svc_pending"; public static String CANCELED_STRING = "canceled"; public static String REJECTED_STRING = "rejected"; public static String COMPLETE_STRING = "complete"; /** * The initial state of a request. Requests in this state have not been * review by policy. * * While in this state the source of the request (usually the servlet, but * it could be some other protocol module, such as email) should populate * the request with data need to service it. */ public static RequestStatus BEGIN = new RequestStatus(BEGIN_STRING); /** * The state of a request that is waiting for action by an agent. When the * agent approves or rejects the request, process will continue as * appropriate. * * In this state there may be PolicyMessages present that indicate the * reason for the pending status. */ public static RequestStatus PENDING = new RequestStatus(PENDING_STRING); /** * The state of a request that has been approved by an agent, or * automatically by the policy engine, but have not been successfully * transmitted to the service module. * * These requests are resent to the service during the recovery process that * runs at server startup. */ public static RequestStatus APPROVED = new RequestStatus(APPROVED_STRING); /** * The state of a request that has been sent to the service, but has not * been fully processed. The service will invoke the serviceComplete() * method to cause processing to continue. */ public static RequestStatus SVC_PENDING = new RequestStatus( SVC_PENDING_STRING); /** * Not implemented. This is intended to be a final state that is reached * when a request is removed from the processing queue without normal * notification occurring. (see REJECTED) */ public static RequestStatus CANCELED = new RequestStatus(CANCELED_STRING); /** * The state of a request after it is rejected. When a request is rejected, * the notifier is called prior to making the finl status change. * * Rejected requests may have PolicyMessages indicating the reason for the * rejection, or AgentMessages, which allow the agent to give reasons for * the action. */ public static RequestStatus REJECTED = new RequestStatus(REJECTED_STRING); /** * The normal final state of a request. The completion status attribute * gives other information about the request. The request is not necessarily * successful, but may indicated that service processing did not succeed. */ public static RequestStatus COMPLETE = new RequestStatus(COMPLETE_STRING); /** * Converts a string name for a request status into the request status enum * object. *

* * @param s The string representation of the state. * @return request status */ public static RequestStatus fromString(String s) { if (s.equals(BEGIN_STRING)) return BEGIN; if (s.equals(PENDING_STRING)) return PENDING; if (s.equals(APPROVED_STRING)) return APPROVED; if (s.equals(SVC_PENDING_STRING)) return SVC_PENDING; if (s.equals(CANCELED_STRING)) return CANCELED; if (s.equals(REJECTED_STRING)) return REJECTED; if (s.equals(COMPLETE_STRING)) return COMPLETE; return null; } /** * Returns the string form of the RequestStatus, which may be used to record * the status in a database. * * @return request status */ public String toString() { return mString; } /** * Class constructor. Creates request status from the string. * * @param string string describing request status */ private RequestStatus(String string) { mString = string; } private String mString; /** * Compares request status with specified string. * * @param string string describing request status */ public boolean equals(String string) { if (string.equals(mString)) return true; else return false; } /** * Compares current request status with request status. * * @param rs request status */ public boolean equals(RequestStatus rs) { if (mString.equals(rs.mString)) return true; else return false; } }