001    /**
002     * Copyright 2004-2013 The Kuali Foundation
003     *
004     * Licensed under the Educational Community License, Version 2.0 (the "License");
005     * you may not use this file except in compliance with the License.
006     * You may obtain a copy of the License at
007     *
008     * http://www.opensource.org/licenses/ecl2.php
009     *
010     * Unless required by applicable law or agreed to in writing, software
011     * distributed under the License is distributed on an "AS IS" BASIS,
012     * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013     * See the License for the specific language governing permissions and
014     * limitations under the License.
015     */
016    package org.apache.torque.mojo;
017    
018    import java.util.Properties;
019    
020    import org.apache.commons.lang.StringUtils;
021    import org.apache.maven.plugin.MojoExecutionException;
022    import org.apache.maven.plugin.descriptor.PluginDescriptor;
023    import org.apache.torque.util.JdbcConfigurer;
024    import org.kuali.core.db.torque.DumpTask;
025    import org.kuali.core.db.torque.PropertyHandlingException;
026    import org.kuali.core.db.torque.StringFilter;
027    
028    /**
029     * Base Mojo for export related functionality
030     */
031    public abstract class ExportMojo extends AntTaskMojo {
032    
033        /**
034         * Additional properties for the JDBC driver
035         *
036         * @parameter
037         */
038        private Properties driverProperties;
039    
040        /**
041         * If true, files will be exported in a format that the Ant impex tasks can understand
042         *
043         * @parameter expression="${antCompatibilityMode}" default-value="false"
044         */
045        private boolean antCompatibilityMode;
046    
047        /**
048         * The Maven artifactId. Included here as a simple property of the mojo itself to facilitate usage of
049         * <code>BeanUtils.copyProperties()</code> to copy properties between Mojo's and Ant tasks
050         *
051         * @parameter expression="${artifactId}" default-value="${project.artifactId}"
052         * @required
053         */
054        private String artifactId;
055    
056        /**
057         * By default the version of the maven plugin being used during the build will be included as part of a comment in
058         * the XML. Set this to false to prevent this. Useful if you are committing files to SCM and don't want a change in
059         * the version of the plugin to show up as a change to the data.
060         *
061         * @parameter expression="${includeVersionInComment}" default-value="true"
062         * @required
063         */
064        private boolean includeVersionInComment;
065    
066        /**
067         * Additional comment that gets placed into the generated XML document. Anything included here gets appended to the
068         * default value <br>
069         * <b>Default value is:</b> Auto-generated by the maven-impex-plugin v1.0.2<br>
070         *
071         * @parameter expression="${comment}"
072         */
073        private String comment;
074    
075        /**
076         * Comma separated list of regular expressions for tables to include in the export
077         *
078         * @parameter expression="${includes}"
079         */
080        private String includes;
081    
082        /**
083         * Comma separated list of regular expressions for tables to exclude from the export
084         *
085         * @parameter expression="${excludes}"
086         */
087        private String excludes;
088    
089        /**
090         * The type of database we are targeting (eg oracle, mysql). This is optional if <code>url</code> is supplied as the
091         * database type will be automatically detected based on the <code>url</code>. If targetDatabase is explicitly
092         * supplied it will override the type selected by the automatic detection logic.
093         *
094         * @parameter expression="${targetDatabase}"
095         */
096        private String targetDatabase;
097    
098        /**
099         * The schema to export. This parameter is optional, as the schema to export is automatically derived from platform
100         * specific logic that converts the artifactId.<br>
101         * <br>
102         * For example:<br>
103         * ks-embedded-db becomes KSEMBEDDED for Oracle, and ksembedded for MySQL If <code>schema</code> is supplied, the
104         * supplied value will be used instead of the value derived from the artifactId
105         *
106         * @parameter expression="${schema}"
107         */
108        private String schema;
109    
110        /**
111         * Database driver classname. This parameter is optional, as the correct JDBC driver to use is detected from the
112         * <code>url</code> in almost all cases (works for Oracle, MySQL, Derby, PostGresSQL, DB2, H2, HSQL, SQL Server). If
113         * a driver is explicitly supplied, it will be used in place of the JDBC driver the automatic detection logic would
114         * have chosen.
115         *
116         * @parameter expression="${driver}"
117         */
118        private String driver;
119    
120        /**
121         * The connect URL of the database.
122         *
123         * @parameter expression="${url}"
124         * @required
125         */
126        private String url;
127    
128        /**
129         * The user name to connect to the database. If not specified this is automatically generated by platform specific
130         * logic for converting the artifact id.<br>
131         * <br>
132         * For example:<br>
133         * ks-embedded-db becomes KSEMBEDDED for Oracle and ksembedded for MySQL
134         *
135         * @parameter expression="${username}"
136         */
137        private String username;
138    
139        /**
140         * The password for the database user. If not specified this is automatically generated by platform specific logic
141         * for converting the artifact id.<br>
142         * <br>
143         * For example:<br>
144         * ks-embedded-db becomes KSEMBEDDED for Oracle and ksembedded for MySQL
145         *
146         * @parameter expression="${password}"
147         */
148        private String password;
149    
150        /**
151         * Returns the fully qualified class name of the database driver.
152         */
153        public String getDriver() {
154            return driver;
155        }
156    
157        /**
158         * Sets the fully qualified class name of the database driver.
159         *
160         * @param driver
161         *            the fully qualified class name of the database driver.
162         */
163        public void setDriver(final String driver) {
164            this.driver = driver;
165        }
166    
167        /**
168         * Returns the password of the database user.
169         *
170         * @return the password of the database user.
171         */
172        public String getPassword() {
173            return password;
174        }
175    
176        /**
177         * Sets the password of the database user.
178         *
179         * @param password
180         *            the password of the database user.
181         */
182        public void setPassword(final String password) {
183            this.password = password;
184        }
185    
186        /**
187         * Returns the connect URL to the database.
188         *
189         * @return the connect URL to the database.
190         */
191        public String getUrl() {
192            return url;
193        }
194    
195        /**
196         * Sets the connect URL to the database.
197         *
198         * @param url
199         *            the connect URL to the database.
200         */
201        public void setUrl(final String url) {
202            this.url = url;
203        }
204    
205        public String getUsername() {
206            return username;
207        }
208    
209        public void setUsername(final String username) {
210            this.username = username;
211        }
212    
213        public String getSchema() {
214            return schema;
215        }
216    
217        public void setSchema(final String schema) {
218            this.schema = schema;
219        }
220    
221        public String getTargetDatabase() {
222            return targetDatabase;
223        }
224    
225        public void setTargetDatabase(final String targetDatabase) {
226            this.targetDatabase = targetDatabase;
227        }
228    
229        public String getIncludes() {
230            return includes;
231        }
232    
233        public void setIncludes(final String includePatterns) {
234            this.includes = includePatterns;
235        }
236    
237        public String getExcludes() {
238            return excludes;
239        }
240    
241        public void setExcludes(final String excludePatterns) {
242            this.excludes = excludePatterns;
243        }
244    
245        public String getComment() {
246            return comment;
247        }
248    
249        public void setComment(final String comment) {
250            this.comment = comment;
251        }
252    
253        protected String getUpdatedComment() {
254            PluginDescriptor descriptor = (PluginDescriptor) this.getPluginContext().get("pluginDescriptor");
255            if (descriptor == null) {
256                // This is null for Maven 2.x
257                return " Auto-generated by the maven-impex-plugin " + getComment();
258            }
259            String name = descriptor.getName();
260            String version = descriptor.getVersion();
261            String comment = " Auto-generated by the " + name;
262            if (isIncludeVersionInComment()) {
263                comment += " v" + version + " ";
264            }
265            if (!StringUtils.isEmpty(getComment())) {
266                comment += getComment();
267            }
268            return comment;
269        }
270    
271        @Override
272        protected void configureTask() throws MojoExecutionException {
273            setComment(getUpdatedComment());
274            try {
275                JdbcConfigurer configurer = new JdbcConfigurer();
276                configurer.updateConfiguration(this);
277                configurer.validateConfiguration(this);
278            } catch (PropertyHandlingException e) {
279                throw new MojoExecutionException("Error handling properties", e);
280            }
281            super.configureTask();
282            DumpTask task = (DumpTask) super.getAntTask();
283            task.setIncludePatterns(StringFilter.getListFromCSV(getIncludes()));
284            task.setExcludePatterns(StringFilter.getListFromCSV(getExcludes()));
285            task.setDriverProperties(driverProperties);
286        }
287    
288        public String getArtifactId() {
289            return artifactId;
290        }
291    
292        public void setArtifactId(final String artifactId) {
293            this.artifactId = artifactId;
294        }
295    
296        public boolean isAntCompatibilityMode() {
297            return antCompatibilityMode;
298        }
299    
300        public void setAntCompatibilityMode(final boolean antCompatibilityMode) {
301            this.antCompatibilityMode = antCompatibilityMode;
302        }
303    
304        /**
305         * @return the includeVersionInComment
306         */
307        public boolean isIncludeVersionInComment() {
308            return includeVersionInComment;
309        }
310    
311        /**
312         * @param includeVersionInComment
313         *            the includeVersionInComment to set
314         */
315        public void setIncludeVersionInComment(final boolean includeVersionInComment) {
316            this.includeVersionInComment = includeVersionInComment;
317        }
318    
319        public Properties getDriverProperties() {
320            return driverProperties;
321        }
322    
323        public void setDriverProperties(Properties driverProperties) {
324            this.driverProperties = driverProperties;
325        }
326    }