/*
* Copyright (c) 2008, WSO2 Inc. (http://www.wso2.org) 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 org.wso2.carbon.governance.api.services.dataobjects;
import org.wso2.carbon.governance.api.common.dataobjects.GovernanceArtifact;
import org.wso2.carbon.governance.api.endpoints.dataobjects.Endpoint;
import org.wso2.carbon.governance.api.exception.GovernanceException;
import org.wso2.carbon.governance.api.policies.dataobjects.Policy;
import org.wso2.carbon.governance.api.schema.dataobjects.Schema;
import org.wso2.carbon.governance.api.wsdls.dataobjects.Wsdl;
public interface Service extends GovernanceArtifact {
/**
* Attach a policy artifact to a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param policy the policy to attach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
void attachPolicy(Policy policy) throws GovernanceException;
/**
* Detach a policy artifact from a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param policyId the identifier of the policy to detach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
@SuppressWarnings("unused")
void detachPolicy(String policyId) throws GovernanceException;
/**
* Method to retrieve all policies attached to this service artifact.
*
* @return all policies attached to this service artifact.
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
Policy[] getAttachedPolicies() throws GovernanceException;
/**
* Attach a schema artifact to a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param schema the schema to attach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
@SuppressWarnings("unused")
void attachSchema(Schema schema) throws GovernanceException;
/**
* Detach a schema artifact from a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param schemaId the identifier of the schema to detach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
@SuppressWarnings("unused")
void detachSchema(String schemaId) throws GovernanceException;
/**
* Method to retrieve all schemas attached to this service artifact.
*
* @return all schemas attached to this service artifact.
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
@SuppressWarnings("unused")
Schema[] getAttachedSchemas() throws GovernanceException;
/**
* Attach a WSDL artifact to a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param wsdl the WSDL to attach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
void attachWSDL(Wsdl wsdl) throws GovernanceException;
/**
* Detach a WSDL artifact from a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param wsdlId the identifier of the WSDL to detach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
@SuppressWarnings("unused")
void detachWSDL(String wsdlId) throws GovernanceException;
/**
* Method to retrieve all WSDLs attached to this service artifact.
*
* @return all WSDLs attached to this service artifact.
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
Wsdl[] getAttachedWsdls() throws GovernanceException;
/**
* Attach an endpoint artifact to a service artifact. Both the artifacts should be saved, before
* calling this method.
*
* @param endpoint the endpoint to attach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
void attachEndpoint(Endpoint endpoint) throws GovernanceException;
/**
* Detach an endpoint artifact from a service artifact. Both the artifacts should be saved,
* before calling this method.
*
* @param endpointId the identifier of the endpoint to detach.
*
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
void detachEndpoint(String endpointId) throws GovernanceException;
/**
* Method to retrieve all endpoints attached to this service artifact.
*
* @return all endpoints attached to this service artifact.
* @throws org.wso2.carbon.governance.api.exception.GovernanceException if the operation failed.
*/
Endpoint[] getAttachedEndpoints() throws GovernanceException;
/**
* Method to activate this service.
* @deprecated since active functionality is no longer used.
*
* @throws GovernanceException if the operation failed.
*/
void activate() throws GovernanceException;
/**
* Method to deactivate this service.
* @deprecated since active functionality is no longer used.
*
* @throws GovernanceException if the operation failed.
*/
void deactivate() throws GovernanceException;
/**
* Method to obtain whether this service is active or not.
* @deprecated since active functionality is no longer used.
*
* @return true if this service is active, and false if not.
* @throws GovernanceException if the operation failed.
*/
boolean isActive() throws GovernanceException;
}