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