techinform 1.4.7 → 1.6.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 47d7adfea5d8bc003f794950bd35562a2dcb6a7dce37fc7a2c76d56e63e9878d
4
- data.tar.gz: eec1a2f73f4d6e5b71ccc619eaaa8a567512f05a723ee242e7dd286784a0b17a
3
+ metadata.gz: ed6f5eee3a820fd700b3071ba7af8b9b89b58095e5c5b9986d532bd2fa205779
4
+ data.tar.gz: 84ab25cca7062e859423ec839f90397009aa3f74b037227b0e18ebb6acc2f574
5
5
  SHA512:
6
- metadata.gz: 6854b94e03b26fee1904a9a7efd21454a2b8ac3065abc7a87d28b17f68a2ab6bc20ed3b97e4f251422999044aea8e17c7bec9a14a88b596834a81dc44eb70906
7
- data.tar.gz: f194077702cedc232239f0deb652cd674b25331f2f0f289071aa02316c516632c660d8289f735a1b45d653aa123d2f8206659bc6df9938e09b6d034d43cbe15b
6
+ metadata.gz: e715736bb3ca16daee805b40112bbccc768d541982a765a2f6bcf8ddbcfbb4a49ad4957a2d585a63d8955bd826e48b1ef68c38698c7f36ea02e6397fda563301
7
+ data.tar.gz: 713d0e4afe0e592b794b6b8d5cca623d717725a3f27492e2e4c62cb1cc315d7cda3628d19c6673d54686d0217add7336ec876c03c45a21e4f30934e6da6bd9bf
@@ -0,0 +1,30 @@
1
+ name: Ruby Gem
2
+
3
+ on:
4
+ push:
5
+ branches: [ master ]
6
+ pull_request:
7
+ branches: [ master ]
8
+
9
+ jobs:
10
+ build:
11
+ name: Build + Publish
12
+ runs-on: ubuntu-latest
13
+
14
+ steps:
15
+ - uses: actions/checkout@v2
16
+ - name: Set up Ruby 2.7
17
+ uses: actions/setup-ruby@v1
18
+ with:
19
+ version: 2.7.x
20
+
21
+ - name: Publish to RubyGems
22
+ run: |
23
+ mkdir -p $HOME/.gem
24
+ touch $HOME/.gem/credentials
25
+ chmod 0600 $HOME/.gem/credentials
26
+ printf -- "---\n:rubygems_api_key: ${GEM_HOST_API_KEY}\n" > $HOME/.gem/credentials
27
+ gem build *.gemspec
28
+ gem push *.gem
29
+ env:
30
+ GEM_HOST_API_KEY: ${{secrets.RUBYGEMS_AUTH_TOKEN}}
@@ -1 +1 @@
1
- 2.5.5
1
+ 2.7.1
@@ -0,0 +1,16 @@
1
+ ### 1.6.0
2
+
3
+ - Adds --delete option on backup sync (via rsync)
4
+
5
+ ### 1.5.2
6
+
7
+ - Version bump with minor text changes
8
+
9
+ ### 1.5.1
10
+
11
+ - Use parallel version of bzip2 - lbzip2 - if installed
12
+ - Use DBUSER environment variable as database user insted of USER
13
+
14
+ ### 1.5.0
15
+
16
+ Change progress display - now correctly shows percents
data/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # Techinform
2
2
 
