diff options
Diffstat (limited to 'src/main/src/conf')
-rw-r--r-- | src/main/src/conf/ConfigDestBean.java | 81 | ||||
-rw-r--r-- | src/main/src/conf/ConfigGlobalsBean.java | 2 | ||||
-rw-r--r-- | src/main/src/conf/ConfigSourceBean.java (renamed from src/main/src/conf/ConfigSrcOrDestBean.java) | 13 | ||||
-rw-r--r-- | src/main/src/conf/ConfigTaskBean.java | 16 | ||||
-rw-r--r-- | src/main/src/conf/SSSyncConnectionsFactory.java | 61 | ||||
-rw-r--r-- | src/main/src/conf/SSSyncTasksFactory.java | 147 |
6 files changed, 101 insertions, 219 deletions
diff --git a/src/main/src/conf/ConfigDestBean.java b/src/main/src/conf/ConfigDestBean.java new file mode 100644 index 0000000..2d9b2f7 --- /dev/null +++ b/src/main/src/conf/ConfigDestBean.java @@ -0,0 +1,81 @@ +/* + * SSSync, a Simple and Stupid Synchronizer for data with multi-valued attributes + * Copyright (C) 2014 Ludovic Pouzenc <ludovic@pouzenc.fr> + * + * This file is part of SSSync. + * + * SSSync is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * SSSync is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with SSSync. If not, see <http://www.gnu.org/licenses/> + */ + +package conf; + +/** + * Generated Configuration Bean + */ +public class ConfigDestBean { + public enum DestinationKind { ldap }; + + private String name; + private DestinationKind kind; + private String conn; + private String attr; + private String base; + private int lookahead = 128; /* Only for ldap kind, query lookahead entries at once */ + + public String getName() { + return name; + } + public void setName(String name) { + this.name = name; + } + public DestinationKind getKind() { + return kind; + } + public void setKind(DestinationKind kind) { + this.kind = kind; + } + public String getConn() { + return conn; + } + public void setConn(String conn) { + this.conn = conn; + } + public String getAttr() { + return attr; + } + public void setAttr(String attr) { + this.attr = attr; + } + public String getBase() { + return base; + } + public void setBase(String base) { + this.base = base; + } + public int getLookahead() { + return lookahead; + } + public void setLookahead(int lookahead) { + this.lookahead = lookahead; + } + + @Override + public String toString() { + return "ConfigDestBean [name=" + name + ", kind=" + kind + ", conn=" + + conn + ", attr=" + attr + ", base=" + base + ", lookahead=" + + lookahead + "]"; + } + + +} diff --git a/src/main/src/conf/ConfigGlobalsBean.java b/src/main/src/conf/ConfigGlobalsBean.java index 256acee..20243f3 100644 --- a/src/main/src/conf/ConfigGlobalsBean.java +++ b/src/main/src/conf/ConfigGlobalsBean.java @@ -24,7 +24,7 @@ package conf; * Generated Configuration Bean */ public class ConfigGlobalsBean { - private int maxExecTime; + private int maxExecTime = 5; public int getMaxExecTime() { return maxExecTime; diff --git a/src/main/src/conf/ConfigSrcOrDestBean.java b/src/main/src/conf/ConfigSourceBean.java index 5be1674..cf01dce 100644 --- a/src/main/src/conf/ConfigSrcOrDestBean.java +++ b/src/main/src/conf/ConfigSourceBean.java @@ -25,8 +25,9 @@ import data.filters.MVDataCombiner; /** * Generated Configuration Bean */ -public class ConfigSrcOrDestBean { +public class ConfigSourceBean { + //TODO : fixed_csv ? public enum SourceKind { csv, ldap, sorted_csv, sql }; private String name; @@ -37,6 +38,7 @@ public class ConfigSrcOrDestBean { private String path; private String attr; private String base; + private int lookahead = 128; /* Only for ldap kind, query lookahead entries at once */ public String getName() { return name; @@ -86,11 +88,18 @@ public class ConfigSrcOrDestBean { public void setBase(String base) { this.base = base; } + public int getLookahead() { + return lookahead; + } + public void setLookahead(int lookahead) { + this.lookahead = lookahead; + } @Override public String toString() { return "ConfigSrcOrDestBean [name=" + name + ", kind=" + kind + ", conn=" + conn + ", mode=" + mode + ", query=" + query - + ", path=" + path + ", attr=" + attr + ", base=" + base + "]"; + + ", path=" + path + ", attr=" + attr + ", base=" + base + ", lookahead=" + + lookahead + "]"; } } diff --git a/src/main/src/conf/ConfigTaskBean.java b/src/main/src/conf/ConfigTaskBean.java index ed34eee..11089d6 100644 --- a/src/main/src/conf/ConfigTaskBean.java +++ b/src/main/src/conf/ConfigTaskBean.java @@ -29,10 +29,10 @@ public class ConfigTaskBean { private String name; private ConfigOpLimitsBean opLimits; - private List<ConfigSrcOrDestBean> sources; - private ConfigSrcOrDestBean destination; - private boolean skipReadErrors; - private boolean skipEntryDelete; + private List<ConfigSourceBean> sources; + private ConfigDestBean destination; + private boolean skipReadErrors = false; + private boolean skipEntryDelete = false; public String getName() { return name; @@ -46,16 +46,16 @@ public class ConfigTaskBean { public void setOpLimits(ConfigOpLimitsBean opLimits) { this.opLimits = opLimits; } - public List<ConfigSrcOrDestBean> getSources() { + public List<ConfigSourceBean> getSources() { return sources; } - public void setSources(List<ConfigSrcOrDestBean> sources) { + public void setSources(List<ConfigSourceBean> sources) { this.sources = sources; } - public ConfigSrcOrDestBean getDestination() { + public ConfigDestBean getDestination() { return destination; } - public void setDestination(ConfigSrcOrDestBean destination) { + public void setDestination(ConfigDestBean destination) { this.destination = destination; } public boolean isSkipReadErrors() { diff --git a/src/main/src/conf/SSSyncConnectionsFactory.java b/src/main/src/conf/SSSyncConnectionsFactory.java deleted file mode 100644 index e747258..0000000 --- a/src/main/src/conf/SSSyncConnectionsFactory.java +++ /dev/null @@ -1,61 +0,0 @@ -/* - * SSSync, a Simple and Stupid Synchronizer for data with multi-valued attributes - * Copyright (C) 2014 Ludovic Pouzenc <ludovic@pouzenc.fr> - * - * This file is part of SSSync. - * - * SSSync is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * SSSync is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with SSSync. If not, see <http://www.gnu.org/licenses/> - */ - -package conf; - -import data.io.ConnectionsHolder; -import data.io.ldap.LDAPConnectionWrapper; -import data.io.sql.SQLConnectionWrapper; - -/** - * TODO javadoc - * - * @author lpouzenc - */ -public class SSSyncConnectionsFactory { - - /** - * Setup all connections described in config - * @return - * @throws Exception - */ - public static ConnectionsHolder setupConnections(ConfigConnectionsBean confConn) throws Exception { - ConnectionsHolder connections = new ConnectionsHolder(); - - for ( ConfigConnectionBean conn : confConn.getConnections() ) { - switch (conn.getType()) { - case jdbc: - SQLConnectionWrapper connSQL = new SQLConnectionWrapper(conn.getDbms(), conn.getHost(), conn.getPort(), conn.getRess(), conn.getUser(), conn.getPass(), conn.getDb()); - connections.putConnSQL(conn.getId(), connSQL); - break; - case ldap: - LDAPConnectionWrapper connLDAP = new LDAPConnectionWrapper(conn.getHost(), conn.getPort(), conn.getBind(), conn.getPass()); - connections.putConnLDAP(conn.getId(), connLDAP); - break; - default: - //XXX : find better Exception type - throw new Exception("Bad config : conn '" + conn.getId() + "' unsupported type"); - } - } - - return connections; - } - -} diff --git a/src/main/src/conf/SSSyncTasksFactory.java b/src/main/src/conf/SSSyncTasksFactory.java deleted file mode 100644 index de3e8f6..0000000 --- a/src/main/src/conf/SSSyncTasksFactory.java +++ /dev/null @@ -1,147 +0,0 @@ -/* - * SSSync, a Simple and Stupid Synchronizer for data with multi-valued attributes - * Copyright (C) 2014 Ludovic Pouzenc <ludovic@pouzenc.fr> - * - * This file is part of SSSync. - * - * SSSync is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * SSSync is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with SSSync. If not, see <http://www.gnu.org/licenses/> - */ - -package conf; - -import java.io.File; -import java.io.FileReader; -import java.util.ArrayList; -import java.util.List; - -import sync.BasicSyncTask; -import data.filters.MVDataCombiner; -import data.filters.MVDataCombiner.MVDataCombineMode; -import data.io.ConnectionsHolder; -import data.io.MVDataReader; -import data.io.MVDataWriter; -import data.io.SafeDataReader; -import data.io.csv.CSVDataReader; -import data.io.ldap.LDAPConnectionWrapper; -import data.io.sql.SQLConnectionWrapper; - -/** - * TODO javadoc - * - * @author lpouzenc - */ -public class SSSyncTasksFactory { - - /** - * Build tasks objects with all needed resources from a config beans tree - * @param conf - * @return - * @throws Exception - */ - public static List<BasicSyncTask> setupTasks(ConnectionsHolder connections, ConfigRootBean confMain) throws Exception { - List<BasicSyncTask> tasks = new ArrayList<BasicSyncTask>(); - - // For each task... - for ( ConfigTaskBean confTask: confMain.getTasks() ) { - MVDataReader srcReader=null; - - // Building all sources - - List<ConfigSrcOrDestBean> confSources = confTask.getSources(); - // See if we are in multiple source situation (then MVDataCombiner) or not (then simple MVDataReader) - if ( confSources.size() == 0 ) { - throw new Exception("Bad config : task '" + confTask.getName() + "' has no defined sources"); - } else if ( confSources.size() == 1 ) { - srcReader = new SafeDataReader(_makeReader(connections, confSources.get(0), confTask.getName()), confTask.isSkipReadErrors()); - } else { - List<MVDataReader> readers = new ArrayList<MVDataReader>(); - List<MVDataCombineMode> mergeModes = new ArrayList<MVDataCombineMode>(); - - // For each source of the future MVDataCombiner... - for ( ConfigSrcOrDestBean confSource: confSources ) { - // Create and add the reader and his parameters - readers.add(new SafeDataReader(_makeReader(connections, confSource, confTask.getName()), confTask.isSkipReadErrors())); - mergeModes.add(confSource.getMode()); - } - - srcReader = new MVDataCombiner("srcCombiner", readers.toArray(new MVDataReader[0]), mergeModes.toArray(new MVDataCombineMode[0])); - } - - // Building destination - - MVDataReader dstReader=null; - MVDataWriter dstWriter=null; - - ConfigSrcOrDestBean confDestination = confTask.getDestination(); - switch ( confDestination.getKind() ) { - case ldap: - LDAPConnectionWrapper builder = connections.getLDAPConnectionBuilder(confDestination.getConn()); - // TODO : configurable lookAhead - MVDataReader tmpReader = builder.newFlatReader(confDestination.getName()+"_reader", confDestination.getBase(), confDestination.getAttr(), 128); - dstReader = new SafeDataReader(tmpReader, false); - dstWriter = builder.newFlatWriter(confDestination.getBase(), confDestination.getAttr()); - break; - default: - throw new Exception("Bad config : task '" + confTask.getName() + "' unsupported destination kind"); - } - - // Then building the sync task and add it to the task list - int maxInserts = confTask.getOpLimits().getInsert(); - int maxUpdates = confTask.getOpLimits().getUpdate(); - int maxDeletes = confTask.getOpLimits().getDelete(); - - BasicSyncTask task = new BasicSyncTask(confTask.getName(), false, srcReader, dstReader, dstWriter); - task.setOperationLimits(maxInserts, maxUpdates, maxDeletes); - task.setSkipEntryDelete(confTask.isSkipEntryDelete()); - tasks.add(task); - } - - return tasks; - } - - /** - * Helper function to make a new reader from an existing connection - * @param confSource - * @param taskName - * @return - * @throws Exception - */ - private static MVDataReader _makeReader(ConnectionsHolder connections, ConfigSrcOrDestBean confSource, String taskName) throws Exception { - MVDataReader reader=null; - switch (confSource.getKind()) { - case csv: - reader = new CSVDataReader(confSource.getName(), new FileReader(confSource.getPath()), false); - break; - case ldap: - LDAPConnectionWrapper ldapConnBuilder = connections.getLDAPConnectionBuilder(confSource.getConn()); - //FIXME : if conf error, get...ConnectionBuilder could return null - //TODO : configurable lookAhead - reader = ldapConnBuilder.newFlatReader(confSource.getName(), confSource.getBase(), confSource.getAttr(), 128); - break; - case sorted_csv: - reader = new CSVDataReader(confSource.getName(), new FileReader(confSource.getPath()), true); - break; - case sql: - SQLConnectionWrapper sqlConnBuilder = connections.getSQLConnectionBuilder(confSource.getConn()); - //TODO We assume the query config item is a filepath. It isn't checked anywhere. - reader = sqlConnBuilder.newReader(confSource.getName(), new File(confSource.getQuery())); - break; - default: - throw new Exception("Bad config : task '" + taskName + "' unsupported source kind"); - } - - return reader; - } - -} |