capistrano-forkcms 2.0.4 → 3.2.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/README.md +27 -3
- data/capistrano-forkcms.gemspec +2 -2
- data/lib/capistrano/forkcms/defaults.rb +7 -1
- data/lib/capistrano/forkcms/version.rb +1 -1
- data/lib/capistrano/tasks/configure.rake +0 -21
- data/lib/capistrano/tasks/database.rake +92 -0
- data/lib/capistrano/tasks/maintenance.rake +41 -0
- data/lib/capistrano/tasks/migrations.rake +115 -0
- data/lib/capistrano/tasks/symlink.rake +26 -0
- data/lib/maintenance/.htaccess +10 -0
- data/lib/maintenance/index.html +75 -0
- metadata +14 -10
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 97e73b2616c4852c8ccc79a9300f32da805d4732fa0c05380eff53b20fef3138
|
4
|
+
data.tar.gz: b1e1184e3334eb9e718bae3e9bd6e8cf93492343aaf6340853743621f299cbad
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1c12985c189d7a95c1d959f92832019aea7cc4c11ea1e402a4cad9d4a98925ce096443ddd5a7bf93a0f23c441333343be265f6de6f2fae55553b65cc264dc5f1
|
7
|
+
data.tar.gz: cbb194229a433cd81566e35cfae4254e1496f15cc97cc860e5eadcdbf7f3ec0fa9ab66b8c6fbe666fbf77cdb87be9fd91be62ca47b8a4a19c74087d2cc33e68f
|
data/README.md
CHANGED
@@ -24,7 +24,7 @@ Require the module in your Capfile:
|
|
24
24
|
|
25
25
|
require "capistrano/forkcms"
|
26
26
|
|
27
|
-
The plugin comes with
|
27
|
+
The plugin comes with some tasks:
|
28
28
|
|
29
29
|
* `forkcms:configure:composer`, which will configure the `capistrano/composer` plugin.
|
30
30
|
* `forkcms:opcache:reset`, which will reset the opcache.
|
@@ -43,6 +43,11 @@ Configuration options:
|
|
43
43
|
required when `:opcache_reset_strategy` is `fcgi`.
|
44
44
|
* `opcache_reset_base_url`, the public url of your website. Required when `:opcache_reset_strategy` is `file`
|
45
45
|
|
46
|
+
### `:opcache_reset_strategy`
|
47
|
+
|
48
|
+
If you are using `file` as the strategy, you will need to alter the .htaccess-file to allow 'php-opcache-reset.php' to be accessed directly.
|
49
|
+
|
50
|
+
Add `RewriteRule ^php-opcache-reset\.php$ - [L]` below `RewriteRule ^index\.php$ - [L]` in the .htaccess-file
|
46
51
|
|
47
52
|
## How to use with a fresh Fork install
|
48
53
|
|
@@ -58,7 +63,7 @@ require 'capistrano/scm/git'
|
|
58
63
|
install_plugin Capistrano::SCM::Git
|
59
64
|
require 'capistrano/forkcms'
|
60
65
|
|
61
|
-
set :format_options, log_file: '
|
66
|
+
set :format_options, log_file: 'var/logs/capistrano.log'
|
62
67
|
|
63
68
|
Dir.glob('app/config/capistrano/tasks/*.rake').each { |r| import r }
|
64
69
|
```
|
@@ -113,6 +118,25 @@ set :opcache_reset_fcgi_connection_string, "$your-php-fpm-socket-or-connection-s
|
|
113
118
|
set :branch, "staging"
|
114
119
|
```
|
115
120
|
|
121
|
+
## Migrations
|
122
|
+
|
123
|
+
Built in migrations allow you to easily update your database or locale when deploying a new codebase.
|
124
|
+
|
125
|
+
### General
|
126
|
+
|
127
|
+
Each migration is contained in its own folder in the main `migrations` folder (e.g. `migrations/new-editor-feature`).
|
128
|
+
When deploying, this gem will check if `new-editor-feature` has been executed before. If it hasn't, it will be executed and saved.
|
129
|
+
|
130
|
+
### Locale
|
131
|
+
|
132
|
+
To create a migration for the locale, create a file called `locale.xml` in your migration folder (e.g. `migrations/new-editor-feature/locale.xml`).
|
133
|
+
This file will be imported automatically using the `bin/console forkcms:locale:import` command.
|
134
|
+
|
135
|
+
### Database
|
136
|
+
|
137
|
+
To create a migration for the database, create a file called `update.sql` in your migration folder (e.g. `migrations/new-editor-feature/update.sql`).
|
138
|
+
This file will be imported automatically using `mysql` so make sure you don't accidentally delete your database.
|
139
|
+
|
116
140
|
## Contributing
|
117
141
|
|
118
142
|
Bug reports and pull requests are welcome on GitHub at [https://github.com/tijsverkoyen/capistrano-forkcms](https://github.com/tijsverkoyen/capistrano-forkcms).
|
@@ -120,4 +144,4 @@ Bug reports and pull requests are welcome on GitHub at [https://github.com/tijsv
|
|
120
144
|
|
121
145
|
## License
|
122
146
|
|
123
|
-
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
|
147
|
+
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
|
data/capistrano-forkcms.gemspec
CHANGED
@@ -19,8 +19,8 @@ Gem::Specification.new do |spec|
|
|
19
19
|
end
|
20
20
|
spec.require_paths = ['lib']
|
21
21
|
|
22
|
-
spec.add_development_dependency 'bundler', '~>
|
23
|
-
spec.add_development_dependency
|
22
|
+
spec.add_development_dependency 'bundler', '~> 2.2'
|
23
|
+
spec.add_development_dependency "rake", ">= 12.3.3"
|
24
24
|
spec.add_development_dependency 'rspec', '~> 3.0'
|
25
25
|
|
26
26
|
spec.add_dependency 'capistrano', '~> 3.8'
|
@@ -2,7 +2,7 @@
|
|
2
2
|
set :linked_files, []
|
3
3
|
set :linked_files, %w(app/config/parameters.yml)
|
4
4
|
set :linked_dirs, []
|
5
|
-
set :linked_dirs, %w(app/logs app/sessions
|
5
|
+
set :linked_dirs, %w(app/logs app/sessions)
|
6
6
|
|
7
7
|
# Run required tasks after the stage
|
8
8
|
Capistrano::DSL.stages.each do |stage|
|
@@ -16,11 +16,17 @@ namespace :deploy do
|
|
16
16
|
after :starting, 'composer:install_executable'
|
17
17
|
after :starting, 'cachetool:install_executable'
|
18
18
|
after :publishing, 'forkcms:symlink:document_root'
|
19
|
+
after :publishing, 'forkcms:symlink:frontend_files'
|
19
20
|
after :publishing, 'forkcms:opcache:reset'
|
21
|
+
after :updated, 'forkcms:migrations:execute'
|
22
|
+
before :reverted, 'forkcms:migrations:rollback'
|
20
23
|
end
|
21
24
|
|
22
25
|
|
23
26
|
# Load the tasks
|
24
27
|
load File.expand_path('../../tasks/configure.rake', __FILE__)
|
28
|
+
load File.expand_path('../../tasks/database.rake', __FILE__)
|
29
|
+
load File.expand_path('../../tasks/maintenance.rake', __FILE__)
|
30
|
+
load File.expand_path('../../tasks/migrations.rake', __FILE__)
|
25
31
|
load File.expand_path('../../tasks/opcache.rake', __FILE__)
|
26
32
|
load File.expand_path('../../tasks/symlink.rake', __FILE__)
|
@@ -21,25 +21,4 @@ namespace :forkcms do
|
|
21
21
|
SSHKit.config.command_map[:cachetool] = "#{fetch :php_bin_path} #{fetch :deploy_to}/shared/cachetool.phar"
|
22
22
|
end
|
23
23
|
end
|
24
|
-
|
25
|
-
namespace :symlink do
|
26
|
-
desc <<-DESC
|
27
|
-
Links the document root to the current folder
|
28
|
-
The document root is the folder that the webserver will serve, it should link to the current path.
|
29
|
-
DESC
|
30
|
-
task :document_root do
|
31
|
-
on roles(:web) do
|
32
|
-
if test("[ -L #{fetch :document_root} ]") && capture("readlink -- #{fetch :document_root}") == "#{current_path}/"
|
33
|
-
# all is well, the symlink is correct
|
34
|
-
elsif test("[ -d #{fetch :document_root} ]") || test("[ -f #{fetch :document_root} ]")
|
35
|
-
error "Document root #{fetch :document_root} already exists."
|
36
|
-
error 'To link it, issue the following command:'
|
37
|
-
error "ln -sf #{current_path}/ #{fetch :document_root}"
|
38
|
-
else
|
39
|
-
execute :mkdir, '-p', File.dirname(fetch(:document_root))
|
40
|
-
execute :ln, '-sf', "#{current_path}/", fetch(:document_root)
|
41
|
-
end
|
42
|
-
end
|
43
|
-
end
|
44
|
-
end
|
45
24
|
end
|
@@ -0,0 +1,92 @@
|
|
1
|
+
namespace :forkcms do
|
2
|
+
namespace :database do
|
3
|
+
backup_file = 'mysql_backup.sql'
|
4
|
+
|
5
|
+
desc 'Create a backup of the database'
|
6
|
+
task :backup do
|
7
|
+
on roles(:web) do
|
8
|
+
flags = get_mysql_connection_flags
|
9
|
+
execute :mysqldump, "#{flags} --skip-lock-tables > #{release_path}/#{backup_file}"
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
desc 'Restore the database from a backup file'
|
14
|
+
task :restore do
|
15
|
+
on roles(:web) do
|
16
|
+
if not test "[[ -f #{release_path}/#{backup_file} ]]"
|
17
|
+
error "No backup file found, create a backup first"
|
18
|
+
else
|
19
|
+
Rake::Task["forkcms:database:execute"].invoke("#{release_path}/#{backup_file}")
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
desc 'Execute an SQL file'
|
25
|
+
task :execute, [:file] do |t, arguments|
|
26
|
+
on roles(:web) do
|
27
|
+
if not test "[[ -f #{arguments[:file]} ]]"
|
28
|
+
raise "File at #{arguments[:file]} does not exist"
|
29
|
+
end
|
30
|
+
|
31
|
+
# Execute the file
|
32
|
+
flags = get_mysql_connection_flags
|
33
|
+
execute :mysql,"#{flags} < #{arguments[:file]}"
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
private
|
38
|
+
def get_parameters
|
39
|
+
parameter_path = "#{shared_path}/app/config/parameters.yml"
|
40
|
+
if not test "[[ -f #{parameter_path} ]]"
|
41
|
+
raise "parameters.yml not found, it should be at #{parameter_path}"
|
42
|
+
end
|
43
|
+
|
44
|
+
# Fetch the content of the parameters
|
45
|
+
parameters_content = capture "cat #{parameter_path}"
|
46
|
+
# It seems we use invalid yml in our config files
|
47
|
+
# Therefore we need to fix some issues with it.
|
48
|
+
parameters_content = parameters_content.gsub(/:(\s*)%(.*)/, ':\1"%\2"')
|
49
|
+
|
50
|
+
parameters_content = YAML::load(parameters_content)
|
51
|
+
|
52
|
+
# Return them
|
53
|
+
return parameters_content.fetch('parameters')
|
54
|
+
end
|
55
|
+
|
56
|
+
def get_mysql_connection_flags
|
57
|
+
# Fetch our parameters to reach the database
|
58
|
+
parameters = get_parameters
|
59
|
+
|
60
|
+
# Abort if no parameters are found
|
61
|
+
if parameters == nil
|
62
|
+
return
|
63
|
+
end
|
64
|
+
|
65
|
+
# Define our mapping
|
66
|
+
mapping = {
|
67
|
+
'host' => parameters.fetch('database.host'),
|
68
|
+
'port' => parameters.fetch('database.port'),
|
69
|
+
'user' => parameters.fetch('database.user'),
|
70
|
+
'password' => parameters.fetch('database.password'),
|
71
|
+
}
|
72
|
+
|
73
|
+
# Set the default flags
|
74
|
+
flags = "--default-character-set='utf8' "
|
75
|
+
|
76
|
+
# Append each mapped property to our flags
|
77
|
+
mapping.each do |key, value|
|
78
|
+
raise "\"#{key}\" is not set in the parameters.yml file" if value.nil?
|
79
|
+
|
80
|
+
flags << "--#{key}=#{value} "
|
81
|
+
end
|
82
|
+
|
83
|
+
# Append our database
|
84
|
+
database = parameters.fetch('database.name')
|
85
|
+
raise "\"database.name\" is not set in the parameters.yml file" if database.nil?
|
86
|
+
|
87
|
+
flags << "#{database}"
|
88
|
+
|
89
|
+
return flags
|
90
|
+
end
|
91
|
+
end
|
92
|
+
end
|
@@ -0,0 +1,41 @@
|
|
1
|
+
namespace :forkcms do
|
2
|
+
namespace :maintenance do
|
3
|
+
desc 'Enable maintenance mode'
|
4
|
+
task :enable do
|
5
|
+
on roles(:web) do
|
6
|
+
create_maintenance_folder
|
7
|
+
execute :rm, '-rf', "#{fetch :document_root} && ln -sf #{shared_path}/maintenance #{fetch :document_root}"
|
8
|
+
|
9
|
+
Rake::Task["forkcms:opcache:reset"].invoke()
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
desc 'Disable maintenance mode'
|
14
|
+
task :disable do
|
15
|
+
on roles(:web) do
|
16
|
+
execute :rm, '-rf', "#{fetch :document_root} && ln -sf #{current_path} #{fetch :document_root}"
|
17
|
+
|
18
|
+
Rake::Task["forkcms:opcache:reset"].invoke()
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
private
|
23
|
+
# Creates the maintenance folder based on the local maintenance folder to display when migrating
|
24
|
+
def create_maintenance_folder
|
25
|
+
# Stop if the maintenance folder exists
|
26
|
+
return if capture("if [ -d #{shared_path}/maintenance ]; then echo 'yes'; fi").chomp == 'yes'
|
27
|
+
|
28
|
+
lib_path = File.dirname(__FILE__)
|
29
|
+
local_maintenance_path = "#{lib_path}/../../maintenance"
|
30
|
+
|
31
|
+
# Create a maintenance folder containing the index page from our gem
|
32
|
+
execute :mkdir, "-p #{shared_path}/maintenance"
|
33
|
+
|
34
|
+
# copy the contents of the index.html file to our shared folder
|
35
|
+
upload! File.open(local_maintenance_path + '/index.html'), "#{shared_path}/maintenance/index.html"
|
36
|
+
|
37
|
+
# copy the contents of the .htaccess file to our shared folder
|
38
|
+
upload! File.open(local_maintenance_path + '/.htaccess'), "#{shared_path}/maintenance/.htaccess"
|
39
|
+
end
|
40
|
+
end
|
41
|
+
end
|
@@ -0,0 +1,115 @@
|
|
1
|
+
namespace :forkcms do
|
2
|
+
namespace :migrations do
|
3
|
+
desc 'Prepare the server for running Fork CMS migrations'
|
4
|
+
task :prepare do
|
5
|
+
on roles(:web) do
|
6
|
+
create_migrations_file
|
7
|
+
end
|
8
|
+
end
|
9
|
+
|
10
|
+
desc 'Execute pending migrations'
|
11
|
+
task :execute do
|
12
|
+
on roles(:web) do
|
13
|
+
# Prepare for migrations if it's not done already
|
14
|
+
Rake::Task["forkcms:migrations:prepare"].invoke()
|
15
|
+
|
16
|
+
# Abort if no migrations are found
|
17
|
+
migration_folders = get_migration_folders
|
18
|
+
next if migration_folders.length == 0
|
19
|
+
|
20
|
+
migrations_to_execute = get_migrations_to_execute
|
21
|
+
|
22
|
+
# Abort if no new migrations are found
|
23
|
+
next if migrations_to_execute.length == 0
|
24
|
+
|
25
|
+
# As migrations can take a while we show a maintenance page
|
26
|
+
Rake::Task["forkcms:maintenance:enable"].invoke()
|
27
|
+
|
28
|
+
# Back up the database, just in case
|
29
|
+
Rake::Task["forkcms:database:backup"].invoke()
|
30
|
+
|
31
|
+
# Execute all migrations
|
32
|
+
migrations_to_execute.each do |dirname|
|
33
|
+
migration_path = "#{release_path}/migrations/#{dirname}"
|
34
|
+
migration_files = capture("ls -1 #{migration_path}").split(/\r?\n/)
|
35
|
+
|
36
|
+
migration_files.each do |filename|
|
37
|
+
# Execute a MySQL file
|
38
|
+
if filename.index('update.sql') != nil
|
39
|
+
Rake::Task["forkcms:database:execute"].invoke("#{migration_path}/#{filename}")
|
40
|
+
|
41
|
+
next
|
42
|
+
end
|
43
|
+
|
44
|
+
# Update the locale through the console command
|
45
|
+
if filename.index('locale.xml') != nil
|
46
|
+
execute :php, "#{release_path}/bin/console forkcms:locale:import -f #{migration_path}/#{filename} --env=prod"
|
47
|
+
|
48
|
+
next
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
# All migrations were executed successfully and we didn't roll back so put them in the executed_migrations file
|
54
|
+
migrations_to_execute.each do |dirname|
|
55
|
+
execute :echo , "#{dirname} | tee -a #{shared_path}/executed_migrations"
|
56
|
+
end
|
57
|
+
|
58
|
+
# Disable maintenance mode, everything is done
|
59
|
+
Rake::Task["forkcms:maintenance:disable"].invoke()
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
desc 'Rollback the migrations'
|
64
|
+
task :rollback do
|
65
|
+
# Restore the database backup so we undo any executed migrations
|
66
|
+
Rake::Task["forkcms:database:restore"].invoke()
|
67
|
+
|
68
|
+
# Disable the maintenance page so the site is accessible again
|
69
|
+
Rake::Task["forkcms:maintenance:disable"].invoke()
|
70
|
+
end
|
71
|
+
|
72
|
+
private
|
73
|
+
|
74
|
+
# Creates a migration file to hold our executed migrations
|
75
|
+
def create_migrations_file
|
76
|
+
# Stop if the migrations file exists
|
77
|
+
return if test "[[ -f #{shared_path}/executed_migrations ]]"
|
78
|
+
|
79
|
+
# Create an empty executed_migrations file
|
80
|
+
upload! StringIO.new(''), "#{shared_path}/executed_migrations"
|
81
|
+
|
82
|
+
# If we just created the executed_migrations file, add all existing migrations
|
83
|
+
execute_initial_migration
|
84
|
+
end
|
85
|
+
|
86
|
+
# Put all items in the migrations folder in the executed_migrations file
|
87
|
+
def execute_initial_migration
|
88
|
+
migration_folders = get_migration_folders
|
89
|
+
|
90
|
+
migration_folders.each do |dirname|
|
91
|
+
run "echo #{dirname} | tee -a #{shared_path}/executed_migrations"
|
92
|
+
end
|
93
|
+
end
|
94
|
+
|
95
|
+
# Gets the new migrations to execute
|
96
|
+
def get_migrations_to_execute
|
97
|
+
executed_migrations = capture("cat #{shared_path}/executed_migrations").chomp.split(/\r?\n/)
|
98
|
+
migrations_to_execute = Array.new
|
99
|
+
migration_folders = get_migration_folders
|
100
|
+
|
101
|
+
# Fetch all migration directories that aren't executed yet
|
102
|
+
migration_folders.each do |dirname|
|
103
|
+
if executed_migrations.index(dirname) == nil
|
104
|
+
migrations_to_execute.push(dirname)
|
105
|
+
end
|
106
|
+
end
|
107
|
+
|
108
|
+
return migrations_to_execute
|
109
|
+
end
|
110
|
+
|
111
|
+
def get_migration_folders
|
112
|
+
return capture("if [ -e #{release_path}/migrations ]; then ls -1 #{release_path}/migrations; fi").split(/\r?\n/)
|
113
|
+
end
|
114
|
+
end
|
115
|
+
end
|
@@ -18,5 +18,31 @@ namespace :forkcms do
|
|
18
18
|
end
|
19
19
|
end
|
20
20
|
end
|
21
|
+
desc <<-DESC
|
22
|
+
Links the frontend files folders to their shared counterparts.
|
23
|
+
It copies the contents of the git folders to the shared folder so you can add files through git.
|
24
|
+
DESC
|
25
|
+
task :frontend_files do
|
26
|
+
on roles(:web) do
|
27
|
+
# get the list of folders in the frontend files
|
28
|
+
folders = get_frontend_files_folders()
|
29
|
+
|
30
|
+
# loop the folders
|
31
|
+
folders.each do |folder|
|
32
|
+
# create the shared folder if it doesn't exist
|
33
|
+
execute :mkdir, '-p', "#{shared_path}/files/#{folder}"
|
34
|
+
# copy the contents of the release folder to the shared folder, allowing for adding new files through git
|
35
|
+
execute :cp, '-r', "#{release_path}/src/Frontend/Files/#{folder}", "#{shared_path}/files/"
|
36
|
+
# remove them from the release folder
|
37
|
+
execute :rm, '-rf', "#{release_path}/src/Frontend/Files/#{folder}"
|
38
|
+
# create a symlink to the shared folder
|
39
|
+
execute :ln, '-s', "#{shared_path}/files/#{folder}", "#{release_path}/src/Frontend/Files/#{folder}"
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
def get_frontend_files_folders
|
45
|
+
return capture("if [ -e #{release_path}/src/Frontend/Files ]; then ls -1 #{release_path}/src/Frontend/Files; fi").split(/\r?\n/)
|
46
|
+
end
|
21
47
|
end
|
22
48
|
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
# All url's will see the maintenance page (index.html)
|
2
|
+
# This way they are back to there original page after maintenance is finished.
|
3
|
+
<IfModule mod_rewrite.c>
|
4
|
+
# nice urls
|
5
|
+
RewriteEngine On
|
6
|
+
RewriteBase /
|
7
|
+
|
8
|
+
# handle urls
|
9
|
+
RewriteRule . index.html [NC,L]
|
10
|
+
</IfModule>
|
@@ -0,0 +1,75 @@
|
|
1
|
+
<!DOCTYPE HTML>
|
2
|
+
<html lang="en">
|
3
|
+
<head>
|
4
|
+
<meta charset="utf-8">
|
5
|
+
<title>Maintenance break!</title>
|
6
|
+
<style type="text/css">
|
7
|
+
body
|
8
|
+
{
|
9
|
+
background-color: #ebf3f9;
|
10
|
+
margin: 0;
|
11
|
+
padding: 0;
|
12
|
+
border: 0;
|
13
|
+
font-family: Arial;
|
14
|
+
}
|
15
|
+
h1
|
16
|
+
{
|
17
|
+
color: #333333;
|
18
|
+
font-size: 20px;
|
19
|
+
line-height: 0;
|
20
|
+
margin-bottom: 30px;
|
21
|
+
}
|
22
|
+
p
|
23
|
+
{
|
24
|
+
color: #666666;
|
25
|
+
font-size: 13px;
|
26
|
+
}
|
27
|
+
#container
|
28
|
+
{
|
29
|
+
position: absolute;
|
30
|
+
left: 50%;
|
31
|
+
top: 50%;
|
32
|
+
width: 340px;
|
33
|
+
height: 471px;
|
34
|
+
margin-left: -200px;
|
35
|
+
margin-top: -250px;
|
36
|
+
}
|
37
|
+
#balloon
|
38
|
+
{
|
39
|
+
background-color: #FFF;
|
40
|
+
width: 340px;
|
41
|
+
padding: 30px;
|
42
|
+
border: 1px solid #c3c3c3;
|
43
|
+
-webkit-border-radius: 3px;
|
44
|
+
-moz-border-radius: 3px;
|
45
|
+
border-radius: 3px;
|
46
|
+
}
|
47
|
+
#triangle
|
48
|
+
{
|
49
|
+
background-image: url();
|
50
|
+
margin-left: 180px;
|
51
|
+
margin-top: -1px;
|
52
|
+
width: 40px;
|
53
|
+
height: 21px;
|
54
|
+
}
|
55
|
+
#bottom
|
56
|
+
{
|
57
|
+
background-image: url();
|
58
|
+
width: 400px;
|
59
|
+
height: 271px;
|
60
|
+
margin-top: 10px;
|
61
|
+
}
|
62
|
+
|
63
|
+
</style>
|
64
|
+
</head>
|
65
|
+
<body>
|
66
|
+
<div id="container">
|
67
|
+
<div id="balloon">
|
68
|
+
<h1>Maintenance break!</h1>
|
69
|
+
<p>Our web wizards are doing some maintenance magic on the site. Go grab a cup of coffee, we'll be back up and running asap.</p>
|
70
|
+
</div>
|
71
|
+
<div id="triangle"> </div>
|
72
|
+
<div id="bottom"> </div>
|
73
|
+
</div>
|
74
|
+
</body>
|
75
|
+
</html>
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: capistrano-forkcms
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 3.2.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Tijs Verkoyen
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-05-12 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -16,28 +16,28 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: '
|
19
|
+
version: '2.2'
|
20
20
|
type: :development
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - "~>"
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: '
|
26
|
+
version: '2.2'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- - "
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version:
|
33
|
+
version: 12.3.3
|
34
34
|
type: :development
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- - "
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version:
|
40
|
+
version: 12.3.3
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rspec
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -115,8 +115,13 @@ files:
|
|
115
115
|
- lib/capistrano/forkcms/defaults.rb
|
116
116
|
- lib/capistrano/forkcms/version.rb
|
117
117
|
- lib/capistrano/tasks/configure.rake
|
118
|
+
- lib/capistrano/tasks/database.rake
|
119
|
+
- lib/capistrano/tasks/maintenance.rake
|
120
|
+
- lib/capistrano/tasks/migrations.rake
|
118
121
|
- lib/capistrano/tasks/opcache.rake
|
119
122
|
- lib/capistrano/tasks/symlink.rake
|
123
|
+
- lib/maintenance/.htaccess
|
124
|
+
- lib/maintenance/index.html
|
120
125
|
homepage: https://github.com/tijsverkoyen/capistrano-forkcms
|
121
126
|
licenses:
|
122
127
|
- MIT
|
@@ -136,8 +141,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
136
141
|
- !ruby/object:Gem::Version
|
137
142
|
version: '0'
|
138
143
|
requirements: []
|
139
|
-
|
140
|
-
rubygems_version: 2.6.11
|
144
|
+
rubygems_version: 3.0.3
|
141
145
|
signing_key:
|
142
146
|
specification_version: 4
|
143
147
|
summary: Fork CMS specific Capistrano tasks
|