/*
* Copyright 2008 Pavel Syrtsov
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and limitations
* under the License.
*/
package com.sf.ddao.shards;
import org.apache.commons.chain.Context;
import javax.inject.Singleton;
import javax.sql.DataSource;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
/**
* Created by psyrtsov
*/
@Singleton
public class TestShardingService implements ShardingService<Long> {
private DataSource ds1;
private DataSource ds2;
public DataSource getShard(Long id, Context ctx) {
if (id == null) {
throw new NullPointerException("Shard key is not defined");
}
if (1 <= id && id <= 10) {
return ds1;
}
if (11 <= id && id <= 20) {
return ds2;
}
return null;
}
public Map<DataSource, Collection<Long>> getMultiShard(Collection<Long> shardKeyCollection, Context context) {
Map<DataSource, Collection<Long>> res = new HashMap<DataSource, Collection<Long>>();
res.put(ds1, shardKeyCollection);
res.put(ds2, shardKeyCollection);
return res;
}
public void setDS1(DataSource DS1) {
this.ds1 = DS1;
}
public void setDS2(DataSource DS2) {
this.ds2 = DS2;
}
}