data_keeper 0.1.6 → 0.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/data_keeper/definition.rb +5 -2
- data/lib/data_keeper/dumper.rb +40 -0
- data/lib/data_keeper/loader.rb +23 -5
- data/lib/data_keeper/local_storage.rb +4 -3
- data/lib/data_keeper/s3_storage.rb +2 -2
- data/lib/data_keeper/tasks/data_keeper.rake +11 -0
- data/lib/data_keeper/version.rb +1 -1
- data/lib/data_keeper.rb +9 -0
- metadata +5 -5
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 8aefdb5a66266a15337e2f65a59595a3017c744c6532d97d8c4377eb64f82d43
|
4
|
+
data.tar.gz: 49e39de5ecc7fbdf4355bf25c6d5300b5027c1413450aee696a51683d930065e
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d91d76636fd6eadab472f6442cca9484b95130209a8ba2adef6197c600ab31e43b054121991f6e96ef7200cc4a4ba4f23215ccdf5bf8d6a599d5495786832b51
|
7
|
+
data.tar.gz: d13e22eb926add303417d44fe1ac802b69b3839eb8349903fb10059139bd583e0d91f9e4aaa3a0e9f67ad2782d8aec4628290f48e95b92b64c1facfe1ac70a8f
|
@@ -37,9 +37,12 @@ module DataKeeper
|
|
37
37
|
end
|
38
38
|
|
39
39
|
def evaluate!
|
40
|
-
|
40
|
+
@definition ||=
|
41
|
+
begin
|
42
|
+
instance_eval(&@definition_block) if @definition_block
|
41
43
|
|
42
|
-
|
44
|
+
Definition.new(@type, @tables, @raw_sqls, @on_after_load_block)
|
45
|
+
end
|
43
46
|
end
|
44
47
|
|
45
48
|
def table(name)
|
data/lib/data_keeper/dumper.rb
CHANGED
@@ -48,6 +48,7 @@ module DataKeeper
|
|
48
48
|
dump_schema(tar)
|
49
49
|
dump_partial_tables(tar)
|
50
50
|
dump_sqls(tar)
|
51
|
+
dump_sequences(tar)
|
51
52
|
end
|
52
53
|
end
|
53
54
|
|
@@ -136,8 +137,47 @@ module DataKeeper
|
|
136
137
|
end
|
137
138
|
end
|
138
139
|
|
140
|
+
def dump_sequences(tar)
|
141
|
+
Tempfile.create do |sequences_dump_file|
|
142
|
+
sequences_dump_file.binmode
|
143
|
+
|
144
|
+
sequences_args = all_sequences_to_export.map { |table| "-t #{table}" }.join(' ')
|
145
|
+
cmd = Terrapin::CommandLine.new(
|
146
|
+
'pg_dump',
|
147
|
+
"#{connection_args} -x -Fc :database #{sequences_args} > :output_path",
|
148
|
+
environment: psql_env
|
149
|
+
)
|
150
|
+
|
151
|
+
cmd.run(database: database, host: host, port: port, output_path: sequences_dump_file.path)
|
152
|
+
|
153
|
+
tar.add_file_simple("sequences.dump", 0644, File.size(sequences_dump_file.path)) do |io|
|
154
|
+
sequences_dump_file.reopen(sequences_dump_file)
|
155
|
+
|
156
|
+
while !sequences_dump_file.eof?
|
157
|
+
io.write(sequences_dump_file.read(2048))
|
158
|
+
end
|
159
|
+
end
|
160
|
+
end
|
161
|
+
end
|
162
|
+
|
139
163
|
def filename
|
140
164
|
"#{@dump_name}-#{Time.now.strftime("%Y%m%d-%H%M")}"
|
141
165
|
end
|
166
|
+
|
167
|
+
def all_sequences_to_export
|
168
|
+
cmd = Terrapin::CommandLine.new(
|
169
|
+
'psql',
|
170
|
+
"#{connection_args} -d :database -c :sql -A -R ',' -t",
|
171
|
+
environment: psql_env
|
172
|
+
)
|
173
|
+
|
174
|
+
sequences = cmd.run(
|
175
|
+
database: database,
|
176
|
+
host: host,
|
177
|
+
port: port,
|
178
|
+
sql: "SELECT sequencename from pg_sequences;"
|
179
|
+
)
|
180
|
+
sequences.split(',').map{|x| x.strip}
|
181
|
+
end
|
142
182
|
end
|
143
183
|
end
|
data/lib/data_keeper/loader.rb
CHANGED
@@ -76,7 +76,9 @@ module DataKeeper
|
|
76
76
|
end
|
77
77
|
|
78
78
|
def load_partial_database!
|
79
|
-
|
79
|
+
ensure_schema_compatibility!
|
80
|
+
|
81
|
+
inflate(@file.path) do |schema_path, tables_path, sql_files, sequences_path|
|
80
82
|
pg_restore = Terrapin::CommandLine.new(
|
81
83
|
'pg_restore',
|
82
84
|
"#{connection_args} -j 4 --no-owner -s --dbname :database #{schema_path}#{log_redirect}",
|
@@ -117,6 +119,18 @@ module DataKeeper
|
|
117
119
|
)
|
118
120
|
end
|
119
121
|
|
122
|
+
pg_restore = Terrapin::CommandLine.new(
|
123
|
+
'pg_restore',
|
124
|
+
"#{connection_args} --data-only -j 4 --no-owner --disable-triggers --dbname :database #{sequences_path}#{log_redirect}",
|
125
|
+
environment: psql_env
|
126
|
+
)
|
127
|
+
|
128
|
+
pg_restore.run(
|
129
|
+
database: database,
|
130
|
+
host: host,
|
131
|
+
port: port
|
132
|
+
)
|
133
|
+
|
120
134
|
set_ar_internal_metadata!
|
121
135
|
end
|
122
136
|
end
|
@@ -149,9 +163,8 @@ module DataKeeper
|
|
149
163
|
|
150
164
|
validate("Schema file is missing") { !!schema_path } &&
|
151
165
|
validate("Tables file is missing") { !!tables_path } &&
|
152
|
-
validate("Not all sql custom dumps are present")
|
153
|
-
|
154
|
-
end
|
166
|
+
validate("Not all sql custom dumps are present") { sql_dumps.size == @dump.sqls.keys.size } &&
|
167
|
+
validate("Sequences file is missing") { !!sequences_path }
|
155
168
|
end
|
156
169
|
|
157
170
|
def schema_path
|
@@ -162,6 +175,10 @@ module DataKeeper
|
|
162
175
|
@tables_path ||= @paths.find { |x| File.basename(x) == "tables.dump" }
|
163
176
|
end
|
164
177
|
|
178
|
+
def sequences_path
|
179
|
+
@sequences_path ||= @paths.find { |x| File.basename(x) == "sequences.dump" }
|
180
|
+
end
|
181
|
+
|
165
182
|
def sql_dumps
|
166
183
|
@sql_dumps ||= @dump.sqls.map do |name, (table, _proc)|
|
167
184
|
path = @paths.find { |x| File.basename(x) == "#{name}.csv" }
|
@@ -191,7 +208,8 @@ module DataKeeper
|
|
191
208
|
yield(
|
192
209
|
inflated_files.schema_path,
|
193
210
|
inflated_files.tables_path,
|
194
|
-
inflated_files.sql_dumps
|
211
|
+
inflated_files.sql_dumps,
|
212
|
+
inflated_files.sequences_path
|
195
213
|
)
|
196
214
|
end
|
197
215
|
end
|
@@ -21,14 +21,15 @@ module DataKeeper
|
|
21
21
|
def retrieve(dump_name)
|
22
22
|
tempfile = Tempfile.new
|
23
23
|
local_store_dir = @local_store_dir
|
24
|
+
last_dump_filename = nil
|
24
25
|
|
25
26
|
on complete_host do
|
26
|
-
|
27
|
+
last_dump_filename = capture :ls, "-1t #{File.join(local_store_dir, dump_name.to_s)} | head -n 1"
|
27
28
|
|
28
|
-
download! File.join(local_store_dir, dump_name.to_s,
|
29
|
+
download! File.join(local_store_dir, dump_name.to_s, last_dump_filename), tempfile.path
|
29
30
|
end
|
30
31
|
|
31
|
-
yield(tempfile)
|
32
|
+
yield(tempfile, last_dump_filename)
|
32
33
|
ensure
|
33
34
|
tempfile.delete
|
34
35
|
end
|
@@ -78,7 +78,7 @@ module DataKeeper
|
|
78
78
|
end
|
79
79
|
|
80
80
|
def retrieve(dump_name)
|
81
|
-
prefix = "#{@store_dir}#{dump_name.to_s}"
|
81
|
+
prefix = "#{@store_dir}#{dump_name.to_s}/"
|
82
82
|
last_dump = s3_client.list_contents(prefix).sort_by(&:last_modified).reverse.first
|
83
83
|
|
84
84
|
Tempfile.create do |tmp_file|
|
@@ -86,7 +86,7 @@ module DataKeeper
|
|
86
86
|
s3_client.stream_to_io(last_dump.key, tmp_file)
|
87
87
|
tmp_file.flush
|
88
88
|
|
89
|
-
yield(tmp_file)
|
89
|
+
yield(tmp_file, File.basename(last_dump.key))
|
90
90
|
end
|
91
91
|
end
|
92
92
|
|
@@ -35,4 +35,15 @@ namespace :data_keeper do
|
|
35
35
|
|
36
36
|
DataKeeper.load_dump!(name, path)
|
37
37
|
end
|
38
|
+
|
39
|
+
desc "Downloads the given dump raw file in the current directory"
|
40
|
+
task :download, [:name] => [:environment] do |_t, args|
|
41
|
+
name = args[:name]
|
42
|
+
|
43
|
+
if name.blank? || !DataKeeper.dump?(name)
|
44
|
+
raise "Please use this rake task giving a name of a configured dump. Ex: bin/rake data_keeper:pull[full]"
|
45
|
+
end
|
46
|
+
|
47
|
+
DataKeeper.download_dump!(name, ".")
|
48
|
+
end
|
38
49
|
end
|
data/lib/data_keeper/version.rb
CHANGED
data/lib/data_keeper.rb
CHANGED
@@ -44,6 +44,15 @@ module DataKeeper
|
|
44
44
|
end
|
45
45
|
end
|
46
46
|
|
47
|
+
def self.download_dump!(name, path)
|
48
|
+
raise DumpDoesNotExist unless dump?(name)
|
49
|
+
raise NoStorageDefined if @storage.nil?
|
50
|
+
|
51
|
+
@storage.retrieve(name) do |file, filename|
|
52
|
+
FileUtils.cp file.path, File.join(path, filename)
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
47
56
|
def self.load_dump!(name, path)
|
48
57
|
raise DumpDoesNotExist unless File.file?(path)
|
49
58
|
raise NoStorageDefined if @storage.nil?
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: data_keeper
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.9
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Roger Campos
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-02-28 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -100,7 +100,7 @@ licenses:
|
|
100
100
|
- MIT
|
101
101
|
metadata:
|
102
102
|
homepage_uri: https://github.com/rogercampos/data_keeper
|
103
|
-
post_install_message:
|
103
|
+
post_install_message:
|
104
104
|
rdoc_options: []
|
105
105
|
require_paths:
|
106
106
|
- lib
|
@@ -116,7 +116,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
116
116
|
version: '0'
|
117
117
|
requirements: []
|
118
118
|
rubygems_version: 3.1.6
|
119
|
-
signing_key:
|
119
|
+
signing_key:
|
120
120
|
specification_version: 4
|
121
121
|
summary: Easy management of database dumps for dev env
|
122
122
|
test_files: []
|