blob: 5552eda7c6e08b97b18ea4ae5d8ecdee211aabe5 [file] [log] [blame]
/*
* Copyright (c) 2013, 2020 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 v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/
// 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>());
}
@Override
public HashPartitioning addConnectionPool(String connectionPool) {
getMetadata().getConnectionPools().add(connectionPool);
return this;
}
@Override
public HashPartitioning setName(String name) {
getMetadata().setName(name);
return this;
}
@Override
public Column setPartitionColumn() {
ColumnImpl column = new ColumnImpl();
getMetadata().setPartitionColumn(column.getMetadata());
return column;
}
@Override
public HashPartitioning setUnionUnpartitionableQueries(Boolean unionUnpartitionableQueries) {
getMetadata().setUnionUnpartitionableQueries(unionUnpartitionableQueries);
return this;
}
}