Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
ce99925f
Commit
ce99925f
authored
Apr 09, 2019
by
GitLab Bot
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge of gitlab-org/gitlab-ce master
parents
23366edf
41e36b05
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
154 additions
and
33 deletions
+154
-33
app/services/verify_pages_domain_service.rb
app/services/verify_pages_domain_service.rb
+9
-6
app/views/notify/_removal_notification.html.haml
app/views/notify/_removal_notification.html.haml
+9
-0
app/views/notify/pages_domain_disabled_email.html.haml
app/views/notify/pages_domain_disabled_email.html.haml
+1
-3
app/views/notify/pages_domain_verification_failed_email.html.haml
...s/notify/pages_domain_verification_failed_email.html.haml
+1
-3
changelogs/unreleased/remove-disabled-pages-domains.yml
changelogs/unreleased/remove-disabled-pages-domains.yml
+5
-0
db/migrate/20190312113229_add_remove_at_to_pages_domains.rb
db/migrate/20190312113229_add_remove_at_to_pages_domains.rb
+10
-0
db/migrate/20190312113634_add_remove_at_index_to_pages_domains.rb
...te/20190312113634_add_remove_at_index_to_pages_domains.rb
+19
-0
db/schema.rb
db/schema.rb
+2
-0
doc/user/project/pages/getting_started_part_three.md
doc/user/project/pages/getting_started_part_three.md
+2
-0
spec/factories/pages_domains.rb
spec/factories/pages_domains.rb
+4
-0
spec/mailers/emails/pages_domains_spec.rb
spec/mailers/emails/pages_domains_spec.rb
+24
-0
spec/services/verify_pages_domain_service_spec.rb
spec/services/verify_pages_domain_service_spec.rb
+68
-21
No files found.
app/services/verify_pages_domain_service.rb
View file @
ce99925f
...
@@ -8,6 +8,7 @@ class VerifyPagesDomainService < BaseService
...
@@ -8,6 +8,7 @@ class VerifyPagesDomainService < BaseService
# How long verification lasts for
# How long verification lasts for
VERIFICATION_PERIOD
=
7
.
days
VERIFICATION_PERIOD
=
7
.
days
REMOVAL_DELAY
=
1
.
week
.
freeze
attr_reader
:domain
attr_reader
:domain
...
@@ -36,7 +37,7 @@ class VerifyPagesDomainService < BaseService
...
@@ -36,7 +37,7 @@ class VerifyPagesDomainService < BaseService
# Prevent any pre-existing grace period from being truncated
# Prevent any pre-existing grace period from being truncated
reverify
=
[
domain
.
enabled_until
,
VERIFICATION_PERIOD
.
from_now
].
compact
.
max
reverify
=
[
domain
.
enabled_until
,
VERIFICATION_PERIOD
.
from_now
].
compact
.
max
domain
.
assign_attributes
(
verified_at:
Time
.
now
,
enabled_until:
reverify
)
domain
.
assign_attributes
(
verified_at:
Time
.
now
,
enabled_until:
reverify
,
remove_at:
nil
)
domain
.
save!
(
validate:
false
)
domain
.
save!
(
validate:
false
)
if
was_disabled
if
was_disabled
...
@@ -49,18 +50,20 @@ class VerifyPagesDomainService < BaseService
...
@@ -49,18 +50,20 @@ class VerifyPagesDomainService < BaseService
end
end
def
unverify_domain!
def
unverify_domain!
if
domain
.
verified?
was_verified
=
domain
.
verified?
domain
.
assign_attributes
(
verified_at:
nil
)
domain
.
save!
(
validate:
false
)
notify
(
:verification_failed
)
domain
.
assign_attributes
(
verified_at:
nil
)
end
domain
.
remove_at
||=
REMOVAL_DELAY
.
from_now
unless
domain
.
enabled?
domain
.
save!
(
validate:
false
)
notify
(
:verification_failed
)
if
was_verified
error
(
"Couldn't verify
#{
domain
.
domain
}
"
)
error
(
"Couldn't verify
#{
domain
.
domain
}
"
)
end
end
def
disable_domain!
def
disable_domain!
domain
.
assign_attributes
(
verified_at:
nil
,
enabled_until:
nil
)
domain
.
assign_attributes
(
verified_at:
nil
,
enabled_until:
nil
)
domain
.
remove_at
||=
REMOVAL_DELAY
.
from_now
domain
.
save!
(
validate:
false
)
domain
.
save!
(
validate:
false
)
notify
(
:disabled
)
notify
(
:disabled
)
...
...
app/views/notify/_removal_notification.html.haml
0 → 100644
View file @
ce99925f
-
if
@domain
.
remove_at
%p
Unless you verify your domain by
%strong
=
@domain
.
remove_at
.
strftime
(
'%F %T,'
)
it will be removed from your GitLab project.
-
else
%p
If you no longer wish to use this domain with GitLab Pages, please remove it
from your GitLab project and delete any related DNS records.
app/views/notify/pages_domain_disabled_email.html.haml
View file @
ce99925f
...
@@ -10,6 +10,4 @@
...
@@ -10,6 +10,4 @@
If this domain has been disabled in error, please follow
If this domain has been disabled in error, please follow
=
link_to
'these instructions'
,
help_page_url
(
'user/project/pages/getting_started_part_three.md'
,
anchor:
'dns-txt-record'
)
=
link_to
'these instructions'
,
help_page_url
(
'user/project/pages/getting_started_part_three.md'
,
anchor:
'dns-txt-record'
)
to verify and re-enable your domain.
to verify and re-enable your domain.
%p
=
render
'removal_notification'
If you no longer wish to use this domain with GitLab Pages, please remove it
from your GitLab project and delete any related DNS records.
app/views/notify/pages_domain_verification_failed_email.html.haml
View file @
ce99925f
...
@@ -12,6 +12,4 @@
...
@@ -12,6 +12,4 @@
Please visit
Please visit
=
link_to
'these instructions'
,
help_page_url
(
'user/project/pages/getting_started_part_three.md'
,
anchor:
'dns-txt-record'
)
=
link_to
'these instructions'
,
help_page_url
(
'user/project/pages/getting_started_part_three.md'
,
anchor:
'dns-txt-record'
)
for more information about custom domain verification.
for more information about custom domain verification.
%p
=
render
'removal_notification'
If you no longer wish to use this domain with GitLab Pages, please remove it
from your GitLab project and delete any related DNS records.
changelogs/unreleased/remove-disabled-pages-domains.yml
0 → 100644
View file @
ce99925f
---
title
:
Mark disabled pages domains for removal, but don't remove them yet
merge_request
:
26212
author
:
type
:
added
db/migrate/20190312113229_add_remove_at_to_pages_domains.rb
0 → 100644
View file @
ce99925f
# frozen_string_literal: true
class
AddRemoveAtToPagesDomains
<
ActiveRecord
::
Migration
[
5.0
]
include
Gitlab
::
Database
::
MigrationHelpers
DOWNTIME
=
false
def
change
add_column
:pages_domains
,
:remove_at
,
:datetime_with_timezone
end
end
db/migrate/20190312113634_add_remove_at_index_to_pages_domains.rb
0 → 100644
View file @
ce99925f
# frozen_string_literal: true
# See http://doc.gitlab.com/ce/development/migration_style_guide.html
# for more information on how to write migrations for GitLab.
class
AddRemoveAtIndexToPagesDomains
<
ActiveRecord
::
Migration
[
5.0
]
include
Gitlab
::
Database
::
MigrationHelpers
DOWNTIME
=
false
disable_ddl_transaction!
def
up
add_concurrent_index
:pages_domains
,
:remove_at
end
def
down
remove_concurrent_index
:pages_domains
,
:remove_at
end
end
db/schema.rb
View file @
ce99925f
...
@@ -2193,9 +2193,11 @@ ActiveRecord::Schema.define(version: 20190404231137) do
...
@@ -2193,9 +2193,11 @@ ActiveRecord::Schema.define(version: 20190404231137) do
t
.
datetime_with_timezone
"verified_at"
t
.
datetime_with_timezone
"verified_at"
t
.
string
"verification_code"
,
null:
false
t
.
string
"verification_code"
,
null:
false
t
.
datetime_with_timezone
"enabled_until"
t
.
datetime_with_timezone
"enabled_until"
t
.
datetime_with_timezone
"remove_at"
t
.
index
[
"domain"
],
name:
"index_pages_domains_on_domain"
,
unique:
true
,
using: :btree
t
.
index
[
"domain"
],
name:
"index_pages_domains_on_domain"
,
unique:
true
,
using: :btree
t
.
index
[
"project_id"
,
"enabled_until"
],
name:
"index_pages_domains_on_project_id_and_enabled_until"
,
using: :btree
t
.
index
[
"project_id"
,
"enabled_until"
],
name:
"index_pages_domains_on_project_id_and_enabled_until"
,
using: :btree
t
.
index
[
"project_id"
],
name:
"index_pages_domains_on_project_id"
,
using: :btree
t
.
index
[
"project_id"
],
name:
"index_pages_domains_on_project_id"
,
using: :btree
t
.
index
[
"remove_at"
],
name:
"index_pages_domains_on_remove_at"
,
using: :btree
t
.
index
[
"verified_at"
,
"enabled_until"
],
name:
"index_pages_domains_on_verified_at_and_enabled_until"
,
using: :btree
t
.
index
[
"verified_at"
,
"enabled_until"
],
name:
"index_pages_domains_on_verified_at_and_enabled_until"
,
using: :btree
t
.
index
[
"verified_at"
],
name:
"index_pages_domains_on_verified_at"
,
using: :btree
t
.
index
[
"verified_at"
],
name:
"index_pages_domains_on_verified_at"
,
using: :btree
end
end
...
...
doc/user/project/pages/getting_started_part_three.md
View file @
ce99925f
...
@@ -115,6 +115,8 @@ If using a [DNS A record](#dns-a-record), you can place the TXT record directly
...
@@ -115,6 +115,8 @@ If using a [DNS A record](#dns-a-record), you can place the TXT record directly
under the domain. If using a
[
DNS CNAME record
](
#dns-cname-record
)
, the two record types won't
under the domain. If using a
[
DNS CNAME record
](
#dns-cname-record
)
, the two record types won't
co-exist, so you need to place the TXT record in a special subdomain of its own.
co-exist, so you need to place the TXT record in a special subdomain of its own.
If the domain cannot be verified for 7 days, it will be removed from the GitLab project.
#### TL;DR
#### TL;DR
For root domains (
`domain.com`
), set a DNS
`A`
record and verify your
For root domains (
`domain.com`
), set a DNS
`A`
record and verify your
...
...
spec/factories/pages_domains.rb
View file @
ce99925f
...
@@ -41,6 +41,10 @@ nNp/xedE1YxutQ==
...
@@ -41,6 +41,10 @@ nNp/xedE1YxutQ==
enabled_until
nil
enabled_until
nil
end
end
trait
:scheduled_for_removal
do
remove_at
{
1
.
day
.
from_now
}
end
trait
:unverified
do
trait
:unverified
do
verified_at
nil
verified_at
nil
end
end
...
...
spec/mailers/emails/pages_domains_spec.rb
View file @
ce99925f
...
@@ -26,6 +26,26 @@ describe Emails::PagesDomains do
...
@@ -26,6 +26,26 @@ describe Emails::PagesDomains do
end
end
end
end
shared_examples
'notification about upcoming domain removal'
do
context
'when domain is not scheduled for removal'
do
it
'asks user to remove it'
do
is_expected
.
to
have_body_text
'please remove it'
end
end
context
'when domain is scheduled for removal'
do
before
do
domain
.
update!
(
remove_at:
1
.
week
.
from_now
)
end
it
'notifies user that domain will be removed automatically'
do
aggregate_failures
do
is_expected
.
to
have_body_text
domain
.
remove_at
.
strftime
(
'%F %T'
)
is_expected
.
to
have_body_text
"it will be removed from your GitLab project"
end
end
end
end
describe
'#pages_domain_enabled_email'
do
describe
'#pages_domain_enabled_email'
do
let
(
:email_subject
)
{
"
#{
project
.
path
}
| GitLab Pages domain '
#{
domain
.
domain
}
' has been enabled"
}
let
(
:email_subject
)
{
"
#{
project
.
path
}
| GitLab Pages domain '
#{
domain
.
domain
}
' has been enabled"
}
...
@@ -43,6 +63,8 @@ describe Emails::PagesDomains do
...
@@ -43,6 +63,8 @@ describe Emails::PagesDomains do
it_behaves_like
'a pages domain email'
it_behaves_like
'a pages domain email'
it_behaves_like
'notification about upcoming domain removal'
it
{
is_expected
.
to
have_body_text
'has been disabled'
}
it
{
is_expected
.
to
have_body_text
'has been disabled'
}
end
end
...
@@ -63,6 +85,8 @@ describe Emails::PagesDomains do
...
@@ -63,6 +85,8 @@ describe Emails::PagesDomains do
it_behaves_like
'a pages domain email'
it_behaves_like
'a pages domain email'
it_behaves_like
'notification about upcoming domain removal'
it
'says verification has failed and when the domain is enabled until'
do
it
'says verification has failed and when the domain is enabled until'
do
is_expected
.
to
have_body_text
'Verification has failed'
is_expected
.
to
have_body_text
'Verification has failed'
is_expected
.
to
have_body_text
domain
.
enabled_until
.
strftime
(
'%F %T'
)
is_expected
.
to
have_body_text
domain
.
enabled_until
.
strftime
(
'%F %T'
)
...
...
spec/services/verify_pages_domain_service_spec.rb
View file @
ce99925f
...
@@ -27,6 +27,7 @@ describe VerifyPagesDomainService do
...
@@ -27,6 +27,7 @@ describe VerifyPagesDomainService do
expect
(
domain
).
to
be_verified
expect
(
domain
).
to
be_verified
expect
(
domain
).
to
be_enabled
expect
(
domain
).
to
be_enabled
expect
(
domain
.
remove_at
).
to
be_nil
end
end
end
end
...
@@ -48,18 +49,32 @@ describe VerifyPagesDomainService do
...
@@ -48,18 +49,32 @@ describe VerifyPagesDomainService do
end
end
end
end
shared_examples
'unverifies and disables domain'
do
it
'unverifies domain'
do
expect
(
service
.
execute
).
to
eq
(
error_status
)
expect
(
domain
).
not_to
be_verified
end
it
'disables domain and shedules it for removal'
do
Timecop
.
freeze
do
service
.
execute
expect
(
domain
).
not_to
be_enabled
expect
(
domain
.
remove_at
).
to
be_within
(
1
.
second
).
of
(
1
.
week
.
from_now
)
end
end
end
context
'when domain is disabled(or new)'
do
context
'when domain is disabled(or new)'
do
let
(
:domain
)
{
create
(
:pages_domain
,
:disabled
)
}
let
(
:domain
)
{
create
(
:pages_domain
,
:disabled
)
}
include_examples
'successful enablement and verification'
include_examples
'successful enablement and verification'
shared_examples
'unverifies and disables domain'
do
context
'when txt record does not contain verification code'
do
it
'unverifies and disables domain'
do
before
do
expect
(
service
.
execute
).
to
eq
(
error_status
)
stub_resolver
(
domain_name
=>
'something else'
)
expect
(
domain
).
not_to
be_verified
expect
(
domain
).
not_to
be_enabled
end
end
include_examples
'unverifies and disables domain'
end
end
context
'when txt record does not contain verification code'
do
context
'when txt record does not contain verification code'
do
...
@@ -84,16 +99,25 @@ describe VerifyPagesDomainService do
...
@@ -84,16 +99,25 @@ describe VerifyPagesDomainService do
include_examples
'successful enablement and verification'
include_examples
'successful enablement and verification'
context
'when txt record does not contain verification code'
do
shared_examples
'unverifing domain'
do
before
do
stub_resolver
(
domain_name
=>
'something else'
)
end
it
'unverifies but does not disable domain'
do
it
'unverifies but does not disable domain'
do
expect
(
service
.
execute
).
to
eq
(
error_status
)
expect
(
service
.
execute
).
to
eq
(
error_status
)
expect
(
domain
).
not_to
be_verified
expect
(
domain
).
not_to
be_verified
expect
(
domain
).
to
be_enabled
expect
(
domain
).
to
be_enabled
end
end
it
'does not schedule domain for removal'
do
service
.
execute
expect
(
domain
.
remove_at
).
to
be_nil
end
end
context
'when txt record does not contain verification code'
do
before
do
stub_resolver
(
domain_name
=>
'something else'
)
end
include_examples
'unverifing domain'
end
end
context
'when no txt records are present'
do
context
'when no txt records are present'
do
...
@@ -101,11 +125,7 @@ describe VerifyPagesDomainService do
...
@@ -101,11 +125,7 @@ describe VerifyPagesDomainService do
stub_resolver
stub_resolver
end
end
it
'unverifies but does not disable domain'
do
include_examples
'unverifing domain'
expect
(
service
.
execute
).
to
eq
(
error_status
)
expect
(
domain
).
not_to
be_verified
expect
(
domain
).
to
be_enabled
end
end
end
end
end
...
@@ -125,13 +145,40 @@ describe VerifyPagesDomainService do
...
@@ -125,13 +145,40 @@ describe VerifyPagesDomainService do
stub_resolver
stub_resolver
end
end
it
'disables domain'
do
let
(
:error_status
)
{
{
status: :error
,
message:
"Couldn't verify
#{
domain
.
domain
}
. It is now disabled."
}
}
error_status
[
:message
]
+=
'. It is now disabled.'
expect
(
service
.
execute
).
to
eq
(
error_status
)
include_examples
'unverifies and disables domain'
end
end
expect
(
domain
).
not_to
be_verified
context
'when domain is disabled and scheduled for removal'
do
expect
(
domain
).
not_to
be_enabled
let
(
:domain
)
{
create
(
:pages_domain
,
:disabled
,
:scheduled_for_removal
)
}
context
'when the right code is present'
do
before
do
stub_resolver
(
domain
.
domain
=>
domain
.
keyed_verification_code
)
end
it
'verifies and enables domain'
do
expect
(
service
.
execute
).
to
eq
(
status: :success
)
expect
(
domain
).
to
be_verified
expect
(
domain
).
to
be_enabled
end
it
'prevent domain from being removed'
do
expect
{
service
.
execute
}.
to
change
{
domain
.
remove_at
}.
to
(
nil
)
end
end
context
'when the right code is not present'
do
before
do
stub_resolver
end
it
'keeps domain scheduled for removal but does not change removal time'
do
expect
{
service
.
execute
}.
not_to
change
{
domain
.
remove_at
}
expect
(
domain
.
remove_at
).
to
be_present
end
end
end
end
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment