KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > opencms > file > collectors > A_CmsResourceCollector


1 /*
2  * File : $Source: /usr/local/cvs/opencms/src/org/opencms/file/collectors/A_CmsResourceCollector.java,v $
3  * Date : $Date: 2006/10/18 09:20:05 $
4  * Version: $Revision: 1.10 $
5  *
6  * This library is part of OpenCms -
7  * the Open Source Content Mananagement System
8  *
9  * Copyright (c) 2005 Alkacon Software GmbH (http://www.alkacon.com)
10  *
11  * This library is free software; you can redistribute it and/or
12  * modify it under the terms of the GNU Lesser General Public
13  * License as published by the Free Software Foundation; either
14  * version 2.1 of the License, or (at your option) any later version.
15  *
16  * This library is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19  * Lesser General Public License for more details.
20  *
21  * For further information about Alkacon Software GmbH, please see the
22  * company website: http://www.alkacon.com
23  *
24  * For further information about OpenCms, please see the
25  * project website: http://www.opencms.org
26  *
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30  */

31
32 package org.opencms.file.collectors;
33
34 import org.opencms.file.CmsDataAccessException;
35 import org.opencms.file.CmsObject;
36 import org.opencms.file.CmsResource;
37 import org.opencms.file.CmsResourceFilter;
38 import org.opencms.main.CmsException;
39 import org.opencms.main.CmsIllegalArgumentException;
40 import org.opencms.util.CmsMacroResolver;
41 import org.opencms.util.PrintfFormat;
42 import org.opencms.workplace.CmsWorkplace;
43
44 import java.util.ArrayList JavaDoc;
45 import java.util.List JavaDoc;
46
47 /**
48  * Provides some helpful base implementations for resource collector classes.<p>
49  *
50  * @author Alexander Kandzior
51  *
52  * @version $Revision: 1.10 $
53  *
54  * @since 6.0.0
55  */

