Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
slapos
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
0
Merge Requests
0
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
Jean-Paul Smets
slapos
Commits
28d19e96
Commit
28d19e96
authored
Sep 06, 2016
by
Nicolas Wavrant
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
resilient: backup.signature can be accessed from takeover interface
parent
1a803bf0
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
10 additions
and
7 deletions
+10
-7
stack/resilient/buildout.cfg
stack/resilient/buildout.cfg
+2
-2
stack/resilient/pbsready-import.cfg.in
stack/resilient/pbsready-import.cfg.in
+7
-5
stack/resilient/resilient-web-takeover-cgi-script.py.in
stack/resilient/resilient-web-takeover-cgi-script.py.in
+1
-0
No files found.
stack/resilient/buildout.cfg
View file @
28d19e96
...
@@ -50,7 +50,7 @@ mode = 0644
...
@@ -50,7 +50,7 @@ mode = 0644
recipe = slapos.recipe.template
recipe = slapos.recipe.template
url = ${:_profile_base_location_}/pbsready-import.cfg.in
url = ${:_profile_base_location_}/pbsready-import.cfg.in
output = ${buildout:directory}/pbsready-import.cfg
output = ${buildout:directory}/pbsready-import.cfg
md5sum =
f4e6831110ad5fcf29e3463f49556eee
md5sum =
cdebc491a50a61fecc3391a5eb311bdb
mode = 0644
mode = 0644
[pbsready-export]
[pbsready-export]
...
@@ -95,7 +95,7 @@ output = ${buildout:directory}/instance-frozen.cfg
...
@@ -95,7 +95,7 @@ output = ${buildout:directory}/instance-frozen.cfg
[resilient-web-takeover-cgi-script-download]
[resilient-web-takeover-cgi-script-download]
recipe = slapos.recipe.build:download
recipe = slapos.recipe.build:download
url = ${:_profile_base_location_}/resilient-web-takeover-cgi-script.py.in
url = ${:_profile_base_location_}/resilient-web-takeover-cgi-script.py.in
md5sum =
b3b47dd6e499ac2ea36aa32dbbdfd5f5
md5sum =
c46c8e3e4ce4376c98ad2fc0e2ff0fe4
mode = 0644
mode = 0644
destination = ${buildout:directory}/resilient-web-takeover-cgi-script.py.in
destination = ${buildout:directory}/resilient-web-takeover-cgi-script.py.in
...
...
stack/resilient/pbsready-import.cfg.in
View file @
28d19e96
...
@@ -62,12 +62,13 @@ callback = $${importer:wrapper}
...
@@ -62,12 +62,13 @@ callback = $${importer:wrapper}
[post-notification-run]
[post-notification-run]
recipe = collective.recipe.template
recipe = collective.recipe.template
diff-file-name = $${basedirectory:backup}/backup.diff
diff-file = $${basedirectory:backup}/backup.diff
proof-signature-file = $${basedirectory:backup}/proof.signature
input = inline:
input = inline:
#!/${bash:location}/bin/bash
#!/${bash:location}/bin/bash
cd $${directory:backup}
cd $${directory:backup}
find -type f ! -name backup.signature ! -wholename "./rdiff-backup-data/*" -print0 | xargs -P4 -0 sha256sum | LC_ALL=C sort -k 66 >
../proof.signature
find -type f ! -name backup.signature ! -wholename "./rdiff-backup-data/*" -print0 | xargs -P4 -0 sha256sum | LC_ALL=C sort -k 66 >
$${:proof-signature-file}
diff -ruw backup.signature $${
basedirectory:backup}/proof.signature > $${:diff-file-nam
e}
diff -ruw backup.signature $${
:proof-signature-file} > $${:diff-fil
e}
output = $${rootdirectory:bin}/post-notification-run
output = $${rootdirectory:bin}/post-notification-run
mode = 0700
mode = 0700
...
@@ -81,7 +82,7 @@ callback = $${post-notification-run:output}
...
@@ -81,7 +82,7 @@ callback = $${post-notification-run:output}
recipe = slapos.recipe.template:jinja2
recipe = slapos.recipe.template:jinja2
template = inline:
template = inline:
#!/${bash:location}/bin/bash
#!/${bash:location}/bin/bash
if [ "$(wc -l $${post-notification-run:diff-file
-name
} | cut -d \ -f1)" -eq 0 ]; then exit 0; else exit 1; fi
if [ "$(wc -l $${post-notification-run:diff-file} | cut -d \ -f1)" -eq 0 ]; then exit 0; else exit 1; fi
rendered = $${basedirectory:promises}/backup-transfer-integrity-promise
rendered = $${basedirectory:promises}/backup-transfer-integrity-promise
mode = 700
mode = 700
...
@@ -113,6 +114,7 @@ input = ${resilient-web-takeover-cgi-script-download:destination}
...
@@ -113,6 +114,7 @@ input = ${resilient-web-takeover-cgi-script-download:destination}
output = $${directory:cgi-bin}/web-takeover.cgi
output = $${directory:cgi-bin}/web-takeover.cgi
password = $${resilient-web-takeover-password:passwd}
password = $${resilient-web-takeover-password:passwd}
mode = 700
mode = 700
proof-signature-url = $${publish:monitor-base-url}/private/resilient/backup.signature
# XXX could it be something lighter?
# XXX could it be something lighter?
# XXX Add SSL
# XXX Add SSL
...
@@ -167,4 +169,4 @@ curl_path = ${curl:location}/bin/curl
...
@@ -167,4 +169,4 @@ curl_path = ${curl:location}/bin/curl
###########
###########
[backup-signature-link]
[backup-signature-link]
recipe = cns.recipe.symlink
recipe = cns.recipe.symlink
symlink = $${basedirectory:backup}/proof.signature = $${directory:monitor-resilient}/backup.signature
symlink = $${post-notification-run:proof-signature-file} = $${directory:monitor-resilient}/backup.signature
\ No newline at end of file
\ No newline at end of file
stack/resilient/resilient-web-takeover-cgi-script.py.in
View file @
28d19e96
...
@@ -87,6 +87,7 @@ if "password" not in form:
...
@@ -87,6 +87,7 @@ if "password" not in form:
<hr
/>
<hr
/>
<p><b>
Last valid backup:
</b>
%s
</p>
<p><b>
Last valid backup:
</b>
%s
</p>
<p><b>
Importer script(s) of backup in progress:
</b>
%s
</p>
<p><b>
Importer script(s) of backup in progress:
</b>
%s
</p>
<p><b>
Backup Signature:
</b>
<a
href=
'${resilient-web-takeover-cgi-script:proof-signature-url}'
>
${resilient-web-takeover-cgi-script:proof-signature-url}
</a></b></p>
%s
%s
<form
action=
"/"
>
<form
action=
"/"
>
Password:
<input
type=
"text"
name=
"password"
>
Password:
<input
type=
"text"
name=
"password"
>
...
...
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