-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add bundle-mapper for afso_gdgs migration
- Loading branch information
1 parent
81c7177
commit 04a0d93
Showing
1 changed file
with
120 additions
and
0 deletions.
There are no files selected for viewing
120 changes: 120 additions & 0 deletions
120
opengever/maintenance/scripts/customer_specific/sg_map_afso_gdgs_migration_bundle.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,120 @@ | ||
""" | ||
This is a copy of sg_map_areg_bdgs_migration_bundle.py with issue-specific | ||
adjustments. | ||
This script is solely intended for transforming the bundle exported as part of | ||
TI-1703 (transforms the bundle in-place). | ||
It deletes all exported repository folders from the bundle, because | ||
in this specific case every single source repository folder is mapped to | ||
an (existing) target repository folder - therefore no complicated logic is | ||
needed to determine which repository folders to keep. | ||
Dossiers are mapped to their target position according to the Excel sheet | ||
from https://4teamwork.atlassian.net/browse/TI-1703 | ||
""" | ||
|
||
from collections import OrderedDict | ||
from opengever.maintenance.debughelpers import setup_app | ||
from opengever.maintenance.debughelpers import setup_plone | ||
from operator import itemgetter | ||
from os.path import join as pjoin | ||
import argparse | ||
import codecs | ||
import json | ||
import os | ||
import sys | ||
import transaction | ||
|
||
|
||
# TBD | ||
MAPPING = { | ||
((1, 1), ): ((9, 0, 0), ), # Example | ||
((1, 0), ): ((1, 10, 0), (1, )), # Example | ||
} | ||
|
||
|
||
class BundleMapper(object): | ||
|
||
def __init__(self, portal, options): | ||
self.portal = portal | ||
self.options = options | ||
self.bundle_dir = self.options.bundle_path | ||
|
||
def run(self): | ||
self.map_dossiers() | ||
self.remove_repofolders() | ||
|
||
def order_dict(self, data): | ||
ordered = OrderedDict() | ||
ordered['guid'] = data.pop('guid') | ||
|
||
parent_guid = data.pop('parent_guid', None) | ||
permissions = data.pop('_permissions', None) | ||
|
||
if parent_guid: | ||
ordered['parent_guid'] = parent_guid | ||
|
||
ordered.update(OrderedDict(sorted(data.items()))) | ||
|
||
if permissions: | ||
ordered['_permissions'] = permissions | ||
|
||
return ordered | ||
|
||
def map_dossiers(self): | ||
dossiers_json_path = pjoin(self.bundle_dir, 'dossiers.json') | ||
with open(dossiers_json_path) as json_file: | ||
dossier_items = json.load(json_file) | ||
|
||
dossier_items = map(self.order_dict, dossier_items) | ||
dossier_items.sort(key=itemgetter('guid')) | ||
|
||
for dossier in dossier_items: | ||
parent_reference = dossier.get('parent_reference') | ||
if not parent_reference: | ||
continue | ||
parent_reference = map(tuple, parent_reference) | ||
parent_reference = tuple(parent_reference) | ||
|
||
new_reference = MAPPING.get(parent_reference) | ||
if new_reference: | ||
print('Mapped %r to %r for %s' % ( | ||
parent_reference, new_reference, dossier['guid'])) | ||
dossier['parent_reference'] = new_reference | ||
else: | ||
# Assertion - every dossier is mapped | ||
raise Exception(dossier['guid']) | ||
|
||
self.dump_to_jsonfile(dossier_items, dossiers_json_path) | ||
|
||
def remove_repofolders(self): | ||
os.remove(pjoin(self.bundle_dir, 'repofolders.json')) | ||
os.remove(pjoin(self.bundle_dir, 'reporoots.json')) | ||
|
||
def dump_to_jsonfile(self, data, json_path): | ||
with open(json_path, 'wb') as jsonfile: | ||
json.dump( | ||
data, | ||
codecs.getwriter('utf-8')(jsonfile), | ||
ensure_ascii=False, | ||
indent=4, | ||
separators=(',', ': ') | ||
) | ||
|
||
|
||
if __name__ == '__main__': | ||
app = setup_app() | ||
|
||
parser = argparse.ArgumentParser() | ||
parser.add_argument('-s', dest='site_root', default=None, | ||
help='Absolute path to the Plone site') | ||
parser.add_argument('bundle_path', help='Path to bundle') | ||
|
||
options = parser.parse_args(sys.argv[3:]) | ||
|
||
transaction.doom() | ||
plone = setup_plone(app, options) | ||
|
||
generator = BundleMapper(plone, options) | ||
generator.run() |