56 public abstract class A_CmsResourceCollector implements I_CmsResourceCollector {
57
58     /** The "number" macro. */
59     private static final String JavaDoc MACRO_NUMBER = "number";
60
61     /** Format for file create parameter. */
62     private static final PrintfFormat NUMBER_FORMAT = new PrintfFormat("%0.4d");
63
64     /** The collector order of this collector. */
65     protected int m_order;
66
67     /** The name of the configured default collector. */
68     private String JavaDoc m_defaultCollectorName;
69
70     /** The default collector parameters. */
71     private String JavaDoc m_defaultCollectorParam;
72
73     /** The hash code of this collector. */
74     private int m_hashcode;
75
76     /**
77      * Constructor to initialize some default values.<p>
78      */

79     public A_CmsResourceCollector() {
80
81         m_hashcode = getClass().getName().hashCode();
82     }
83
84     /**
85      * @see java.lang.Comparable#compareTo(java.lang.Object)
86      */

87     public int compareTo(Object JavaDoc obj) {
88
89         if (obj == this) {
90             return 0;
91         }
92         if (obj instanceof I_CmsResourceCollector) {
93             return getOrder() - ((I_CmsResourceCollector)obj).getOrder();
94         }
95         return 0;
96     }
97
98     /**
99      * Two collectors are considered to be equal if they are sharing the same
100      * implementation class.<p>
101      *
102      * @see java.lang.Object#equals(java.lang.Object)
103      */

104     public boolean equals(Object JavaDoc obj) {
105
106         if (obj == this) {
107             return true;
108         }
109         if (obj instanceof I_CmsResourceCollector) {
110             return getClass().getName().equals(obj.getClass().getName());
111         }
112         return false;
113     }
114
115     /**
116      * @see org.opencms.file.collectors.I_CmsResourceCollector#getCreateLink(org.opencms.file.CmsObject)
117      */

118     public String JavaDoc getCreateLink(CmsObject cms) throws CmsException, CmsDataAccessException {
119
120         checkParams();
121         return getCreateLink(cms, getDefaultCollectorName(), getDefaultCollectorParam());
122     }
123
124     /**
125      * @see org.opencms.file.collectors.I_CmsResourceCollector#getCreateParam(org.opencms.file.CmsObject)
126      */

127     public String JavaDoc getCreateParam(CmsObject cms) throws CmsDataAccessException {
128
129         checkParams();
130         return getCreateParam(cms, getDefaultCollectorName(), getDefaultCollectorParam());
131     }
132
133     /**
134      * @see org.opencms.file.collectors.I_CmsResourceCollector#getDefaultCollectorName()
135      */

136     public String JavaDoc getDefaultCollectorName() {
137
138         return m_defaultCollectorName;
139     }
140
141     /**
142      * @see org.opencms.file.collectors.I_CmsResourceCollector#getDefaultCollectorParam()
143      */

144     public String JavaDoc getDefaultCollectorParam() {
145
146         return m_defaultCollectorParam;
147     }
148
149     /**
150      * @see org.opencms.file.collectors.I_CmsResourceCollector#getOrder()
151      */

152     public int getOrder() {
153
154         return m_order;
155     }
156
157     /**
158      * @see org.opencms.file.collectors.I_CmsResourceCollector#getResults(org.opencms.file.CmsObject)
159      */

160     public List JavaDoc getResults(CmsObject cms) throws CmsDataAccessException, CmsException {
161
162         checkParams();
163         return getResults(cms, getDefaultCollectorName(), getDefaultCollectorParam());
164     }
165
166     /**
167      * @see java.lang.Object#hashCode()
168      */

169     public int hashCode() {
170
171         return m_hashcode;
172     }
173
174     /**
175      * @see org.opencms.file.collectors.I_CmsResourceCollector#setDefaultCollectorName(java.lang.String)
176      */

177     public void setDefaultCollectorName(String JavaDoc collectorName) {
178
179         m_defaultCollectorName = collectorName;
180     }
181
182     /**
183      * @see org.opencms.file.collectors.I_CmsResourceCollector#setDefaultCollectorParam(java.lang.String)
184      */

185     public void setDefaultCollectorParam(String JavaDoc param) {
186
187         m_defaultCollectorParam = param;
188     }
189
190     /**
191      * @see org.opencms.file.collectors.I_CmsResourceCollector#setOrder(int)
192      */

193     public void setOrder(int order) {
194
195         m_order = order;
196     }
197
198     /**
199      * Checks if the required parameters have been set.<p>
200      *
201      * @see #setDefaultCollectorName(String)
202      * @see #setDefaultCollectorParam(String)
203      */

204     protected void checkParams() {
205
206         if ((m_defaultCollectorName == null) || (m_defaultCollectorParam == null)) {
207             throw new CmsIllegalArgumentException(Messages.get().container(
208                 Messages.ERR_COLLECTOR_DEFAULTS_INVALID_2,
209                 m_defaultCollectorName,
210                 m_defaultCollectorParam));
211         }
212     }
213
214     /**
215      * Returns the link to create a new XML content item in the folder pointed to by the parameter.<p>
216      *
217      * @param cms the current CmsObject
218      * @param param the folder name to use
219      *
220      * @return the link to create a new XML content item in the folder
221      *
222      * @throws CmsException if something goes wrong
223      */

224     protected String JavaDoc getCreateInFolder(CmsObject cms, String JavaDoc param) throws CmsException {
225
226         CmsCollectorData data = new CmsCollectorData(param);
227
228         String JavaDoc foldername = CmsResource.getFolderPath(data.getFileName());
229
230         // must check ALL resources in folder because name doesn't care for type
231
List JavaDoc resources = cms.readResources(foldername, CmsResourceFilter.ALL, false);
232
233         // now create a list of all resources that just contains the file names
234
List JavaDoc result = new ArrayList JavaDoc(resources.size());
235         for (int i = 0; i < resources.size(); i++) {
236             CmsResource resource = (CmsResource)resources.get(i);
237             result.add(resource.getRootPath());
238         }
239
240         String JavaDoc fileName = cms.getRequestContext().addSiteRoot(data.getFileName());
241         int fileNameLength = fileName.length();
242         String JavaDoc checkFileName;
243         String JavaDoc checkName;
244         StringBuffer JavaDoc checkTempFileName;
245         String JavaDoc number;
246         CmsMacroResolver resolver = CmsMacroResolver.newInstance();
247
248         int j = 0;
249         do {
250             number = NUMBER_FORMAT.sprintf(++j);
251             resolver.addMacro(MACRO_NUMBER, number);
252             checkFileName = resolver.resolveMacros(fileName);
253             // get new resource name without path information
254
checkName = CmsResource.getName(checkFileName);
255             // create temporary file name to check for additionally
256
checkTempFileName = new StringBuffer JavaDoc(fileNameLength);
257             checkTempFileName.append(CmsResource.getFolderPath(checkFileName));
258             checkTempFileName.append(CmsWorkplace.TEMP_FILE_PREFIX);
259             checkTempFileName.append(checkName);
260         } while (result.contains(checkFileName) || result.contains(checkTempFileName.toString()));
261
262         return cms.getRequestContext().removeSiteRoot(checkFileName);
263     }
264
265     /**
266      * Shrinks a List to fit a maximum size.<p>
267      *
268      * @param result a List
269      * @param maxSize the maximum size of the List
270      *
271      * @return the shrinked list
272      */

273     protected List JavaDoc shrinkToFit(List JavaDoc result, int maxSize) {
274
275         if ((maxSize > 0) && (result.size() > maxSize)) {
276             // cut off all items > count
277
result = result.subList(0, maxSize);
278         }
279
280         return result;
281     }
282 }
Popular Tags