Child: [515b02] (diff)

Download this file

purge_project.py    47 lines (38 with data), 1.3 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
import os
import sys
import json
import logging
from pylons import g
from ming.orm import state, session
from pymongo.json_util import default
from pyforge import model as M
log = logging.getLogger(__name__)
MONGO_HOME=os.environ.get('MONGO_HOME', '')
MONGO_DUMP=os.path.join(MONGO_HOME, 'bin/mongodump')
MONGO_RESTORE=os.path.join(MONGO_HOME, 'bin/mongorestore')
def main():
if len(sys.argv) != 2:
log.error('Usage: %s <shortname>', sys.argv[0])
return
pname = sys.argv[1]
log.info('Purging %s', pname)
project = M.Project.query.get(shortname=pname)
if project is None:
log.fatal('Project %s not found', pname)
return
dump_project(project)
def dump_project(project):
pname = project.shortname
gid = project.tool_data.get('sfx', {}).get('group_id', project._id)
dirname = '%s-%s.purge' % (pname, gid)
log.info('Purging %s to %s', pname, dirname)
os.system('%s --db %s -o %s' % (
MONGO_DUMP, project.database, dirname))
with open(os.path.join(dirname, 'project.json'), 'w') as fp:
json.dump(state(project).document, fp, default=default)
project.shortname = 'deleted-%s' % gid
project.deleted = True
g.solr.delete(q='project_id_s:%s' % project._id)
session(project).flush()
if __name__ == '__main__':
main()