Browse Source

Adiciona dump de templates do SDE

pull/1634/head
Marcio Mazza 7 years ago
parent
commit
203d7493b4
  1. 21
      sapl/legacy/scripts/exporta_zope/exporta_zope.py

21
sapl/legacy/scripts/exporta_zope/exporta_zope.py

@ -139,28 +139,30 @@ def read_sde(element):
def read_properties():
for id, obj, meta_type in enumerate_properties(element):
assert meta_type == 'string'
if id == 'title':
assert not obj
else:
yield id, decode_iso8859(obj)
def read_children():
for id, obj, meta_type in enumerate_folder(element):
assert meta_type == 'SDE-Document-Element'
assert meta_type in ['SDE-Document-Element',
'SDE-Template-Element',
'SDE-Template-Link',
'SDE-Template-Attribute',
'Script (Python)',
]
if meta_type != 'Script (Python)':
# ignoramos os scrips python de eventos dos templates
yield id, read_sde(obj)
data = dict(read_properties())
children = list(read_children())
if children:
assert all(k.startswith('SDE') for k, v in children)
data['children'] = children
return data
def dump_sde(strdoc, path):
def dump_sde(strdoc, path, tipo):
id = strdoc['id']
fullname = os.path.join(path, id + '.sde.yaml')
fullname = os.path.join(path, '{}.{}.yaml'.format(id, tipo))
print(fullname)
sde = read_sde(strdoc)
with open(fullname, 'w') as arquivo:
@ -173,7 +175,8 @@ DUMP_FUNCTIONS = {
'Image': dump_file,
'Folder': partial(dump_folder, enum=enumerate_folder),
'BTreeFolder2': partial(dump_folder, enum=enumerate_btree),
'SDE-Document': dump_sde,
'SDE-Document': partial(dump_sde, tipo='sde.document'),
'SDE-Template': partial(dump_sde, tipo='sde.template'),
# explicitamente ignorados
'ZCatalog': None,

Loading…
Cancel
Save