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.DB_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
72 _buildCreateFile();
73 }
74 catch (Exception e) {
75 e.printStackTrace();
76 }
77 }
78
79 private void _buildCreateFile() throws IOException {
80 for (int i = 0; i < _databaseTypes.length; i++) {
81 String databaseType = _databaseTypes[i];
82
83 if (databaseType.equals(DBUtil.DB_TYPE_HYPERSONIC) ||
84 databaseType.equals(DBUtil.DB_TYPE_INTERBASE) ||
85 databaseType.equals(DBUtil.DB_TYPE_JDATASTORE) ||
86 databaseType.equals(DBUtil.DB_TYPE_SAP)) {
87
88 continue;
89 }
90
91 DBUtil dbUtil = _getDBUtil(_databaseTypes[i]);
92
93 if (dbUtil != null) {
94 dbUtil.buildCreateFile(_databaseName);
95 }
96 }
97 }
98
99 private void _buildSQLFile(String fileName) throws IOException {
100 if (!FileUtil.exists("../sql/" + fileName + ".sql")) {
101 return;
102 }
103
104 for (int i = 0; i < _databaseTypes.length; i++) {
105 DBUtil dbUtil = _getDBUtil(_databaseTypes[i]);
106
107 if (dbUtil != null) {
108 dbUtil.buildSQLFile(fileName);
109 }
110 }
111 }
112
113 private DBUtil _getDBUtil(String dbType) {
114 return DBUtil.getInstance(dbType);
115 }
116
117 private String _databaseName;
118
119 private String[] _databaseTypes;
120
121 }