/******************************************************************************* * 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.ValuePartitionMetadata; import org.eclipse.persistence.internal.jpa.metadata.partitioning.ValuePartitioningMetadata; import org.eclipse.persistence.jpa.config.Column; import org.eclipse.persistence.jpa.config.ValuePartition; import org.eclipse.persistence.jpa.config.ValuePartitioning; /** * JPA scripting API implementation. * * @author Guy Pelletier * @since EclipseLink 2.5.1 */ public class ValuePartitioningImpl extends MetadataImpl<ValuePartitioningMetadata> implements ValuePartitioning { public ValuePartitioningImpl() { super(new ValuePartitioningMetadata()); getMetadata().setPartitions(new ArrayList<ValuePartitionMetadata>()); } public ValuePartition addPartition() { ValuePartitionImpl valuePartition = new ValuePartitionImpl(); getMetadata().getPartitions().add(valuePartition.getMetadata()); return valuePartition; } public ValuePartitioning setDefaultConnectionPool(String defaultConnectionPool) { getMetadata().setDefaultConnectionPool(defaultConnectionPool); return this; } public ValuePartitioning setName(String name) { getMetadata().setName(name); return this; } public Column setPartitionColumn() { ColumnImpl column = new ColumnImpl(); getMetadata().setPartitionColumn(column.getMetadata()); return column; } public ValuePartitioning setPartitionValueType(String partitionValueType) { getMetadata().setPartitionValueTypeName(partitionValueType); return this; } public ValuePartitioning setUnionUnpartitionableQueries(Boolean unionUnpartitionableQueries) { getMetadata().setUnionUnpartitionableQueries(unionUnpartitionableQueries); return this; } }