/*******************************************************************************
* Copyright (c) 2013, 2015 Oracle and/or its affiliates. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Guy Pelletier - initial API and implementation
******************************************************************************/
package org.eclipse.persistence.internal.jpa.config.partitioning;
import java.util.ArrayList;
import org.eclipse.persistence.internal.jpa.config.MetadataImpl;
import org.eclipse.persistence.internal.jpa.config.columns.ColumnImpl;
import org.eclipse.persistence.internal.jpa.metadata.partitioning.HashPartitioningMetadata;
import org.eclipse.persistence.jpa.config.Column;
import org.eclipse.persistence.jpa.config.HashPartitioning;
/**
* JPA scripting API implementation.
*
* @author Guy Pelletier
* @since EclipseLink 2.5.1
*/
public class HashPartitioningImpl extends MetadataImpl<HashPartitioningMetadata> implements HashPartitioning {
public HashPartitioningImpl() {
super(new HashPartitioningMetadata());
getMetadata().setConnectionPools(new ArrayList<String>());
}
public HashPartitioning addConnectionPool(String connectionPool) {
getMetadata().getConnectionPools().add(connectionPool);
return this;
}
public HashPartitioning setName(String name) {
getMetadata().setName(name);
return this;
}
public Column setPartitionColumn() {
ColumnImpl column = new ColumnImpl();
getMetadata().setPartitionColumn(column.getMetadata());
return column;
}
public HashPartitioning setUnionUnpartitionableQueries(Boolean unionUnpartitionableQueries) {
getMetadata().setUnionUnpartitionableQueries(unionUnpartitionableQueries);
return this;
}
}