mirror of
https://github.com/internetee/registry.git
synced 2025-06-08 05:34:46 +02:00
Merge pull request #1495 from internetee/846-upgrade-rails-to-5.1
Raise ruby version to 2.6.3, raise some gem versions
This commit is contained in:
commit
199d3931c1
39 changed files with 254 additions and 278 deletions
|
@ -1 +1 @@
|
||||||
2.4.7
|
2.6.3
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
FROM internetee/ruby:2.4
|
FROM internetee/ruby:2.6-buster
|
||||||
|
|
||||||
RUN mkdir -p /opt/webapps/app/tmp/pids
|
RUN mkdir -p /opt/webapps/app/tmp/pids
|
||||||
WORKDIR /opt/webapps/app
|
WORKDIR /opt/webapps/app
|
||||||
|
|
10
Gemfile
10
Gemfile
|
@ -1,8 +1,8 @@
|
||||||
source 'https://rubygems.org'
|
source 'https://rubygems.org'
|
||||||
|
|
||||||
# core
|
# core
|
||||||
gem 'iso8601', '0.8.6' # for dates and times
|
gem 'iso8601', '0.12.1' # for dates and times
|
||||||
gem 'rails', '~> 5.0.7'
|
gem 'rails', '~> 5.1.7'
|
||||||
gem 'rest-client'
|
gem 'rest-client'
|
||||||
gem 'uglifier'
|
gem 'uglifier'
|
||||||
|
|
||||||
|
@ -10,11 +10,11 @@ gem 'uglifier'
|
||||||
gem 'figaro', '1.1.1'
|
gem 'figaro', '1.1.1'
|
||||||
|
|
||||||
# model related
|
# model related
|
||||||
gem 'pg', '0.19.0'
|
gem 'paper_trail', '~> 8.1'
|
||||||
|
gem 'pg', '1.2.2'
|
||||||
# 1.8 is for Rails < 5.0
|
# 1.8 is for Rails < 5.0
|
||||||
gem 'ransack', '~> 1.8'
|
gem 'ransack', '~> 1.8'
|
||||||
gem 'validates_email_format_of', '1.6.3' # validates email against RFC 2822 and RFC 3696
|
gem 'validates_email_format_of', '1.6.3' # validates email against RFC 2822 and RFC 3696
|
||||||
gem 'paper_trail', '~> 4.0'
|
|
||||||
|
|
||||||
# 0.7.3 is the latest for Rails 4.2, however, it is absent on Rubygems server
|
# 0.7.3 is the latest for Rails 4.2, however, it is absent on Rubygems server
|
||||||
# https://github.com/huacnlee/rails-settings-cached/issues/165
|
# https://github.com/huacnlee/rails-settings-cached/issues/165
|
||||||
|
@ -84,8 +84,8 @@ end
|
||||||
group :test do
|
group :test do
|
||||||
gem 'capybara'
|
gem 'capybara'
|
||||||
gem 'database_cleaner'
|
gem 'database_cleaner'
|
||||||
|
gem 'minitest', '~> 5.14'
|
||||||
gem 'simplecov', require: false
|
gem 'simplecov', require: false
|
||||||
gem 'webdrivers'
|
gem 'webdrivers'
|
||||||
gem 'webmock'
|
gem 'webmock'
|
||||||
gem 'minitest', '~> 5.10.0'
|
|
||||||
end
|
end
|
||||||
|
|
251
Gemfile.lock
251
Gemfile.lock
|
@ -27,7 +27,7 @@ GIT
|
||||||
|
|
||||||
GIT
|
GIT
|
||||||
remote: https://github.com/internetee/epp.git
|
remote: https://github.com/internetee/epp.git
|
||||||
revision: 76f9fd487d0ca3865b6f706c5a72703951c03996
|
revision: af7cefda37ac81d14b1d12641cde410776082d59
|
||||||
branch: master
|
branch: master
|
||||||
specs:
|
specs:
|
||||||
epp (1.5.0)
|
epp (1.5.0)
|
||||||
|
@ -58,70 +58,66 @@ GIT
|
||||||
GEM
|
GEM
|
||||||
remote: https://rubygems.org/
|
remote: https://rubygems.org/
|
||||||
specs:
|
specs:
|
||||||
actioncable (5.0.7.2)
|
actioncable (5.1.7)
|
||||||
actionpack (= 5.0.7.2)
|
actionpack (= 5.1.7)
|
||||||
nio4r (>= 1.2, < 3.0)
|
nio4r (~> 2.0)
|
||||||
websocket-driver (~> 0.6.1)
|
websocket-driver (~> 0.6.1)
|
||||||
actionmailer (5.0.7.2)
|
actionmailer (5.1.7)
|
||||||
actionpack (= 5.0.7.2)
|
actionpack (= 5.1.7)
|
||||||
actionview (= 5.0.7.2)
|
actionview (= 5.1.7)
|
||||||
activejob (= 5.0.7.2)
|
activejob (= 5.1.7)
|
||||||
mail (~> 2.5, >= 2.5.4)
|
mail (~> 2.5, >= 2.5.4)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
actionpack (5.0.7.2)
|
actionpack (5.1.7)
|
||||||
actionview (= 5.0.7.2)
|
actionview (= 5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
rack (~> 2.0)
|
rack (~> 2.0)
|
||||||
rack-test (~> 0.6.3)
|
rack-test (>= 0.6.3)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
rails-html-sanitizer (~> 1.0, >= 1.0.2)
|
rails-html-sanitizer (~> 1.0, >= 1.0.2)
|
||||||
actionview (5.0.7.2)
|
actionview (5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
builder (~> 3.1)
|
builder (~> 3.1)
|
||||||
erubis (~> 2.7.0)
|
erubi (~> 1.4)
|
||||||
rails-dom-testing (~> 2.0)
|
rails-dom-testing (~> 2.0)
|
||||||
rails-html-sanitizer (~> 1.0, >= 1.0.3)
|
rails-html-sanitizer (~> 1.0, >= 1.0.3)
|
||||||
activejob (5.0.7.2)
|
activejob (5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
globalid (>= 0.3.6)
|
globalid (>= 0.3.6)
|
||||||
activemodel (5.0.7.2)
|
activemodel (5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
activerecord (5.0.7.2)
|
activerecord (5.1.7)
|
||||||
activemodel (= 5.0.7.2)
|
activemodel (= 5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
arel (~> 7.0)
|
arel (~> 8.0)
|
||||||
activesupport (5.0.7.2)
|
activesupport (5.1.7)
|
||||||
concurrent-ruby (~> 1.0, >= 1.0.2)
|
concurrent-ruby (~> 1.0, >= 1.0.2)
|
||||||
i18n (>= 0.7, < 2)
|
i18n (>= 0.7, < 2)
|
||||||
minitest (~> 5.1)
|
minitest (~> 5.1)
|
||||||
tzinfo (~> 1.1)
|
tzinfo (~> 1.1)
|
||||||
addressable (2.7.0)
|
addressable (2.7.0)
|
||||||
public_suffix (>= 2.0.2, < 5.0)
|
public_suffix (>= 2.0.2, < 5.0)
|
||||||
airbrake (9.4.5)
|
airbrake (10.0.1)
|
||||||
airbrake-ruby (~> 4.7)
|
airbrake-ruby (~> 4.13)
|
||||||
airbrake-ruby (4.7.1)
|
airbrake-ruby (4.13.0)
|
||||||
rbtree3 (~> 0.5)
|
rbtree3 (~> 0.5)
|
||||||
akami (1.3.1)
|
akami (1.3.1)
|
||||||
gyoku (>= 0.4.0)
|
gyoku (>= 0.4.0)
|
||||||
nokogiri
|
nokogiri
|
||||||
arel (7.1.4)
|
arel (8.0.0)
|
||||||
autodoc (0.7.3)
|
autodoc (0.7.3)
|
||||||
actionpack
|
actionpack
|
||||||
activesupport (>= 3.0.0)
|
activesupport (>= 3.0.0)
|
||||||
rspec
|
rspec
|
||||||
autoprefixer-rails (9.6.5)
|
autoprefixer-rails (9.7.4)
|
||||||
execjs
|
execjs
|
||||||
axiom-types (0.1.1)
|
|
||||||
descendants_tracker (~> 0.0.4)
|
|
||||||
ice_nine (~> 0.11.0)
|
|
||||||
thread_safe (~> 0.3, >= 0.3.1)
|
|
||||||
bcrypt (3.1.13)
|
bcrypt (3.1.13)
|
||||||
bootstrap-sass (3.4.1)
|
bootstrap-sass (3.4.1)
|
||||||
autoprefixer-rails (>= 5.2.1)
|
autoprefixer-rails (>= 5.2.1)
|
||||||
sassc (>= 2.0.0)
|
sassc (>= 2.0.0)
|
||||||
builder (3.2.3)
|
builder (3.2.4)
|
||||||
cancancan (3.0.1)
|
cancancan (3.0.2)
|
||||||
capybara (3.29.0)
|
capybara (3.31.0)
|
||||||
addressable
|
addressable
|
||||||
mini_mime (>= 0.1.3)
|
mini_mime (>= 0.1.3)
|
||||||
nokogiri (~> 1.8)
|
nokogiri (~> 1.8)
|
||||||
|
@ -132,8 +128,6 @@ GEM
|
||||||
childprocess (3.0.0)
|
childprocess (3.0.0)
|
||||||
chronic (0.10.2)
|
chronic (0.10.2)
|
||||||
coderay (1.1.0)
|
coderay (1.1.0)
|
||||||
coercible (1.0.0)
|
|
||||||
descendants_tracker (~> 0.0.1)
|
|
||||||
coffee-rails (4.2.2)
|
coffee-rails (4.2.2)
|
||||||
coffee-script (>= 2.2.0)
|
coffee-script (>= 2.2.0)
|
||||||
railties (>= 4.0.0)
|
railties (>= 4.0.0)
|
||||||
|
@ -148,16 +142,14 @@ GEM
|
||||||
unicode_utils (~> 1.4)
|
unicode_utils (~> 1.4)
|
||||||
crack (0.4.3)
|
crack (0.4.3)
|
||||||
safe_yaml (~> 1.0.0)
|
safe_yaml (~> 1.0.0)
|
||||||
crass (1.0.5)
|
crass (1.0.6)
|
||||||
daemons (1.3.1)
|
daemons (1.3.1)
|
||||||
daemons-rails (1.2.1)
|
daemons-rails (1.2.1)
|
||||||
daemons
|
daemons
|
||||||
multi_json (~> 1.0)
|
multi_json (~> 1.0)
|
||||||
data_migrate (6.0.5)
|
data_migrate (6.2.0)
|
||||||
rails (>= 5.0)
|
rails (>= 5.0)
|
||||||
database_cleaner (1.7.0)
|
database_cleaner (1.8.2)
|
||||||
descendants_tracker (0.0.4)
|
|
||||||
thread_safe (~> 0.3, >= 0.3.1)
|
|
||||||
devise (4.7.1)
|
devise (4.7.1)
|
||||||
bcrypt (~> 3.0)
|
bcrypt (~> 3.0)
|
||||||
orm_adapter (~> 0.1)
|
orm_adapter (~> 0.1)
|
||||||
|
@ -168,21 +160,42 @@ GEM
|
||||||
docile (1.3.2)
|
docile (1.3.2)
|
||||||
domain_name (0.5.20190701)
|
domain_name (0.5.20190701)
|
||||||
unf (>= 0.0.5, < 1.0.0)
|
unf (>= 0.0.5, < 1.0.0)
|
||||||
equalizer (0.0.11)
|
dry-configurable (0.9.0)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
dry-core (~> 0.4, >= 0.4.7)
|
||||||
|
dry-container (0.7.2)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
dry-configurable (~> 0.1, >= 0.1.3)
|
||||||
|
dry-core (0.4.9)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
dry-equalizer (0.3.0)
|
||||||
|
dry-inflector (0.2.0)
|
||||||
|
dry-logic (1.0.5)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
dry-core (~> 0.2)
|
||||||
|
dry-equalizer (~> 0.2)
|
||||||
|
dry-types (1.2.2)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
dry-container (~> 0.3)
|
||||||
|
dry-core (~> 0.4, >= 0.4.4)
|
||||||
|
dry-equalizer (~> 0.3)
|
||||||
|
dry-inflector (~> 0.1, >= 0.1.2)
|
||||||
|
dry-logic (~> 1.0, >= 1.0.2)
|
||||||
|
erubi (1.9.0)
|
||||||
erubis (2.7.0)
|
erubis (2.7.0)
|
||||||
execjs (2.7.0)
|
execjs (2.7.0)
|
||||||
ffi (1.11.1)
|
ffi (1.12.2)
|
||||||
figaro (1.1.1)
|
figaro (1.1.1)
|
||||||
thor (~> 0.14)
|
thor (~> 0.14)
|
||||||
globalid (0.4.2)
|
globalid (0.4.2)
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
grape (1.2.4)
|
grape (1.3.0)
|
||||||
activesupport
|
activesupport
|
||||||
builder
|
builder
|
||||||
|
dry-types (>= 1.1)
|
||||||
mustermann-grape (~> 1.0.0)
|
mustermann-grape (~> 1.0.0)
|
||||||
rack (>= 1.3.0)
|
rack (>= 1.3.0)
|
||||||
rack-accept
|
rack-accept
|
||||||
virtus (>= 1.0.0)
|
|
||||||
gyoku (1.3.1)
|
gyoku (1.3.1)
|
||||||
builder (>= 2.1.2)
|
builder (>= 2.1.2)
|
||||||
haml (5.1.2)
|
haml (5.1.2)
|
||||||
|
@ -197,12 +210,11 @@ GEM
|
||||||
httpi (2.4.4)
|
httpi (2.4.4)
|
||||||
rack
|
rack
|
||||||
socksify
|
socksify
|
||||||
i18n (1.7.0)
|
i18n (1.8.2)
|
||||||
concurrent-ruby (~> 1.0)
|
concurrent-ruby (~> 1.0)
|
||||||
i18n_data (0.8.0)
|
i18n_data (0.8.0)
|
||||||
ice_nine (0.11.2)
|
|
||||||
isikukood (0.1.2)
|
isikukood (0.1.2)
|
||||||
iso8601 (0.8.6)
|
iso8601 (0.12.1)
|
||||||
jquery-rails (4.3.5)
|
jquery-rails (4.3.5)
|
||||||
rails-dom-testing (>= 1, < 3)
|
rails-dom-testing (>= 1, < 3)
|
||||||
railties (>= 4.2.0)
|
railties (>= 4.2.0)
|
||||||
|
@ -210,27 +222,27 @@ GEM
|
||||||
jquery-ui-rails (5.0.5)
|
jquery-ui-rails (5.0.5)
|
||||||
railties (>= 3.2.16)
|
railties (>= 3.2.16)
|
||||||
json (1.8.6)
|
json (1.8.6)
|
||||||
kaminari (1.1.1)
|
kaminari (1.2.0)
|
||||||
activesupport (>= 4.1.0)
|
activesupport (>= 4.1.0)
|
||||||
kaminari-actionview (= 1.1.1)
|
kaminari-actionview (= 1.2.0)
|
||||||
kaminari-activerecord (= 1.1.1)
|
kaminari-activerecord (= 1.2.0)
|
||||||
kaminari-core (= 1.1.1)
|
kaminari-core (= 1.2.0)
|
||||||
kaminari-actionview (1.1.1)
|
kaminari-actionview (1.2.0)
|
||||||
actionview
|
actionview
|
||||||
kaminari-core (= 1.1.1)
|
kaminari-core (= 1.2.0)
|
||||||
kaminari-activerecord (1.1.1)
|
kaminari-activerecord (1.2.0)
|
||||||
activerecord
|
activerecord
|
||||||
kaminari-core (= 1.1.1)
|
kaminari-core (= 1.2.0)
|
||||||
kaminari-core (1.1.1)
|
kaminari-core (1.2.0)
|
||||||
keystores (0.4.0)
|
keystores (0.4.0)
|
||||||
libxml-ruby (3.1.0)
|
libxml-ruby (3.1.0)
|
||||||
loofah (2.3.1)
|
loofah (2.4.0)
|
||||||
crass (~> 1.0.2)
|
crass (~> 1.0.2)
|
||||||
nokogiri (>= 1.5.9)
|
nokogiri (>= 1.5.9)
|
||||||
mail (2.7.1)
|
mail (2.7.1)
|
||||||
mini_mime (>= 0.1.1)
|
mini_mime (>= 0.1.1)
|
||||||
method_source (0.8.2)
|
method_source (0.8.2)
|
||||||
mime-types (3.3)
|
mime-types (3.3.1)
|
||||||
mime-types-data (~> 3.2015)
|
mime-types-data (~> 3.2015)
|
||||||
mime-types-data (3.2019.1009)
|
mime-types-data (3.2019.1009)
|
||||||
mina (0.3.1)
|
mina (0.3.1)
|
||||||
|
@ -238,38 +250,38 @@ GEM
|
||||||
rake
|
rake
|
||||||
mini_mime (1.0.2)
|
mini_mime (1.0.2)
|
||||||
mini_portile2 (2.4.0)
|
mini_portile2 (2.4.0)
|
||||||
minitest (5.10.3)
|
minitest (5.14.0)
|
||||||
monetize (1.9.2)
|
monetize (1.9.4)
|
||||||
money (~> 6.12)
|
money (~> 6.12)
|
||||||
money (6.13.4)
|
money (6.13.7)
|
||||||
i18n (>= 0.6.4, <= 2)
|
i18n (>= 0.6.4, <= 2)
|
||||||
money-rails (1.13.2)
|
money-rails (1.13.3)
|
||||||
activesupport (>= 3.0)
|
activesupport (>= 3.0)
|
||||||
monetize (~> 1.9.0)
|
monetize (~> 1.9.0)
|
||||||
money (~> 6.13.2)
|
money (~> 6.13.2)
|
||||||
railties (>= 3.0)
|
railties (>= 3.0)
|
||||||
multi_json (1.14.1)
|
multi_json (1.14.1)
|
||||||
mustermann (1.0.3)
|
mustermann (1.1.1)
|
||||||
mustermann-grape (1.0.0)
|
ruby2_keywords (~> 0.0.1)
|
||||||
mustermann (~> 1.0.0)
|
mustermann-grape (1.0.1)
|
||||||
|
mustermann (>= 1.0.0)
|
||||||
netrc (0.11.0)
|
netrc (0.11.0)
|
||||||
nio4r (2.5.2)
|
nio4r (2.5.2)
|
||||||
nokogiri (1.10.4)
|
nokogiri (1.10.7)
|
||||||
mini_portile2 (~> 2.4.0)
|
mini_portile2 (~> 2.4.0)
|
||||||
nori (2.6.0)
|
nori (2.6.0)
|
||||||
open4 (1.3.4)
|
open4 (1.3.4)
|
||||||
orm_adapter (0.5.0)
|
orm_adapter (0.5.0)
|
||||||
paper_trail (4.2.0)
|
paper_trail (8.1.2)
|
||||||
activerecord (>= 3.0, < 6.0)
|
activerecord (>= 4.2, < 5.2)
|
||||||
activesupport (>= 3.0, < 6.0)
|
|
||||||
request_store (~> 1.1)
|
request_store (~> 1.1)
|
||||||
pdfkit (0.8.4.1)
|
pdfkit (0.8.4.1)
|
||||||
pg (0.19.0)
|
pg (1.2.2)
|
||||||
pry (0.10.1)
|
pry (0.10.1)
|
||||||
coderay (~> 1.1.0)
|
coderay (~> 1.1.0)
|
||||||
method_source (~> 0.8.1)
|
method_source (~> 0.8.1)
|
||||||
slop (~> 3.4)
|
slop (~> 3.4)
|
||||||
public_suffix (4.0.1)
|
public_suffix (4.0.3)
|
||||||
puma (4.3.1)
|
puma (4.3.1)
|
||||||
nio4r (~> 2.0)
|
nio4r (~> 2.0)
|
||||||
que (0.14.3)
|
que (0.14.3)
|
||||||
|
@ -277,25 +289,25 @@ GEM
|
||||||
erubis
|
erubis
|
||||||
que (~> 0.8)
|
que (~> 0.8)
|
||||||
sinatra
|
sinatra
|
||||||
rack (2.0.8)
|
rack (2.1.2)
|
||||||
rack-accept (0.4.5)
|
rack-accept (0.4.5)
|
||||||
rack (>= 0.4)
|
rack (>= 0.4)
|
||||||
rack-protection (2.0.7)
|
rack-protection (2.0.8.1)
|
||||||
rack
|
rack
|
||||||
rack-test (0.6.3)
|
rack-test (1.1.0)
|
||||||
rack (>= 1.0)
|
rack (>= 1.0, < 3)
|
||||||
railroady (1.3.0)
|
railroady (1.3.0)
|
||||||
rails (5.0.7.2)
|
rails (5.1.7)
|
||||||
actioncable (= 5.0.7.2)
|
actioncable (= 5.1.7)
|
||||||
actionmailer (= 5.0.7.2)
|
actionmailer (= 5.1.7)
|
||||||
actionpack (= 5.0.7.2)
|
actionpack (= 5.1.7)
|
||||||
actionview (= 5.0.7.2)
|
actionview (= 5.1.7)
|
||||||
activejob (= 5.0.7.2)
|
activejob (= 5.1.7)
|
||||||
activemodel (= 5.0.7.2)
|
activemodel (= 5.1.7)
|
||||||
activerecord (= 5.0.7.2)
|
activerecord (= 5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
bundler (>= 1.3.0)
|
bundler (>= 1.3.0)
|
||||||
railties (= 5.0.7.2)
|
railties (= 5.1.7)
|
||||||
sprockets-rails (>= 2.0.0)
|
sprockets-rails (>= 2.0.0)
|
||||||
rails-dom-testing (2.0.3)
|
rails-dom-testing (2.0.3)
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
|
@ -304,25 +316,25 @@ GEM
|
||||||
loofah (~> 2.3)
|
loofah (~> 2.3)
|
||||||
rails-settings-cached (0.7.2)
|
rails-settings-cached (0.7.2)
|
||||||
rails (>= 4.2.0)
|
rails (>= 4.2.0)
|
||||||
railties (5.0.7.2)
|
railties (5.1.7)
|
||||||
actionpack (= 5.0.7.2)
|
actionpack (= 5.1.7)
|
||||||
activesupport (= 5.0.7.2)
|
activesupport (= 5.1.7)
|
||||||
method_source
|
method_source
|
||||||
rake (>= 0.8.7)
|
rake (>= 0.8.7)
|
||||||
thor (>= 0.18.1, < 2.0)
|
thor (>= 0.18.1, < 2.0)
|
||||||
rake (13.0.0)
|
rake (13.0.1)
|
||||||
ransack (1.8.10)
|
ransack (1.8.10)
|
||||||
actionpack (>= 3.0, < 5.2)
|
actionpack (>= 3.0, < 5.2)
|
||||||
activerecord (>= 3.0, < 5.2)
|
activerecord (>= 3.0, < 5.2)
|
||||||
activesupport (>= 3.0, < 5.2)
|
activesupport (>= 3.0, < 5.2)
|
||||||
i18n
|
i18n
|
||||||
rb-fsevent (0.10.3)
|
rb-fsevent (0.10.3)
|
||||||
rb-inotify (0.10.0)
|
rb-inotify (0.10.1)
|
||||||
ffi (~> 1.0)
|
ffi (~> 1.0)
|
||||||
rbtree3 (0.5.0)
|
rbtree3 (0.6.0)
|
||||||
rdoc (4.3.0)
|
rdoc (4.3.0)
|
||||||
regexp_parser (1.6.0)
|
regexp_parser (1.6.0)
|
||||||
request_store (1.4.1)
|
request_store (1.5.0)
|
||||||
rack (>= 1.4)
|
rack (>= 1.4)
|
||||||
responders (3.0.0)
|
responders (3.0.0)
|
||||||
actionpack (>= 5.0)
|
actionpack (>= 5.0)
|
||||||
|
@ -336,16 +348,17 @@ GEM
|
||||||
rspec-core (~> 3.9.0)
|
rspec-core (~> 3.9.0)
|
||||||
rspec-expectations (~> 3.9.0)
|
rspec-expectations (~> 3.9.0)
|
||||||
rspec-mocks (~> 3.9.0)
|
rspec-mocks (~> 3.9.0)
|
||||||
rspec-core (3.9.0)
|
rspec-core (3.9.1)
|
||||||
rspec-support (~> 3.9.0)
|
rspec-support (~> 3.9.1)
|
||||||
rspec-expectations (3.9.0)
|
rspec-expectations (3.9.0)
|
||||||
diff-lcs (>= 1.2.0, < 2.0)
|
diff-lcs (>= 1.2.0, < 2.0)
|
||||||
rspec-support (~> 3.9.0)
|
rspec-support (~> 3.9.0)
|
||||||
rspec-mocks (3.9.0)
|
rspec-mocks (3.9.1)
|
||||||
diff-lcs (>= 1.2.0, < 2.0)
|
diff-lcs (>= 1.2.0, < 2.0)
|
||||||
rspec-support (~> 3.9.0)
|
rspec-support (~> 3.9.0)
|
||||||
rspec-support (3.9.0)
|
rspec-support (3.9.2)
|
||||||
rubyzip (2.0.0)
|
ruby2_keywords (0.0.2)
|
||||||
|
rubyzip (2.2.0)
|
||||||
safe_yaml (1.0.5)
|
safe_yaml (1.0.5)
|
||||||
sass (3.7.4)
|
sass (3.7.4)
|
||||||
sass-listen (~> 4.0.0)
|
sass-listen (~> 4.0.0)
|
||||||
|
@ -374,19 +387,18 @@ GEM
|
||||||
select2-rails (3.5.9.3)
|
select2-rails (3.5.9.3)
|
||||||
thor (~> 0.14)
|
thor (~> 0.14)
|
||||||
selectize-rails (0.12.1)
|
selectize-rails (0.12.1)
|
||||||
selenium-webdriver (3.142.6)
|
selenium-webdriver (3.142.7)
|
||||||
childprocess (>= 0.5, < 4.0)
|
childprocess (>= 0.5, < 4.0)
|
||||||
rubyzip (>= 1.2.2)
|
rubyzip (>= 1.2.2)
|
||||||
simplecov (0.17.1)
|
simplecov (0.18.1)
|
||||||
docile (~> 1.1)
|
docile (~> 1.1)
|
||||||
json (>= 1.8, < 3)
|
simplecov-html (~> 0.11.0)
|
||||||
simplecov-html (~> 0.10.0)
|
simplecov-html (0.11.0)
|
||||||
simplecov-html (0.10.2)
|
|
||||||
simpleidn (0.0.9)
|
simpleidn (0.0.9)
|
||||||
sinatra (2.0.7)
|
sinatra (2.0.8.1)
|
||||||
mustermann (~> 1.0)
|
mustermann (~> 1.0)
|
||||||
rack (~> 2.0)
|
rack (~> 2.0)
|
||||||
rack-protection (= 2.0.7)
|
rack-protection (= 2.0.8.1)
|
||||||
tilt (~> 2.0)
|
tilt (~> 2.0)
|
||||||
sixarm_ruby_unaccent (1.2.0)
|
sixarm_ruby_unaccent (1.2.0)
|
||||||
slop (3.6.0)
|
slop (3.6.0)
|
||||||
|
@ -402,7 +414,7 @@ GEM
|
||||||
thor (0.20.3)
|
thor (0.20.3)
|
||||||
thread_safe (0.3.6)
|
thread_safe (0.3.6)
|
||||||
tilt (2.0.10)
|
tilt (2.0.10)
|
||||||
tzinfo (1.2.5)
|
tzinfo (1.2.6)
|
||||||
thread_safe (~> 0.1)
|
thread_safe (~> 0.1)
|
||||||
uglifier (4.2.0)
|
uglifier (4.2.0)
|
||||||
execjs (>= 0.3.0, < 3)
|
execjs (>= 0.3.0, < 3)
|
||||||
|
@ -412,21 +424,16 @@ GEM
|
||||||
unicode_utils (1.4.0)
|
unicode_utils (1.4.0)
|
||||||
validates_email_format_of (1.6.3)
|
validates_email_format_of (1.6.3)
|
||||||
i18n
|
i18n
|
||||||
virtus (1.0.5)
|
|
||||||
axiom-types (~> 0.1)
|
|
||||||
coercible (~> 1.0)
|
|
||||||
descendants_tracker (~> 0.0, >= 0.0.3)
|
|
||||||
equalizer (~> 0.0, >= 0.0.9)
|
|
||||||
warden (1.2.8)
|
warden (1.2.8)
|
||||||
rack (>= 2.0.6)
|
rack (>= 2.0.6)
|
||||||
wasabi (3.5.0)
|
wasabi (3.5.0)
|
||||||
httpi (~> 2.0)
|
httpi (~> 2.0)
|
||||||
nokogiri (>= 1.4.2)
|
nokogiri (>= 1.4.2)
|
||||||
webdrivers (4.1.3)
|
webdrivers (4.2.0)
|
||||||
nokogiri (~> 1.6)
|
nokogiri (~> 1.6)
|
||||||
rubyzip (>= 1.3.0)
|
rubyzip (>= 1.3.0)
|
||||||
selenium-webdriver (>= 3.0, < 4.0)
|
selenium-webdriver (>= 3.0, < 4.0)
|
||||||
webmock (3.7.6)
|
webmock (3.8.0)
|
||||||
addressable (>= 2.3.6)
|
addressable (>= 2.3.6)
|
||||||
crack (>= 0.3.2)
|
crack (>= 0.3.2)
|
||||||
hashdiff (>= 0.4.0, < 2.0.0)
|
hashdiff (>= 0.4.0, < 2.0.0)
|
||||||
|
@ -435,7 +442,7 @@ GEM
|
||||||
websocket-extensions (0.1.4)
|
websocket-extensions (0.1.4)
|
||||||
whenever (0.9.4)
|
whenever (0.9.4)
|
||||||
chronic (>= 0.6.3)
|
chronic (>= 0.6.3)
|
||||||
wkhtmltopdf-binary (0.12.4)
|
wkhtmltopdf-binary (0.12.5.1)
|
||||||
xpath (3.2.0)
|
xpath (3.2.0)
|
||||||
nokogiri (~> 1.8)
|
nokogiri (~> 1.8)
|
||||||
|
|
||||||
|
@ -465,24 +472,24 @@ DEPENDENCIES
|
||||||
grape
|
grape
|
||||||
haml (~> 5.0)
|
haml (~> 5.0)
|
||||||
isikukood
|
isikukood
|
||||||
iso8601 (= 0.8.6)
|
iso8601 (= 0.12.1)
|
||||||
jquery-rails
|
jquery-rails
|
||||||
jquery-ui-rails (= 5.0.5)
|
jquery-ui-rails (= 5.0.5)
|
||||||
kaminari
|
kaminari
|
||||||
lhv!
|
lhv!
|
||||||
mina (= 0.3.1)
|
mina (= 0.3.1)
|
||||||
minitest (~> 5.10.0)
|
minitest (~> 5.14)
|
||||||
money-rails
|
money-rails
|
||||||
nokogiri
|
nokogiri
|
||||||
paper_trail (~> 4.0)
|
paper_trail (~> 8.1)
|
||||||
pdfkit
|
pdfkit
|
||||||
pg (= 0.19.0)
|
pg (= 1.2.2)
|
||||||
pry (= 0.10.1)
|
pry (= 0.10.1)
|
||||||
puma
|
puma
|
||||||
que
|
que
|
||||||
que-web
|
que-web
|
||||||
railroady (= 1.3.0)
|
railroady (= 1.3.0)
|
||||||
rails (~> 5.0.7)
|
rails (~> 5.1.7)
|
||||||
rails-settings-cached (= 0.7.2)
|
rails-settings-cached (= 0.7.2)
|
||||||
ransack (~> 1.8)
|
ransack (~> 1.8)
|
||||||
rest-client
|
rest-client
|
||||||
|
@ -500,4 +507,4 @@ DEPENDENCIES
|
||||||
wkhtmltopdf-binary
|
wkhtmltopdf-binary
|
||||||
|
|
||||||
BUNDLED WITH
|
BUNDLED WITH
|
||||||
2.0.2
|
2.1.4
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
class ApplicationController < ActionController::Base
|
class ApplicationController < ActionController::Base
|
||||||
check_authorization unless: :devise_controller?
|
check_authorization unless: :devise_controller?
|
||||||
|
before_action :set_paper_trail_whodunnit
|
||||||
|
|
||||||
# Prevent CSRF attacks by raising an exception.
|
# Prevent CSRF attacks by raising an exception.
|
||||||
# For APIs, you may want to use :null_session instead.
|
# For APIs, you may want to use :null_session instead.
|
||||||
|
@ -32,4 +33,4 @@ class ApplicationController < ActionController::Base
|
||||||
def available_languages
|
def available_languages
|
||||||
{ en: 'English', et: 'Estonian' }.invert
|
{ en: 'English', et: 'Estonian' }.invert
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -10,7 +10,7 @@ module Epp
|
||||||
before_action :latin_only
|
before_action :latin_only
|
||||||
before_action :validate_against_schema
|
before_action :validate_against_schema
|
||||||
before_action :validate_request
|
before_action :validate_request
|
||||||
before_action :update_epp_session, if: 'signed_in?'
|
before_action :update_epp_session, if: -> { signed_in? }
|
||||||
|
|
||||||
around_action :wrap_exceptions
|
around_action :wrap_exceptions
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@ module Epp
|
||||||
class DomainsController < BaseController
|
class DomainsController < BaseController
|
||||||
before_action :find_domain, only: %i[info renew update transfer delete]
|
before_action :find_domain, only: %i[info renew update transfer delete]
|
||||||
before_action :find_password, only: %i[info update transfer delete]
|
before_action :find_password, only: %i[info update transfer delete]
|
||||||
|
before_action :set_paper_trail_whodunnit
|
||||||
|
|
||||||
def info
|
def info
|
||||||
authorize! :info, @domain
|
authorize! :info, @domain
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
module Epp
|
module Epp
|
||||||
class SessionsController < BaseController
|
class SessionsController < BaseController
|
||||||
skip_authorization_check only: [:hello, :login, :logout]
|
skip_authorization_check only: [:hello, :login, :logout]
|
||||||
|
before_action :set_paper_trail_whodunnit
|
||||||
|
|
||||||
def hello
|
def hello
|
||||||
render_epp_response('greeting')
|
render_epp_response('greeting')
|
||||||
|
|
0
app/jobs/send_e_invoice_job.rb
Normal file
0
app/jobs/send_e_invoice_job.rb
Normal file
|
@ -4,7 +4,7 @@ class AdminUser < User
|
||||||
validates :identity_code, presence: true, if: -> { country_code == 'EE' }
|
validates :identity_code, presence: true, if: -> { country_code == 'EE' }
|
||||||
validates :email, presence: true
|
validates :email, presence: true
|
||||||
validates :password, :password_confirmation, presence: true, if: :new_record?
|
validates :password, :password_confirmation, presence: true, if: :new_record?
|
||||||
validates :password_confirmation, presence: true, if: :encrypted_password_changed?
|
validates :password_confirmation, presence: true, if: :will_save_change_to_encrypted_password?
|
||||||
validate :validate_identity_code, if: -> { country_code == 'EE' }
|
validate :validate_identity_code, if: -> { country_code == 'EE' }
|
||||||
|
|
||||||
ROLES = %w(user customer_service admin) # should not match to api_users roles
|
ROLES = %w(user customer_service admin) # should not match to api_users roles
|
||||||
|
|
|
@ -43,7 +43,7 @@ class ApiUser < User
|
||||||
after_initialize :set_defaults
|
after_initialize :set_defaults
|
||||||
def set_defaults
|
def set_defaults
|
||||||
return unless new_record?
|
return unless new_record?
|
||||||
self.active = true unless active_changed?
|
self.active = true unless saved_change_to_active?
|
||||||
end
|
end
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
|
|
|
@ -3,7 +3,7 @@ module Concerns::Contact::Transferable
|
||||||
|
|
||||||
included do
|
included do
|
||||||
validates :auth_info, presence: true
|
validates :auth_info, presence: true
|
||||||
after_initialize :generate_auth_info, if: 'new_record? && auth_info.blank?'
|
after_initialize :generate_auth_info, if: -> { new_record? && auth_info.blank? }
|
||||||
end
|
end
|
||||||
|
|
||||||
def transfer(new_registrar)
|
def transfer(new_registrar)
|
||||||
|
|
|
@ -45,17 +45,17 @@ module Versions
|
||||||
|
|
||||||
# callbacks
|
# callbacks
|
||||||
def touch_domain_version
|
def touch_domain_version
|
||||||
domain.try(:touch_with_version)
|
domain.paper_trail.try(:touch_with_version)
|
||||||
end
|
end
|
||||||
|
|
||||||
def touch_domains_version
|
def touch_domains_version
|
||||||
domains.each(&:touch_with_version)
|
domains.each { |domain| domain.paper_trail.touch_with_version }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
module ClassMethods
|
module ClassMethods
|
||||||
def all_versions_for(ids, time)
|
def all_versions_for(ids, time)
|
||||||
ver_klass = paper_trail_version_class
|
ver_klass = paper_trail.version_class
|
||||||
from_history = ver_klass.where(item_id: ids.to_a).
|
from_history = ver_klass.where(item_id: ids.to_a).
|
||||||
order(:item_id).
|
order(:item_id).
|
||||||
preceding(time + 1, true).
|
preceding(time + 1, true).
|
||||||
|
|
|
@ -23,12 +23,14 @@ class Contact < ApplicationRecord
|
||||||
accepts_nested_attributes_for :legal_documents
|
accepts_nested_attributes_for :legal_documents
|
||||||
|
|
||||||
validates :name, :email, presence: true
|
validates :name, :email, presence: true
|
||||||
validates :street, :city, :zip, :country_code, presence: true, if: 'self.class.address_processing?'
|
validates :street, :city, :zip, :country_code, presence: true, if: lambda {
|
||||||
|
self.class.address_processing?
|
||||||
|
}
|
||||||
|
|
||||||
validates :phone, presence: true, e164: true, phone: true
|
validates :phone, presence: true, e164: true, phone: true
|
||||||
|
|
||||||
validates :email, format: /@/
|
validates :email, format: /@/
|
||||||
validates :email, email_format: { message: :invalid }, if: proc { |c| c.email_changed? }
|
validates :email, email_format: { message: :invalid }, if: proc { |c| c.will_save_change_to_email? }
|
||||||
|
|
||||||
validates :code,
|
validates :code,
|
||||||
uniqueness: { message: :epp_id_taken },
|
uniqueness: { message: :epp_id_taken },
|
||||||
|
@ -37,7 +39,7 @@ class Contact < ApplicationRecord
|
||||||
validates_associated :identifier
|
validates_associated :identifier
|
||||||
|
|
||||||
validate :validate_html
|
validate :validate_html
|
||||||
validate :validate_country_code, if: 'self.class.address_processing?'
|
validate :validate_country_code, if: -> { self.class.address_processing? }
|
||||||
|
|
||||||
after_initialize do
|
after_initialize do
|
||||||
self.status_notes = {} if status_notes.nil?
|
self.status_notes = {} if status_notes.nil?
|
||||||
|
|
|
@ -9,10 +9,16 @@ class Dnskey < ApplicationRecord
|
||||||
validate :validate_protocol
|
validate :validate_protocol
|
||||||
validate :validate_flags
|
validate :validate_flags
|
||||||
|
|
||||||
before_save -> { generate_digest if public_key_changed? && !ds_digest_changed? }
|
before_save lambda {
|
||||||
|
generate_digest if will_save_change_to_public_key? && !will_save_change_to_ds_digest?
|
||||||
|
}
|
||||||
|
|
||||||
before_save lambda {
|
before_save lambda {
|
||||||
if (public_key_changed? || flags_changed? || alg_changed? || protocol_changed?) && !ds_key_tag_changed?
|
if (will_save_change_to_public_key? ||
|
||||||
|
will_save_change_to_flags? ||
|
||||||
|
will_save_change_to_alg? ||
|
||||||
|
will_save_change_to_protocol?) &&
|
||||||
|
!will_save_change_to_ds_key_tag?
|
||||||
generate_ds_key_tag
|
generate_ds_key_tag
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,12 +73,13 @@ class Domain < ApplicationRecord
|
||||||
|
|
||||||
before_update :manage_statuses
|
before_update :manage_statuses
|
||||||
def manage_statuses
|
def manage_statuses
|
||||||
return unless registrant_id_changed? # rollback has not yet happened
|
return unless will_save_change_to_registrant_id? # rollback has not yet happened
|
||||||
|
|
||||||
pending_update! if registrant_verification_asked?
|
pending_update! if registrant_verification_asked?
|
||||||
true
|
true
|
||||||
end
|
end
|
||||||
|
|
||||||
after_commit :update_whois_record, unless: 'domain_name.at_auction?'
|
after_commit :update_whois_record, unless: -> { domain_name.at_auction? }
|
||||||
|
|
||||||
after_create :update_reserved_domains
|
after_create :update_reserved_domains
|
||||||
def update_reserved_domains
|
def update_reserved_domains
|
||||||
|
@ -547,7 +548,7 @@ class Domain < ApplicationRecord
|
||||||
activate if nameservers.reject(&:marked_for_destruction?).size >= Setting.ns_min_count
|
activate if nameservers.reject(&:marked_for_destruction?).size >= Setting.ns_min_count
|
||||||
end
|
end
|
||||||
|
|
||||||
cancel_force_delete if force_delete_scheduled? && registrant_id_changed?
|
cancel_force_delete if force_delete_scheduled? && will_save_change_to_registrant_id?
|
||||||
|
|
||||||
if statuses.empty? && valid?
|
if statuses.empty? && valid?
|
||||||
statuses << DomainStatus::OK
|
statuses << DomainStatus::OK
|
||||||
|
|
|
@ -182,7 +182,7 @@ class Epp::Contact < Contact
|
||||||
|
|
||||||
self.attributes = at
|
self.attributes = at
|
||||||
|
|
||||||
email_changed = email_changed?
|
email_changed = will_save_change_to_email?
|
||||||
old_email = email_was
|
old_email = email_was
|
||||||
updated = save
|
updated = save
|
||||||
|
|
||||||
|
|
|
@ -21,9 +21,9 @@ class Registrar < ApplicationRecord
|
||||||
validates :reference_no, format: Billing::ReferenceNo::REGEXP
|
validates :reference_no, format: Billing::ReferenceNo::REGEXP
|
||||||
validate :forbid_special_code
|
validate :forbid_special_code
|
||||||
|
|
||||||
validates :vat_rate, presence: true, if: 'vat_liable_in_foreign_country? && vat_no.blank?'
|
validates :vat_rate, presence: true, if: -> { vat_liable_in_foreign_country? && vat_no.blank? }
|
||||||
validates :vat_rate, absence: true, if: :vat_liable_locally?
|
validates :vat_rate, absence: true, if: :vat_liable_locally?
|
||||||
validates :vat_rate, absence: true, if: 'vat_liable_in_foreign_country? && vat_no?'
|
validates :vat_rate, absence: true, if: -> { vat_liable_in_foreign_country? && vat_no? }
|
||||||
validates :vat_rate, numericality: { greater_than_or_equal_to: 0, less_than: 100 },
|
validates :vat_rate, numericality: { greater_than_or_equal_to: 0, less_than: 100 },
|
||||||
allow_nil: true
|
allow_nil: true
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ class Registrar < ApplicationRecord
|
||||||
after_initialize :set_defaults
|
after_initialize :set_defaults
|
||||||
|
|
||||||
validates :email, email_format: { message: :invalid },
|
validates :email, email_format: { message: :invalid },
|
||||||
allow_blank: true, if: proc { |c| c.email_changed? }
|
allow_blank: true, if: proc { |c| c.will_save_change_to_email? }
|
||||||
validates :billing_email, email_format: { message: :invalid }, allow_blank: true
|
validates :billing_email, email_format: { message: :invalid }, allow_blank: true
|
||||||
|
|
||||||
alias_attribute :contact_email, :email
|
alias_attribute :contact_email, :email
|
||||||
|
|
25
bin/setup
25
bin/setup
|
@ -1,33 +1,36 @@
|
||||||
#!/usr/bin/env ruby
|
#!/usr/bin/env ruby
|
||||||
require 'pathname'
|
require 'pathname'
|
||||||
require 'fileutils'
|
include FileUtils
|
||||||
|
|
||||||
# path to your application root.
|
# path to your application root.
|
||||||
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
|
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
|
||||||
|
|
||||||
|
|
||||||
def system!(*args)
|
def system!(*args)
|
||||||
system(*args) || abort("\n== Command #{args} failed ==")
|
system(*args) || abort("\n== Command #{args} failed ==")
|
||||||
end
|
end
|
||||||
|
|
||||||
Dir.chdir APP_ROOT do
|
chdir APP_ROOT do
|
||||||
|
# This script is a starting point to setup your application.
|
||||||
|
# Add necessary setup steps to this file.
|
||||||
|
|
||||||
puts '== Installing dependencies with bundler =='
|
puts '== Installing dependencies =='
|
||||||
system! 'gem install bundler --conservative'
|
system! 'gem install bundler --conservative'
|
||||||
system('bundle check') || system!('bundle install')
|
system('bundle check') || system!('bundle install')
|
||||||
|
|
||||||
puts "\n== Copying sample development database config files =="
|
# Install JavaScript dependencies if using Yarn
|
||||||
unless File.exist?('config/database.yml')
|
# system('bin/yarn')
|
||||||
system! 'cp config/database-example-development.yml config/database.yml'
|
|
||||||
end
|
puts "\n== Copying sample files =="
|
||||||
|
unless File.exist?('config/database.yml')
|
||||||
|
system! 'cp config/database.yml.sample config/database.yml'
|
||||||
|
end
|
||||||
|
|
||||||
puts "\n== Preparing database =="
|
puts "\n== Preparing database =="
|
||||||
system! 'bin/rails db:setup'
|
system! 'bin/rails db:setup'
|
||||||
|
|
||||||
puts "\n== Removing old logs and tempfiles =="
|
puts "\n== Removing old logs and tempfiles =="
|
||||||
system! 'bin/rake log:clear tmp:clear'
|
system! 'bin/rails log:clear tmp:clear'
|
||||||
|
|
||||||
puts "\n== Restarting application server =="
|
puts "\n== Restarting application server =="
|
||||||
system! 'touch tmp/restart.txt'
|
system! 'bin/rails restart'
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
0
bin/update
Normal file → Executable file
0
bin/update
Normal file → Executable file
11
bin/yarn
Executable file
11
bin/yarn
Executable file
|
@ -0,0 +1,11 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
VENDOR_PATH = File.expand_path('..', __dir__)
|
||||||
|
Dir.chdir(VENDOR_PATH) do
|
||||||
|
begin
|
||||||
|
exec "yarnpkg #{ARGV.join(" ")}"
|
||||||
|
rescue Errno::ENOENT
|
||||||
|
$stderr.puts "Yarn executable was not detected in the system."
|
||||||
|
$stderr.puts "Download Yarn at https://yarnpkg.com/en/docs/install"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
end
|
|
@ -16,6 +16,7 @@ end
|
||||||
|
|
||||||
module DomainNameRegistry
|
module DomainNameRegistry
|
||||||
class Application < Rails::Application
|
class Application < Rails::Application
|
||||||
|
config.load_defaults 5.1
|
||||||
# Settings in config/environments/* take precedence over those specified here.
|
# Settings in config/environments/* take precedence over those specified here.
|
||||||
# Application configuration should go into files in config/initializers
|
# Application configuration should go into files in config/initializers
|
||||||
# -- all .rb files in that directory are automatically loaded.
|
# -- all .rb files in that directory are automatically loaded.
|
||||||
|
|
|
@ -7,3 +7,4 @@ test:
|
||||||
production:
|
production:
|
||||||
adapter: redis
|
adapter: redis
|
||||||
url: redis://localhost:6379/1
|
url: redis://localhost:6379/1
|
||||||
|
channel_prefix: domain_name_registry_production
|
||||||
|
|
|
@ -66,7 +66,7 @@ Rails.application.configure do
|
||||||
|
|
||||||
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
||||||
# the I18n.default_locale when a translation cannot be found).
|
# the I18n.default_locale when a translation cannot be found).
|
||||||
config.i18n.fallbacks = [I18n.default_locale]
|
config.i18n.fallbacks = true
|
||||||
|
|
||||||
# Send deprecation notices to registered listeners.
|
# Send deprecation notices to registered listeners.
|
||||||
config.active_support.deprecation = :notify
|
config.active_support.deprecation = :notify
|
||||||
|
|
|
@ -5,7 +5,7 @@ Rails.application.configure do
|
||||||
config.assets.version = '1.0'
|
config.assets.version = '1.0'
|
||||||
|
|
||||||
# Add additional assets to the asset load path
|
# Add additional assets to the asset load path
|
||||||
config.assets.paths << Rails.root.join('vendor', 'assets', 'fonts')
|
config.assets.paths << Rails.root.join('vendor', 'assets', 'fonts', 'node_modules')
|
||||||
|
|
||||||
# Precompile additional assets.
|
# Precompile additional assets.
|
||||||
# application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
|
# application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
|
||||||
|
@ -14,4 +14,5 @@ Rails.application.configure do
|
||||||
config.assets.precompile += %w(admin-manifest.css admin-manifest.js)
|
config.assets.precompile += %w(admin-manifest.css admin-manifest.js)
|
||||||
config.assets.precompile += %w(registrar-manifest.css registrar-manifest.js)
|
config.assets.precompile += %w(registrar-manifest.css registrar-manifest.js)
|
||||||
config.assets.precompile += %w(registrant-manifest.css registrant-manifest.js)
|
config.assets.precompile += %w(registrant-manifest.css registrant-manifest.js)
|
||||||
|
config.assets.precompile += %w( admin.js admin.css )
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
MoneyRails.configure do |config|
|
MoneyRails.configure do |config|
|
||||||
# Wrapper for Money#default_currency with additional functionality
|
# Wrapper for Money#default_currency with additional functionality
|
||||||
config.default_currency = :eur
|
config.default_currency = :eur
|
||||||
end
|
config.rounding_mode = BigDecimal::ROUND_HALF_EVEN
|
||||||
|
config.locale_backend = :i18n
|
||||||
|
end
|
||||||
|
|
|
@ -6,7 +6,8 @@
|
||||||
#
|
#
|
||||||
# Read the Guide for Upgrading Ruby on Rails for more info on each option.
|
# Read the Guide for Upgrading Ruby on Rails for more info on each option.
|
||||||
|
|
||||||
Rails.application.config.action_controller.raise_on_unfiltered_parameters = true
|
# DEPRECATION WARNING: raise_on_unfiltered_parameters is deprecated and has no effect in Rails 5.1.
|
||||||
|
#Rails.application.config.action_controller.raise_on_unfiltered_parameters = true
|
||||||
|
|
||||||
# Enable per-form CSRF tokens. Previous versions had false.
|
# Enable per-form CSRF tokens. Previous versions had false.
|
||||||
Rails.application.config.action_controller.per_form_csrf_tokens = true
|
Rails.application.config.action_controller.per_form_csrf_tokens = true
|
||||||
|
@ -19,7 +20,9 @@ Rails.application.config.action_controller.forgery_protection_origin_check = tru
|
||||||
ActiveSupport.to_time_preserves_timezone = true
|
ActiveSupport.to_time_preserves_timezone = true
|
||||||
|
|
||||||
# Do not halt callback chains when a callback returns false. Previous versions had true.
|
# Do not halt callback chains when a callback returns false. Previous versions had true.
|
||||||
ActiveSupport.halt_callback_chains_on_return_false = false
|
# DEPRECATION WARNING: ActiveSupport.halt_callback_chains_on_return_false= is deprecated and
|
||||||
|
# will be removed in Rails 5.2.
|
||||||
|
#ActiveSupport.halt_callback_chains_on_return_false = false
|
||||||
|
|
||||||
# Configure SSL options to enable HSTS with subdomains. Previous versions had false.
|
# Configure SSL options to enable HSTS with subdomains. Previous versions had false.
|
||||||
Rails.application.config.ssl_options = { hsts: { subdomains: true } }
|
Rails.application.config.ssl_options = { hsts: { subdomains: true } }
|
||||||
|
|
14
config/initializers/new_framework_defaults_5_1.rb
Normal file
14
config/initializers/new_framework_defaults_5_1.rb
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
# Be sure to restart your server when you modify this file.
|
||||||
|
#
|
||||||
|
# This file contains migration options to ease your Rails 5.1 upgrade.
|
||||||
|
#
|
||||||
|
# Once upgraded flip defaults one by one to migrate to the new default.
|
||||||
|
#
|
||||||
|
# Read the Guide for Upgrading Ruby on Rails for more info on each option.
|
||||||
|
|
||||||
|
# Make `form_with` generate non-remote forms.
|
||||||
|
Rails.application.config.action_view.form_with_generates_remote_forms = false
|
||||||
|
|
||||||
|
# Unknown asset fallback will return the path passed in when the given
|
||||||
|
# asset is not present in the asset pipeline.
|
||||||
|
# Rails.application.config.assets.unknown_asset_fallback = false
|
1
config/initializers/paper_trail.rb
Normal file
1
config/initializers/paper_trail.rb
Normal file
|
@ -0,0 +1 @@
|
||||||
|
PaperTrail.config.track_associations = false
|
|
@ -1,13 +1,13 @@
|
||||||
# Puma can serve each request in a thread from an internal thread pool.
|
# Puma can serve each request in a thread from an internal thread pool.
|
||||||
# The `threads` method setting takes two numbers a minimum and maximum.
|
# The `threads` method setting takes two numbers: a minimum and maximum.
|
||||||
# Any libraries that use thread pools should be configured to match
|
# Any libraries that use thread pools should be configured to match
|
||||||
# the maximum value specified for Puma. Default is set to 5 threads for minimum
|
# the maximum value specified for Puma. Default is set to 5 threads for minimum
|
||||||
# and maximum, this matches the default thread size of Active Record.
|
# and maximum; this matches the default thread size of Active Record.
|
||||||
#
|
#
|
||||||
threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }.to_i
|
threads_count = ENV.fetch("RAILS_MAX_THREADS") { 5 }
|
||||||
threads threads_count, threads_count
|
threads threads_count, threads_count
|
||||||
|
|
||||||
# Specifies the `port` that Puma will listen on to receive requests, default is 3000.
|
# Specifies the `port` that Puma will listen on to receive requests; default is 3000.
|
||||||
#
|
#
|
||||||
port ENV.fetch("PORT") { 3000 }
|
port ENV.fetch("PORT") { 3000 }
|
||||||
|
|
||||||
|
@ -32,16 +32,25 @@ environment ENV.fetch("RAILS_ENV") { "development" }
|
||||||
#
|
#
|
||||||
# preload_app!
|
# preload_app!
|
||||||
|
|
||||||
|
# If you are preloading your application and using Active Record, it's
|
||||||
|
# recommended that you close any connections to the database before workers
|
||||||
|
# are forked to prevent connection leakage.
|
||||||
|
#
|
||||||
|
# before_fork do
|
||||||
|
# ActiveRecord::Base.connection_pool.disconnect! if defined?(ActiveRecord)
|
||||||
|
# end
|
||||||
|
|
||||||
# The code in the `on_worker_boot` will be called if you are using
|
# The code in the `on_worker_boot` will be called if you are using
|
||||||
# clustered mode by specifying a number of `workers`. After each worker
|
# clustered mode by specifying a number of `workers`. After each worker
|
||||||
# process is booted this block will be run, if you are using `preload_app!`
|
# process is booted, this block will be run. If you are using the `preload_app!`
|
||||||
# option you will want to use this block to reconnect to any threads
|
# option, you will want to use this block to reconnect to any threads
|
||||||
# or connections that may have been created at application boot, Ruby
|
# or connections that may have been created at application boot, as Ruby
|
||||||
# cannot share connections between processes.
|
# cannot share connections between processes.
|
||||||
#
|
#
|
||||||
# on_worker_boot do
|
# on_worker_boot do
|
||||||
# ActiveRecord::Base.establish_connection if defined?(ActiveRecord)
|
# ActiveRecord::Base.establish_connection if defined?(ActiveRecord)
|
||||||
# end
|
# end
|
||||||
|
#
|
||||||
|
|
||||||
# Allow puma to be restarted by `rails restart` command.
|
# Allow puma to be restarted by `rails restart` command.
|
||||||
plugin :tmp_restart
|
plugin :tmp_restart
|
||||||
|
|
6
config/spring.rb
Normal file
6
config/spring.rb
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
%w(
|
||||||
|
.ruby-version
|
||||||
|
.rbenv-vars
|
||||||
|
tmp/restart.txt
|
||||||
|
tmp/caching-dev.txt
|
||||||
|
).each { |path| Spring.watch(path) }
|
|
@ -25,7 +25,7 @@ class RegistrantApiRegistryLocksTest < ApplicationIntegrationTest
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_locking_a_domain_creates_a_version_record
|
def test_locking_a_domain_creates_a_version_record
|
||||||
assert_difference '@domain.versions.count', 1 do
|
assert_difference '@domain.versions.count', 2 do
|
||||||
post '/api/v1/registrant/domains/2df2c1a1-8f6a-490a-81be-8bdf29866880/registry_lock',
|
post '/api/v1/registrant/domains/2df2c1a1-8f6a-490a-81be-8bdf29866880/registry_lock',
|
||||||
headers: @auth_headers
|
headers: @auth_headers
|
||||||
end
|
end
|
||||||
|
|
|
@ -5,7 +5,7 @@ class ContactAuditLogTest < ActionDispatch::IntegrationTest
|
||||||
contact = contacts(:john)
|
contact = contacts(:john)
|
||||||
|
|
||||||
contact.legal_document_id = 1
|
contact.legal_document_id = 1
|
||||||
assert_difference 'contact.versions.count' do
|
assert_difference 'contact.versions.count', 2 do
|
||||||
contact.save!
|
contact.save!
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -13,4 +13,4 @@ class ContactAuditLogTest < ActionDispatch::IntegrationTest
|
||||||
assert_equal ({ legal_documents: [1] }).with_indifferent_access,
|
assert_equal ({ legal_documents: [1] }).with_indifferent_access,
|
||||||
contact_version.children.with_indifferent_access
|
contact_version.children.with_indifferent_access
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -14,7 +14,7 @@ class DomainAuditLogTest < ActionDispatch::IntegrationTest
|
||||||
assert_equal registrant_id, domain.registrant_id
|
assert_equal registrant_id, domain.registrant_id
|
||||||
domain.legal_document_id = legal_document_id
|
domain.legal_document_id = legal_document_id
|
||||||
|
|
||||||
assert_difference 'domain.versions.count' do
|
assert_difference 'domain.versions.count', 2 do
|
||||||
domain.save!
|
domain.save!
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -26,4 +26,4 @@ class DomainAuditLogTest < ActionDispatch::IntegrationTest
|
||||||
assert_equal [legal_document_id], domain_version.children['legal_documents']
|
assert_equal [legal_document_id], domain_version.children['legal_documents']
|
||||||
assert_equal [registrant_id], domain_version.children['registrant']
|
assert_equal [registrant_id], domain_version.children['registrant']
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -40,7 +40,7 @@ class PaperTrailLearningTest < ActiveSupport::TestCase
|
||||||
@record = Post.create!(title: 'any')
|
@record = Post.create!(title: 'any')
|
||||||
|
|
||||||
assert_difference -> { @record.versions.size } do
|
assert_difference -> { @record.versions.size } do
|
||||||
@record.touch_with_version
|
@record.paper_trail.touch_with_version
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,6 +13,8 @@ class AuctionDoubleTest < ActiveSupport::TestCase
|
||||||
end
|
end
|
||||||
|
|
||||||
class DNS::DomainNameTest < ActiveSupport::TestCase
|
class DNS::DomainNameTest < ActiveSupport::TestCase
|
||||||
|
fixtures 'whois/records'
|
||||||
|
|
||||||
def test_available_when_not_at_auction
|
def test_available_when_not_at_auction
|
||||||
domain_name = DNS::DomainName.new('auction.test')
|
domain_name = DNS::DomainName.new('auction.test')
|
||||||
auctions(:one).update!(domain: 'auction.test', status: Auction.statuses[:domain_registered])
|
auctions(:one).update!(domain: 'auction.test', status: Auction.statuses[:domain_registered])
|
||||||
|
|
|
@ -17,7 +17,7 @@ class DomainVersionTest < ActiveSupport::TestCase
|
||||||
duplicate_domain = prepare_duplicate_domain
|
duplicate_domain = prepare_duplicate_domain
|
||||||
|
|
||||||
PaperTrail.whodunnit = @user.id_role_username
|
PaperTrail.whodunnit = @user.id_role_username
|
||||||
assert_difference 'duplicate_domain.versions.count', 1 do
|
assert_difference 'duplicate_domain.versions.count', 2 do
|
||||||
duplicate_domain.save!
|
duplicate_domain.save!
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@ class DomainVersionTest < ActiveSupport::TestCase
|
||||||
def test_assigns_updator_to_paper_trail_whodunnit
|
def test_assigns_updator_to_paper_trail_whodunnit
|
||||||
PaperTrail.whodunnit = @user.id_role_username
|
PaperTrail.whodunnit = @user.id_role_username
|
||||||
|
|
||||||
assert_difference '@domain.versions.count', 1 do
|
assert_difference '@domain.versions.count', 2 do
|
||||||
@domain.apply_registry_lock
|
@domain.apply_registry_lock
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,96 +0,0 @@
|
||||||
# Built-in since Rails 5.1
|
|
||||||
|
|
||||||
module ActiveSupport
|
|
||||||
module Testing
|
|
||||||
module Assertions
|
|
||||||
UNTRACKED = Object.new # :nodoc:
|
|
||||||
|
|
||||||
# Assertion that the result of evaluating an expression is changed before
|
|
||||||
# and after invoking the passed in block.
|
|
||||||
#
|
|
||||||
# assert_changes 'Status.all_good?' do
|
|
||||||
# post :create, params: { status: { ok: false } }
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# You can pass the block as a string to be evaluated in the context of
|
|
||||||
# the block. A lambda can be passed for the block as well.
|
|
||||||
#
|
|
||||||
# assert_changes -> { Status.all_good? } do
|
|
||||||
# post :create, params: { status: { ok: false } }
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# The assertion is useful to test side effects. The passed block can be
|
|
||||||
# anything that can be converted to string with #to_s.
|
|
||||||
#
|
|
||||||
# assert_changes :@object do
|
|
||||||
# @object = 42
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# The keyword arguments :from and :to can be given to specify the
|
|
||||||
# expected initial value and the expected value after the block was
|
|
||||||
# executed.
|
|
||||||
#
|
|
||||||
# assert_changes :@object, from: nil, to: :foo do
|
|
||||||
# @object = :foo
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# An error message can be specified.
|
|
||||||
#
|
|
||||||
# assert_changes -> { Status.all_good? }, 'Expected the status to be bad' do
|
|
||||||
# post :create, params: { status: { incident: true } }
|
|
||||||
# end
|
|
||||||
def assert_changes(expression, message = nil, from: UNTRACKED, to: UNTRACKED, &block)
|
|
||||||
exp = expression.respond_to?(:call) ? expression : -> { eval(expression.to_s, block.binding) }
|
|
||||||
|
|
||||||
before = exp.call
|
|
||||||
retval = yield
|
|
||||||
|
|
||||||
unless from == UNTRACKED
|
|
||||||
error = "#{expression.inspect} isn't #{from.inspect}"
|
|
||||||
error = "#{message}.\n#{error}" if message
|
|
||||||
assert from === before, error
|
|
||||||
end
|
|
||||||
|
|
||||||
after = exp.call
|
|
||||||
|
|
||||||
if to == UNTRACKED
|
|
||||||
error = "#{expression.inspect} didn't changed"
|
|
||||||
error = "#{message}.\n#{error}" if message
|
|
||||||
assert_not_equal before, after, error
|
|
||||||
else
|
|
||||||
error = "#{expression.inspect} didn't change to #{to}"
|
|
||||||
error = "#{message}.\n#{error}" if message
|
|
||||||
assert to === after, error
|
|
||||||
end
|
|
||||||
|
|
||||||
retval
|
|
||||||
end
|
|
||||||
|
|
||||||
# Assertion that the result of evaluating an expression is changed before
|
|
||||||
# and after invoking the passed in block.
|
|
||||||
#
|
|
||||||
# assert_no_changes 'Status.all_good?' do
|
|
||||||
# post :create, params: { status: { ok: true } }
|
|
||||||
# end
|
|
||||||
#
|
|
||||||
# An error message can be specified.
|
|
||||||
#
|
|
||||||
# assert_no_changes -> { Status.all_good? }, 'Expected the status to be good' do
|
|
||||||
# post :create, params: { status: { ok: false } }
|
|
||||||
# end
|
|
||||||
def assert_no_changes(expression, message = nil, &block)
|
|
||||||
exp = expression.respond_to?(:call) ? expression : -> { eval(expression.to_s, block.binding) }
|
|
||||||
|
|
||||||
before = exp.call
|
|
||||||
retval = yield
|
|
||||||
after = exp.call
|
|
||||||
|
|
||||||
error = "#{expression.inspect} did change to #{after}"
|
|
||||||
error = "#{message}.\n#{error}" if message
|
|
||||||
assert_equal before, after, error
|
|
||||||
|
|
||||||
retval
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -16,7 +16,6 @@ require 'minitest/mock'
|
||||||
require 'capybara/rails'
|
require 'capybara/rails'
|
||||||
require 'capybara/minitest'
|
require 'capybara/minitest'
|
||||||
require 'webmock/minitest'
|
require 'webmock/minitest'
|
||||||
require 'support/rails5_assertions' # Remove once upgraded to Rails 5.1
|
|
||||||
require 'support/assertions/epp_assertions'
|
require 'support/assertions/epp_assertions'
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue