org.glassfish.maven.plugin.command.CreateJDBCConnectionPoolCommand Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of maven-glassfish-plugin Show documentation
Show all versions of maven-glassfish-plugin Show documentation
The Glassfish Maven Plugin is a Maven2 plugin allowing management of Glassfish domains and component deployments
from within the Maven build lifecycle. It encapsulates domain configuration and deployment attributes within the build
configuration for a more rapid development integration loop and simplified management of continuous integration testing of
components destined for deployment within the Glassfish V2 and later JavaEE containers.
The newest version!
/*******************************************************************************
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2007-2008 maven-glassfish-plugin developers. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can obtain
* a copy of the License at https://glassfish.dev.java.net/public/CDDL+GPL.html
* or glassfish/bootstrap/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at glassfish/bootstrap/legal/LICENSE.txt.
* Sun designates this particular file as subject to the "Classpath" exception
* as provided by the copyright holder in the GPL Version 2 section of the
* License file that accompanied this code. If applicable, add the following
* below the License Header, with the fields enclosed by brackets [] replaced
* by your own identifying information:
* "Portions Copyrighted [year] [name of copyright owner]"
*
* Contributor(s):
*
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
******************************************************************************/
package org.glassfish.maven.plugin.command;
import org.glassfish.maven.plugin.Domain;
import org.glassfish.maven.plugin.GlassfishMojo;
import org.glassfish.maven.plugin.JdbcDataSource;
import java.util.Arrays;
import java.util.List;
/**
* Created by dwhitla at Apr 10, 2007 1:21:52 PM
*
* @author Dave Whitla
* @version $Id: CreateJDBCConnectionPoolCommand.java 0 Apr 10, 2007 1:21:52 PM dwhitla $
*/
public class CreateJDBCConnectionPoolCommand extends InteractiveAsadminCommand {
private Domain domain;
private JdbcDataSource jdbcDataSource;
public CreateJDBCConnectionPoolCommand(GlassfishMojo sharedContext, Domain domain, JdbcDataSource jdbcDataSource) {
super(sharedContext);
this.domain = domain;
this.jdbcDataSource = jdbcDataSource;
}
protected String getName() {
return "create-jdbc-connection-pool";
}
protected List getParameters() {
List parameters = super.getParameters();
parameters.addAll(Arrays.asList(
"--port", String.valueOf(domain.getAdminPort()),
"--restype", jdbcDataSource.getType().toString(),
"--validationmethod", jdbcDataSource.getValidationMethod(),
"--allownoncomponentcallers=" + jdbcDataSource.isAllowNonComponentCallers(),
"--isconnectvalidatereq=" + jdbcDataSource.isValidateConnections(),
"--failconnection=" + jdbcDataSource.isFailConnection(),
"--nontransactionalconnections=" + jdbcDataSource.isNonTransactionalConnections(),
"--idletimeout", String.valueOf(jdbcDataSource.getIdleTimeout()),
//"--isisolationguaranteed", String.valueOf(jdbcDataSource.isIsolationGuaranteed()),
"--steadypoolsize", String.valueOf(jdbcDataSource.getSteadyPoolSize()),
"--poolresize", String.valueOf(jdbcDataSource.getPoolResize()),
"--maxpoolsize", String.valueOf(jdbcDataSource.getMaxPoolSize()),
"--maxwait", String.valueOf(jdbcDataSource.getMaxWait()),
"--datasourceclassname", jdbcDataSource.getClassName(),
"--description", jdbcDataSource.getDescription()
));
addProperties(parameters, jdbcDataSource.getProperties());
parameters.add(jdbcDataSource.getPoolName());
return parameters;
}
protected String getErrorMessage() {
return "Unable to create JDBC connection pool " + jdbcDataSource.getPoolName() + ".";
}
}