1
19
20 package com.liferay.portal.dao.shard;
21
22 import com.liferay.portal.kernel.log.Log;
23 import com.liferay.portal.kernel.log.LogFactoryUtil;
24 import com.liferay.portal.util.PropsValues;
25
26 import javax.sql.DataSource;
27
28
34 public class ShardUtil {
35
36 public static String COMPANY_SCOPE = "COMPANY_SCOPE";
37
38 public static DataSource getDataSource() {
39 return _shardAdvice.getDataSource();
40 }
41
42 public static ShardSelector getShardSelector() {
43 return _shardSelector;
44 }
45
46 public static String popCompanyService() {
47 String value = null;
48
49 if (_shardAdvice != null) {
50 value = _shardAdvice.popCompanyService();
51 }
52
53 return value;
54 }
55
56 public static void pushCompanyService(long companyId) {
57 if (_shardAdvice != null) {
58 _shardAdvice.pushCompanyService(companyId);
59 }
60 }
61
62 public static void pushCompanyService(String shardName) {
63 if (_shardAdvice != null) {
64 _shardAdvice.pushCompanyService(shardName);
65 }
66 }
67
68 public void setShardAdvice(ShardAdvice shardAdvice) {
69 _shardAdvice = shardAdvice;
70 }
71
72 private static Log _log = LogFactoryUtil.getLog(ShardUtil.class);
73
74 private static ShardAdvice _shardAdvice;
75 private static ShardSelector _shardSelector;
76
77 static {
78 try {
79 _shardSelector = (ShardSelector)Class.forName(
80 PropsValues.SHARD_SELECTOR).newInstance();
81 }
82 catch (Exception e) {
83 _log.error(e, e);
84 }
85 }
86
87 }