1
19
20 package com.liferay.portal.tools;
21
22 import com.liferay.portal.kernel.util.FileUtil;
23 import com.liferay.portal.kernel.util.StringUtil;
24 import com.liferay.portal.tools.sql.DBUtil;
25 import com.liferay.portal.util.InitUtil;
26
27 import java.io.IOException;
28
29
37 public class DBBuilder {
38
39 public static void main(String[] args) {
40 InitUtil.initWithSpring();
41
42 if (args.length == 1) {
43 new DBBuilder(args[0], DBUtil.TYPE_ALL);
44 }
45 else if (args.length == 2) {
46 new DBBuilder(args[0], StringUtil.split(args[1]));
47 }
48 else {
49 throw new IllegalArgumentException();
50 }
51 }
52
53 public DBBuilder(String databaseName, String[] databaseTypes) {
54 try {
55 _databaseName = databaseName;
56 _databaseTypes = databaseTypes;
57
58 _buildSQLFile("portal");
59 _buildSQLFile("portal-minimal");
60 _buildSQLFile("indexes");
61 _buildSQLFile("sequences");
62 _buildSQLFile("update-4.2.0-4.3.0");
63 _buildSQLFile("update-4.3.0-4.3.1");
64 _buildSQLFile("update-4.3.1-4.3.2");
65 _buildSQLFile("update-4.3.2-4.3.3");
66 _buildSQLFile("update-4.3.3-4.3.4");
67 _buildSQLFile("update-4.3.6-4.4.0");
68 _buildSQLFile("update-4.4.0-5.0.0");
69 _buildSQLFile("update-5.0.1-5.1.0");
70 _buildSQLFile("update-5.1.1-5.1.2");
71 _buildSQLFile("update-5.1.4-5.1.5");
72
73 _buildCreateFile();
74 }
75 catch (Exception e) {
76 e.printStackTrace();
77 }
78 }
79
80 private void _buildCreateFile() throws IOException {
81 for (int i = 0; i < _databaseTypes.length; i++) {
82 String databaseType = _databaseTypes[i];
83
84 if (databaseType.equals(DBUtil.TYPE_HYPERSONIC) ||
85 databaseType.equals(DBUtil.TYPE_INTERBASE) ||
86 databaseType.equals(DBUtil.TYPE_JDATASTORE) ||
87 databaseType.equals(DBUtil.TYPE_SAP)) {
88
89 continue;
90 }
91
92 DBUtil dbUtil = _getDBUtil(_databaseTypes[i]);
93
94 if (dbUtil != null) {
95 dbUtil.buildCreateFile(_databaseName);
96 }
97 }
98 }
99
100 private void _buildSQLFile(String fileName) throws IOException {
101 if (!FileUtil.exists("../sql/" + fileName + ".sql")) {
102 return;
103 }
104
105 for (int i = 0; i < _databaseTypes.length; i++) {
106 DBUtil dbUtil = _getDBUtil(_databaseTypes[i]);
107
108 if (dbUtil != null) {
109 dbUtil.buildSQLFile(fileName);
110 }
111 }
112 }
113
114 private DBUtil _getDBUtil(String dbType) {
115 return DBUtil.getInstance(dbType);
116 }
117
118 private String _databaseName;
119
120 private String[] _databaseTypes;
121
122 }