/******************************************************************************* * 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; } }