/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you 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.apache.synapse.config; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.apache.synapse.SynapseArtifact; import org.apache.synapse.SynapseException; import java.net.URL; import java.util.Properties; /** * Represents an Entry contained in the local registry used by Synapse * * @see org.apache.synapse.config.SynapseConfiguration#localRegistry */ public class Entry implements SynapseArtifact { private static final Log log = LogFactory.getLog(Entry.class); /** The key of the entry */ private String key; /** The type of the entry */ private int type; /** Source URL of the entry if it is a URL_SRC */ private URL src; /** The value of the entry. This can be either an OMElement or an String */ private Object value; /** An XML to Object mapper - if one is available */ private XMLToObjectMapper mapper; /** The version of the cached resource */ private long version; /** The local expiry time for the cached resource */ private long expiryTime; /** The name of the file where this entry is defined */ private String fileName; /** The description of the local entry */ private String description; /** The artifact container name of the local entry was deployed from */ private String artifactContainerName; /** Whether the artifact edited via management console or not */ private boolean isEdited; /** * Registry resource properties */ private Properties entryProperties; public Entry() {} public Entry(String key) { this.key = key; } public int getType() { return type; } public boolean isRemote() { return type == REMOTE_ENTRY; } public boolean isURLSource() { return type == URL_SRC; } public boolean isInlineXML() { return type == INLINE_XML; } public boolean isInlineText() { return type == INLINE_TEXT; } public void setType(int type) { if (type <= 4 && type >= 0) { this.type = type; } else { handleException("Invalid entry type for the static entry"); } } public URL getSrc() { return src; } public void setSrc(URL src) { this.src = src; } public String getKey() { return this.key; } public void setKey(String key) { this.key = key; } /** * Gets the value of the entry. String if the type is INLINE_TEXT or VALUE_TYPE, * OMElement otherwise. * @return Either an OMElement or a String */ public Object getValue() { return value; } public void setValue(Object value) { this.value = value; } /** * * @return mapper */ public XMLToObjectMapper getMapper() { return mapper; } /** * Set the mapper * * @param mapper XMLToObjectMapper instance */ public void setMapper(XMLToObjectMapper mapper) { this.mapper = mapper; } public long getVersion() { return version; } public void setVersion(long version) { this.version = version; } public long getExpiryTime() { return expiryTime; } public void setExpiryTime(long expiryTime) { this.expiryTime = expiryTime; } public String getFileName() { return fileName; } public void setFileName(String fileName) { this.fileName = fileName; } public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } public Properties getEntryProperties() { return entryProperties; } public void setEntryProperties(Properties entryProperties) { this.entryProperties = entryProperties; } public boolean isExpired() { return getType() == REMOTE_ENTRY && getExpiryTime() > 0 && System.currentTimeMillis() > expiryTime; } public boolean isCached() { if (value != null) { return true; } else if (entryProperties != null) { if (!entryProperties.isEmpty()) { return true; } } return false; } public void clearCache() { if (this.isDynamic()) { value = null; expiryTime = System.currentTimeMillis(); } } public boolean isDynamic() { return type == REMOTE_ENTRY; } private void handleException(String msg) { log.error(msg); throw new SynapseException(msg); } public String getArtifactContainerName() { return artifactContainerName; } public void setArtifactContainerName(String artifactContainerName) { this.artifactContainerName = artifactContainerName; } public boolean getIsEdited() { return isEdited; } public void setIsEdited(boolean isEdited) { this.isEdited = isEdited; } public static final int INLINE_TEXT = 0; public static final int INLINE_XML = 1; public static final int URL_SRC = 2; public static final int REMOTE_ENTRY = 3; }