3
- Collection of console tools, useful for everyday tasks in Techinform company.
3
+ Collection of console tools, useful for everyday tasks in Techinform Soft company (https://techinform.dev).
4
4
 
5
5
  * All backups stored at /backups/local directory.
6
6
  * All backup sync goes to /backups/< server name > directory.
@@ -17,7 +17,7 @@ Install gem yourself as:
17
17
 
18
18
  * mysqldump - for mysql database dumps
19
19
  * gpg2 - backup encryption support
20
- * bzip2 - backup compression support
20
+ * bzip2 - backup compression support (prefer lbzip2 if installed)
21
21
  * rsync - syncing backups
22
22
 
23
23
  ## Configuration
@@ -28,7 +28,7 @@ Available variables:
28
28
 
29
29
  DEBUG=true # Print debug information on commands run
30
30
  GPGKEY=< email | key id > # Enables encryption and encrypt with specific public key via gpg2. gpg2 should be installed
31
- USER=root # User for database access
31
+ DBUSER=root # User for database access
32
32
  PASSWORD=password # Password for database access
33
33
 
34
34
  ## Usage
@@ -1,6 +1,7 @@
1
1
  require 'date'
2
2
  require_relative '../techinform/defaults'
3
3
  require 'highline'
4
+ require 'bzip2_selector'
4
5
 
5
6
  class Backup
6
7
  attr_reader :dry_run, :quiet
@@ -60,7 +61,7 @@ class Backup
60
61
  if encrypt?
61
62
  "| gpg2 --encrypt #{"--compress-algo=bzip2" if compress?} --recipient=#{ENV['GPGKEY']}"
62
63
  else
63
- "| bzip2" if compress?
64
+ "| #{bzip2}" if compress?
64
65
  end
65
66
  end
66
67
 
@@ -5,7 +5,7 @@ class DbBackup < Backup
5
5
 
6
6
  def initialize user: nil, database: nil, password: nil, compress: true, host: nil, encrypt: nil
7
7
  super compress: compress, encrypt: encrypt
8
- user = ENV['USER'] if user.nil?
8
+ user = ENV['DBUSER'] if user.nil?
9
9
  password = ENV['PASSWORD'] if password.nil?
10
10
  @password, @user, @database, @host = password, user, database, host
11
11
  ensure_path unless database.nil?
@@ -0,0 +1,7 @@
1
+ def bzip2
2
+ @bzip2 ||= (system('which lbzip2 > /dev/null') ? 'lbzip2' : 'bzip2')
3
+ end
4
+
5
+ def bunzip2
6
+ @bunzip2 ||= (system('which lbunzip2 > /dev/null') ? 'lbunzip2' : 'bunzip2')
7
+ end
@@ -2,12 +2,15 @@ require 'techinform/version'
2
2
  require 'techinform/projects'
3
3
  require_relative 'techinform/backup'
4
4
  require 'thor'
5
+ require 'bzip2_selector'
6
+
5
7
 
6
8
  module Techinform
7
9
  class CLI < Thor
8
10
  desc 'restore [type] [absolute_filename or database to select file] [dbname]', 'Restore database from backup; if no absolute filename given, will present select menu to choose file'
9
- def restore(type, filename, dbname, just_decrypt = false)
11
+ def restore(type, filename, dbname = nil, just_decrypt = false)
10
12
  require 'highline'
13
+ dbname = filename if dbname.nil?
11
14
  if !File.exist?(filename)
12
15
  cli = HighLine.new
13
16
  path = type == 'pg' ? PostgreBackup.new(database: filename).restore_path : MysqlBackup.new(database: filename).restore_path
@@ -15,28 +18,31 @@ module Techinform
15
18
  end
16
19
  encrypted = filename.split('.').last == 'gpg'
17
20
  if type == 'pg'
18
- puts "Restoring postgres backup to database #{dbname}..."
19
21
  if encrypted && just_decrypt
20
- `gpg2 --decrypt #{filename} | pv --wait | bzip2 > #{File.basename(filename, '.*')}.bz2`
22
+ puts "Decrypting postgres backup of #{filename}..."
23
+ `pv --wait #{filename} | gpg2 --decrypt | #{bzip2} > #{File.basename(filename, '.*') + '.bz2'}`
21
24
  elsif encrypted
22
- `gpg2 --decrypt #{filename} | pv --wait | psql #{dbname} > /dev/null`
25
+ puts "Restoring postgres backup to database #{dbname}..."
26
+ `pv --wait #{filename} | gpg2 --decrypt | psql #{dbname} > /dev/null`
23
27
  else
24
- `tar -xOf #{filename} | bunzip2 | pv | psql #{dbname} > /dev/null`
28
+ `pv --wait #{filename} | #{bunzip2} | psql #{dbname} > /dev/null`
25
29
  end
26
30
  else
27
- puts "Restoring mysql backup to database #{dbname}..."
28
31
  if encrypted && just_decrypt
29
- `gpg2 --decrypt #{filename} | pv --wait | bzip2 > #{File.basename(filename, '.*')}.bz2`
32
+ puts "Decrypting mysql backup of #{filename}..."
33
+ `pv --wait #{filename} | gpg2 --decrypt | #{bzip2} > #{File.basename(filename, '.*') + '.bz2'}`
30
34
  elsif encrypted
31
- `gpg2 --decrypt #{filename} | pv --wait | mysql #{"-u#{ENV['USER']}" if !ENV['USER'].nil?} #{"-p#{ENV['PASSWORD']}" if !ENV['PASSWORD'].nil?} #{dbname}`
35
+ puts "Restoring mysql backup to database #{dbname}..."
36
+ `pv --wait #{filename} | gpg2 --decrypt | mysql#{" -u#{ENV['DBUSER']}" if !ENV['DBUSER'].nil?}#{" -p#{ENV['PASSWORD']}" if !ENV['PASSWORD'].nil?} #{dbname}`
32
37
  else
33
- `tar -xOf #{filename} | bunzip2 | pv | mysql #{"-u#{ENV['USER']}" if !ENV['USER'].nil?} #{"-p#{ENV['PASSWORD']}" if !ENV['PASSWORD'].nil?} #{dbname}`
38
+ `pv --wait #{filename} | #{bunzip2} | mysql#{" -u#{ENV['DBUSER']}" if !ENV['DBUSER'].nil?}#{" -p#{ENV['PASSWORD']}" if !ENV['PASSWORD'].nil?} #{dbname}`
34
39
  end
35
40
  end
36
41
  end
37
42
 
38
43
  desc 'decrypt [type] [absolute_filename or database to select file]', 'Decrypt file from backup; if no absolute filename given, will present select menu to choose file'
39
44
  def decrypt(type, filename)
45
+ puts "lbzip2 is not found. Single-threaded bzip2 will be used. Consider installing lbzip2" if bzip2 == 'bzip2'
40
46
  restore(type, filename, nil, true)
41
47
  end
42
48
 
@@ -47,10 +47,11 @@ module Techinform
47
47
  end
48
48
 
49
49
  desc 'sync [server] [type] [ipaddr | dnsname]', 'Sync backups from remote server'
50
+ option :delete, type: :boolean, default: false, desc: 'Mirror files (delete nonexistent) on sync'
50
51
  def sync(server, type, ipaddr)
51
52
  location = Techinform.backups_syncing_location(server, type)
52
53
  `mkdir -p #{location}`
53
- system("rsync -avz #{"--exclude-from=#{"#{File.dirname(__FILE__)}/sync/rails_exclude_files"}" if type == 'rails'} backup@#{ipaddr}::#{type} #{location}")
54
+ system("rsync -avz #{'--delete' if options[:delete]} #{"--exclude-from=#{"#{File.dirname(__FILE__)}/sync/rails_exclude_files"}" if type == 'rails'} backup@#{ipaddr}::#{type} #{location}")
54
55
  end
55
56
  end
56
57
  end
@@ -1,3 +1,3 @@
1
1
  module Techinform
2
- VERSION = "1.4.7"
2
+ VERSION = "1.6.0"
3
3
  end
@@ -7,11 +7,24 @@ Gem::Specification.new do |spec|
7
7
  spec.name = 'techinform'
8
8
  spec.version = Techinform::VERSION
9
9
  spec.authors = ['Alexey Chernikov']
10
- spec.email = ['alexey.chernikov@gmail.com']
10
+ spec.email = ['alexey@chernikov.online']
11
11
 
12
12
  spec.summary = %q{Console tools, useful at Techinform}
13
- spec.description = %q{Collection of console tools, which is useful for everyday work at Techinform.}
14
- spec.homepage = 'https://techinform.pro'
13
+ spec.description = %q{Collection of console tools, which is useful for everyday work at Techinform Soft ( https://techinform.dev )}
14
+ spec.homepage = 'https://techinform.dev'
15
+
16
+ # Prevent pushing this gem to RubyGems.org. To allow pushes either set the 'allowed_push_host'
17
+ # to allow pushing to a single host or delete this section to allow pushing to any host.
18
+ if spec.respond_to?(:metadata)
19
+ # spec.metadata["allowed_push_host"] = "https://rubygems.org"
20
+
21
+ spec.metadata["homepage_uri"] = spec.homepage
22
+ spec.metadata["source_code_uri"] = "https://github.com/alexey-chernikov/techinform"
23
+ spec.metadata["changelog_uri"] = "https://github.com/alexey-chernikov/techinform/CHANGELOG.md"
24
+ else
25
+ raise "RubyGems 2.0 or newer is required to protect against " \
26
+ "public gem pushes."
27
+ end
15
28
 
16
29
  spec.files = `git ls-files -z`.split("\x0").reject do |f|
17
30
  f.match(%r{^(test|spec|features)/})
@@ -25,7 +38,7 @@ Gem::Specification.new do |spec|
25
38
  spec.add_dependency 'thor', '~> 0.20'
26
39
  spec.add_dependency 'highline', '~> 2.0'
27
40
 
28
- spec.add_development_dependency 'bundler', '~> 1.15'
29
- spec.add_development_dependency 'rake', '~> 10.0'
41
+ spec.add_development_dependency 'bundler', '~> 2.1'
42
+ spec.add_development_dependency 'rake', '~> 13.0.1'
30
43
  spec.add_development_dependency 'minitest', '~> 5.0'
31
44
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: techinform
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.4.7
4
+ version: 1.6.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Alexey Chernikov
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2019-07-14 00:00:00.000000000 Z
11
+ date: 2020-12-19 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: thor
@@ -44,28 +44,28 @@ dependencies:
44
44
  requirements:
45
45
  - - "~>"
46
46
  - !ruby/object:Gem::Version
47
- version: '1.15'
47
+ version: '2.1'
48
48
  type: :development
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
52
  - - "~>"
53
53
  - !ruby/object:Gem::Version
54
- version: '1.15'
54
+ version: '2.1'
55
55
  - !ruby/object:Gem::Dependency
56
56
  name: rake
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
59
  - - "~>"
60
60
  - !ruby/object:Gem::Version
61
- version: '10.0'
61
+ version: 13.0.1
62
62
  type: :development
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: '10.0'
68
+ version: 13.0.1
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: minitest
71
71
  requirement: !ruby/object:Gem::Requirement
@@ -80,17 +80,20 @@ dependencies:
80
80
  - - "~>"
81
81
  - !ruby/object:Gem::Version
82
82
  version: '5.0'
83
- description: Collection of console tools, which is useful for everyday work at Techinform.
83
+ description: Collection of console tools, which is useful for everyday work at Techinform
84
+ Soft ( https://techinform.dev )
84
85
  email:
85
- - alexey.chernikov@gmail.com
86
+ - alexey@chernikov.online
86
87
  executables:
87
88
  - techinform
88
89
  - ti
89
90
  extensions: []
90
91
  extra_rdoc_files: []
91
92
  files:
93
+ - ".github/workflows/gempush.yml"
92
94
  - ".gitignore"
93
95
  - ".ruby-version"
96
+ - CHANGELOG.md
94
97
  - CODE_OF_CONDUCT.md
95
98
  - Gemfile
96
99
  - README.md
@@ -106,6 +109,7 @@ files:
106
109
  - lib/backup/files_backup.rb
107
110
  - lib/backup/mysql_backup.rb
108
111
  - lib/backup/postgre_backup.rb
112
+ - lib/bzip2_selector.rb
109
113
  - lib/techinform.rb
110
114
  - lib/techinform/backup.rb
111
115
  - lib/techinform/defaults.rb
@@ -113,10 +117,13 @@ files:
113
117
  - lib/techinform/sync/rails_exclude_files
114
118
  - lib/techinform/version.rb
115
119
  - techinform.gemspec
116
- homepage: https://techinform.pro
120
+ homepage: https://techinform.dev
117
121
  licenses:
118
122
  - MIT
119
- metadata: {}
123
+ metadata:
124
+ homepage_uri: https://techinform.dev
125
+ source_code_uri: https://github.com/alexey-chernikov/techinform
126
+ changelog_uri: https://github.com/alexey-chernikov/techinform/CHANGELOG.md
120
127
  post_install_message:
121
128
  rdoc_options: []
122
129
  require_paths:
@@ -132,7 +139,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
132
139
  - !ruby/object:Gem::Version
133
140
  version: '0'
134
141
  requirements: []
135
- rubygems_version: 3.0.3
142
+ rubygems_version: 3.1.4
136
143
  signing_key:
137
144
  specification_version: 4
138
145
  summary: Console tools, useful at Techinform