001/*
002 * $Id: XmpSchema.java 4784 2011-03-15 08:33:00Z blowagie $
003 *
004 * This file is part of the iText (R) project.
005 * Copyright (c) 1998-2011 1T3XT BVBA
006 * Authors: Bruno Lowagie, Paulo Soares, et al.
007 *
008 * This program is free software; you can redistribute it and/or modify
009 * it under the terms of the GNU Affero General Public License version 3
010 * as published by the Free Software Foundation with the addition of the
011 * following permission added to Section 15 as permitted in Section 7(a):
012 * FOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY 1T3XT,
013 * 1T3XT DISCLAIMS THE WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
014 *
015 * This program is distributed in the hope that it will be useful, but
016 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
017 * or FITNESS FOR A PARTICULAR PURPOSE.
018 * See the GNU Affero General Public License for more details.
019 * You should have received a copy of the GNU Affero General Public License
020 * along with this program; if not, see http://www.gnu.org/licenses or write to
021 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
022 * Boston, MA, 02110-1301 USA, or download the license from the following URL:
023 * http://itextpdf.com/terms-of-use/
024 *
025 * The interactive user interfaces in modified source and object code versions
026 * of this program must display Appropriate Legal Notices, as required under
027 * Section 5 of the GNU Affero General Public License.
028 *
029 * In accordance with Section 7(b) of the GNU Affero General Public License,
030 * a covered work must retain the producer line in every PDF that is created
031 * or manipulated using iText.
032 *
033 * You can be released from the requirements of the license by purchasing
034 * a commercial license. Buying such a license is mandatory as soon as you
035 * develop commercial activities involving the iText software without
036 * disclosing the source code of your own applications.
037 * These activities include: offering paid services to customers as an ASP,
038 * serving PDFs on the fly in a web application, shipping iText with a closed
039 * source product.
040 *
041 * For more information, please contact iText Software Corp. at this
042 * address: sales@itextpdf.com
043 */
044package com.itextpdf.text.xml.xmp;
045
046import java.util.Enumeration;
047import java.util.Properties;
048
049/**
050 * Abstract superclass of the XmpSchemas supported by iText.
051 */
052public abstract class XmpSchema extends Properties {
053
054        private static final long serialVersionUID = -176374295948945272L;
055
056        /** the namesspace */
057        protected String xmlns;
058
059        /** Constructs an XMP schema.
060         * @param xmlns
061         */
062        public XmpSchema(String xmlns) {
063                super();
064                this.xmlns = xmlns;
065        }
066        /**
067         * The String representation of the contents.
068         * @return a String representation.
069         */
070        @Override
071    public String toString() {
072                StringBuffer buf = new StringBuffer();
073                for (Enumeration<?> e = this.propertyNames(); e.hasMoreElements(); ) {
074                        process(buf, e.nextElement());
075                }
076                return buf.toString();
077        }
078        /**
079         * Processes a property
080         * @param buf
081         * @param p
082         */
083        protected void process(StringBuffer buf, Object p) {
084                buf.append('<');
085                buf.append(p);
086                buf.append('>');
087                buf.append(this.get(p));
088                buf.append("</");
089                buf.append(p);
090                buf.append('>');
091        }
092        /**
093         * @return Returns the xmlns.
094         */
095        public String getXmlns() {
096                return xmlns;
097        }
098
099        /**
100         * @param key
101         * @param value
102         * @return the previous property (null if there wasn't one)
103         */
104        public Object addProperty(String key, String value) {
105                return this.setProperty(key, value);
106        }
107
108        /**
109         * @see java.util.Properties#setProperty(java.lang.String, java.lang.String)
110         */
111        @Override
112    public Object setProperty(String key, String value) {
113                return super.setProperty(key, escape(value));
114        }
115
116        /**
117         * @see java.util.Properties#setProperty(java.lang.String, java.lang.String)
118         *
119         * @param key
120         * @param value
121         * @return the previous property (null if there wasn't one)
122         */
123        public Object setProperty(String key, XmpArray value) {
124                return super.setProperty(key, value.toString());
125        }
126
127        /**
128         * @see java.util.Properties#setProperty(java.lang.String, java.lang.String)
129         *
130         * @param key
131         * @param value
132         * @return the previous property (null if there wasn't one)
133         */
134        public Object setProperty(String key, LangAlt value) {
135                return super.setProperty(key, value.toString());
136         }
137
138        /**
139         * @param content
140         * @return an escaped string
141         */
142        public static String escape(String content) {
143                StringBuffer buf = new StringBuffer();
144                for (int i = 0; i < content.length(); i++) {
145                        switch(content.charAt(i)) {
146                        case '<':
147                                buf.append("&lt;");
148                                break;
149                        case '>':
150                                buf.append("&gt;");
151                                break;
152                        case '\'':
153                                buf.append("&apos;");
154                                break;
155                        case '\"':
156                                buf.append("&quot;");
157                                break;
158                        case '&':
159                                buf.append("&amp;");
160                                break;
161                        default:
162                                buf.append(content.charAt(i));
163                        }
164                }
165                return buf.toString();
166        }
167}