bulk_importer 0.2.0 → 0.2.1
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/bulk_importer/postgresql_module.rb +14 -11
- data/lib/bulk_importer/version.rb +1 -1
- data/lib/bulk_importer.rb +4 -3
- metadata +2 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA1:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 55b8c71a91b7654fde766010d72fb4ce9870c322
|
|
4
|
+
data.tar.gz: e09f5235f7ebbbd06b3339f3f4c2bbd892e15335
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 3994d8a548c294a2038b340b185f0645ede8671d000dacd389c233fff3aec6ae64d82a73b91536fda4a6c253fdc520cafa9bf366dd50a73ea712398a1251a770
|
|
7
|
+
data.tar.gz: d0a2c510e5cc5af410b3ad83b10b82ab0a5a3d0f090882d0bc56cfc518324c0036d23b88872d42df8a9f89def7087ff5795ec219e58f87894771c6634d659526
|
|
@@ -205,20 +205,23 @@ module PostgresqlModule
|
|
|
205
205
|
#
|
|
206
206
|
def self.can_execute_copy()
|
|
207
207
|
# Only superusers can execute COPY.
|
|
208
|
+
self.is_superuser
|
|
209
|
+
end
|
|
210
|
+
|
|
211
|
+
# Checks if the current user is SUPERUSER.
|
|
212
|
+
#
|
|
213
|
+
# ==== Return
|
|
214
|
+
#
|
|
215
|
+
# + bool+
|
|
216
|
+
#
|
|
217
|
+
def self.is_superuser
|
|
208
218
|
query = <<-eof
|
|
209
|
-
SELECT
|
|
219
|
+
SELECT rolsuper
|
|
210
220
|
FROM pg_roles
|
|
211
|
-
WHERE
|
|
212
|
-
|
|
221
|
+
WHERE rolname = CURRENT_USER
|
|
222
|
+
LIMIT 1
|
|
213
223
|
eof
|
|
214
224
|
|
|
215
|
-
|
|
216
|
-
ActiveRecord::Base.connection.execute(query).cmd_tuples > 0
|
|
217
|
-
rescue Exception => e
|
|
218
|
-
Rails.logger.error e.message
|
|
219
|
-
Rails.logger.error e.backtrace
|
|
220
|
-
|
|
221
|
-
false
|
|
222
|
-
end
|
|
225
|
+
ActiveRecord::Base.connection.execute(query).first['rolsuper'] == 't'
|
|
223
226
|
end
|
|
224
227
|
end
|
data/lib/bulk_importer.rb
CHANGED
|
@@ -163,9 +163,10 @@ module BulkImporter
|
|
|
163
163
|
sql << "(#{columns.values.join(',')})"
|
|
164
164
|
sql << "SELECT #{self.keys_to_list(columns.keys, 'o', types)}"
|
|
165
165
|
sql << "FROM #{origin} o"
|
|
166
|
-
sql << "
|
|
167
|
-
sql << "
|
|
168
|
-
sql << "
|
|
166
|
+
sql << "LEFT JOIN #{destination} d"
|
|
167
|
+
sql << "ON (#{self.keys_to_list(keys.keys, 'o')}) = "
|
|
168
|
+
sql << "(#{self.keys_to_list(keys.values, 'd')})"
|
|
169
|
+
sql << "WHERE (#{self.keys_to_list(keys.values, 'd')}) is null"
|
|
169
170
|
|
|
170
171
|
[ sql.join(' ') ]
|
|
171
172
|
end
|
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: bulk_importer
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.2.
|
|
4
|
+
version: 0.2.1
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Abel M. Osorio
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: exe
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2016-12-
|
|
11
|
+
date: 2016-12-03 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: bundler
|