-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.txt
71 lines (47 loc) · 2.56 KB
/
README.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
rubysync
by Ritchie Young
http://rubysync.org
== DESCRIPTION:
RubySync is a tool for synchronizing part or all of your directory,
database or application data with anything else. It's event driven
so it will happily sit there monitoring changes and passing them on.
Alternatively, you can run it in one-shot mode and simply sync A with B.
You can configure RubySync to perform transformations on the data as it
syncs. RubySync is designed both as a handy utility to pack into your
directory management toolkit or as a fully-fledged provisioning system
for your organization.
== FEATURES/PROBLEMS:
* Event-driven synchronization (if connector supports it) with fall-back to polling
* Ruby DSL for "configuration" style event processing
* Clean separation of connector details from data transformation
* Connectors available for CSV files, XML, LDAP and RDBMS (via ActiveRecord)
* Easy API for writing your own connectors
== SYNOPSIS:
This sets up the skeleton of a configuration for importing comma delimited
text files into a database. Note, if the application happens to be a Rails
app then it can also export changes.
$ rubysync create db_demo
$ cd db_demo
$ rubysync connector my_csv -t csv_file
$ rubysync connector my_db -t active_record
You would then edit the files:
connectors/my_csv_connector.rb ;where to get CSV files, field names, etc
connectors/my_db_connector.rb ;how to connect to your DB or Rails app.
And enter:
$ rubysync pipeline my -C my_csv -V my_db
You would then edit the file pipelines/my_pipeline.rb to configure the
policy for synchronizing between the two connectors.
You may then execute the pipeline in one-shot mode:
$ rubysync once my
== REQUIREMENTS:
* An RDBMS system if you want to sync one
* An LDAP server if you want to sync one
== INSTALL:
* sudo gem install rubysync -y
== LICENSE:
RubySync 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 2 of the License, or (at your option) any later version.
RubySync 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 RubySync; if not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA