Parent: [d4b2bc] (diff)

Child: [ea9881] (diff)

Download this file

purge_project.py    59 lines (50 with data), 1.7 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
47
48
49
50
51
52
53
54
55
56
57
58
import sys
import logging
from pylons import g, c
from ming.orm import session, mapper, MappedClass
from allura import model as M
log = logging.getLogger(__name__)
def main():
USAGE='Usage: %s <shortname> [test]' % sys.argv[0]
if len(sys.argv) not in (2,3):
log.error(USAGE)
return 1
if len(sys.argv) == 3 and sys.argv[2] != 'test':
log.error(USAGE)
return 1
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 2
if len(sys.argv) == 3:
log.info('Test mode, not purging project')
else:
purge_project(project)
return 0
def purge_project(project):
gid = project.tool_data.get('sfx', {}).get('group_id', project._id)
project.shortname = 'deleted-%s' % gid
project.deleted = True
g.solr.delete(q='project_id_s:%s' % project._id)
session(project).flush()
c.project = project
app_config_ids = [
ac._id for ac in M.AppConfig.query.find(dict(project_id=c.project._id)) ]
for name, cls in MappedClass._registry.iteritems():
if 'project_id' in mapper(cls).property_index:
# Purge the things directly related to the project
cls.query.remove(
dict(project_id=project._id),
)
elif 'app_config_id' in mapper(cls).property_index:
# ... and the things related to its apps
cls.query.remove(
dict(app_config_id={'$in':app_config_ids}),
)
else:
# Don't dump other things
continue
if __name__ == '__main__':
sys.exit(main())