annotate backup-trac-project @ 0:186968f53947 default tip

Initial Import
author Louis Opter <louis.opter@dotcloud.com>
date Fri, 19 Mar 2010 21:40:29 +0100
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
1 #!/usr/bin/env python
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
2
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
3 # The MIT License
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
4 #
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
5 # Copyright (c) 2010 Louis Opter <kalessin@kalessin.fr>
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
6 #
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
7 # Permission is hereby granted, free of charge, to any person obtaining a copy
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
8 # of this software and associated documentation files (the "Software"), to deal
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
9 # in the Software without restriction, including without limitation the rights
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
10 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
11 # copies of the Software, and to permit persons to whom the Software is
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
12 # furnished to do so, subject to the following conditions:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
13 #
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
14 # The above copyright notice and this permission notice shall be included in
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
15 # all copies or substantial portions of the Software.
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
16 #
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
17 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
18 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
19 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
20 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
21 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
22 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
23 # THE SOFTWARE.
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
24
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
25 import errno
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
26 import os
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
27 import shutil
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
28 import subprocess
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
29 import sys
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
30 import tarfile
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
31 import tempfile
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
32
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
33 class TempDir(object):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
34 """Wrap tempfile.mkdtemp to use the with statement"""
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
35
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
36 def __init__(self):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
37 pass
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
38
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
39 def __enter__(self):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
40 self.__path = tempfile.mkdtemp()
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
41 return self.__path
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
42
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
43 def __exit__(self, exc_type, exc_value, traceback):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
44 shutil.rmtree(self.__path)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
45
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
46 def status(message):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
47 print '%s: %s.' % (os.path.basename(sys.argv[0]), message)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
48
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
49 def die(message):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
50 status(message)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
51 status('a log has been recorded in %s' % log_path)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
52 sys.exit(1)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
53
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
54 def hotcopy_repo():
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
55 """Use trac-admin to hotcopy the trac environnement into `root'"""
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
56
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
57 dest = os.path.join(root, name)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
58 if subprocess.call(['sudo', 'trac-admin', trac_env_root, 'hotcopy', dest],
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
59 stdout=log, stderr=log) != 0:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
60 die('error while copying the Trac environnement into a temporary directory')
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
61
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
62 subprocess.call(['sudo', 'chown', '-R', 'ubuntu:ubuntu', dest])
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
63
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
64 status('Trac environnement copied')
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
65
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
66 def archive_repo():
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
67 """Create a tar bzipped archive of the trac environnement"""
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
68
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
69 try:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
70 archive = tarfile.open(os.path.join(root, archive_name), 'w:bz2')
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
71 archive.add(os.path.join(root, name), 'backup-tracenv-%s' % name)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
72 archive.close()
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
73 except tarfile.TarError, ex:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
74 die('Can\'t create the tar archive %s: %s' % (archive_name, str(ex)))
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
75
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
76 status('Archive %s created' % archive_name)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
77
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
78 def send_repo():
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
79 """Send the tar to archive using scp"""
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
80
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
81 dest = sys.argv[2]
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
82 archive = os.path.join(root, archive_name)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
83 if subprocess.call(['scp', archive, dest]) != 0:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
84 die('error while scpying %s to %s' % (archive_name, dest))
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
85
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
86 status('Archive %s copied to "%s"' % (archive_name, dest))
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
87
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
88 if __name__ == '__main__':
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
89 if len(sys.argv) != 3 or sys.argv[1] == '--help':
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
90 print 'Usage: %s project-name [[user@]host:]path' % os.path.basename(sys.argv[0])
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
91 sys.exit(0)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
92
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
93 # globals
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
94 name = sys.argv[1]
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
95 archive_name = 'backup-tracenv-%s.tar.bz2' % name
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
96 log_path = os.path.join(os.getenv('TMP') or '/tmp/', name + '.log')
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
97 trac_env_root = os.path.join('/var/trac/envs/', name)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
98
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
99 if not os.path.exists(trac_env_root):
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
100 status('%s: %s' % (name, os.strerror(errno.ENOENT)))
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
101 sys.exit(1)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
102
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
103 with open(log_path, 'w') as log:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
104 with TempDir() as root:
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
105 status('root=%s' % root)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
106 hotcopy_repo()
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
107 archive_repo()
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
108 send_repo()
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
109 os.remove(log_path)
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
110
186968f53947 Initial Import
Louis Opter <louis.opter@dotcloud.com>
parents:
diff changeset
111 sys.exit(0)