odoo/ext/custom-addons/dp_dump_anonym/service/db.py

65 lines
2.2 KiB
Python
Executable File

# Copyright 2018-Today datenpol gmbh(<http://www.datenpol.at>)
# License OPL-1 or later (https://www.odoo.com/documentation/user/11.0/legal/licenses/licenses.html#licenses).
import json
import logging
import os
import shutil
import tempfile
import base64
import odoo
from odoo.service.db import check_db_management_enabled, dump_db_manifest
_logger = logging.getLogger(__name__)
@check_db_management_enabled
def exp_dump(db_name, backup_format, raw):
with tempfile.TemporaryFile(mode='w+b') as t:
dump_db(db_name, t, backup_format, raw)
t.seek(0)
return base64.b64encode(t.read()).decode()
odoo.service.db.exp_dump = exp_dump
@check_db_management_enabled
def dump_db(db_name, stream, backup_format='zip', raw=None):
_logger.info('DUMP DB: %s format %s', db_name, backup_format)
self_dir = os.path.dirname(os.path.realpath(__file__))
anon_sql_file = os.path.join(self_dir, '..', 'data', 'anon.sql')
with odoo.tools.osutil.tempdir() as dump_dir:
if backup_format == 'zip':
filestore = odoo.tools.config.filestore(db_name)
if os.path.exists(filestore):
shutil.copytree(filestore, os.path.join(dump_dir, 'filestore'))
with open(os.path.join(dump_dir, 'manifest.json'), 'w') as fh:
db = odoo.sql_db.db_connect(db_name)
with db.cursor() as cr:
json.dump(dump_db_manifest(cr), fh, indent=4)
cmd = ['pg_dump', '--no-owner', db_name, '--file=' + os.path.join(dump_dir, 'dump.sql')]
odoo.tools.exec_pg_command(*cmd)
if not raw:
with open(os.path.join(dump_dir, 'dump.sql'), 'ab') as dump_file, open(anon_sql_file, 'rb') as anon:
shutil.copyfileobj(anon, dump_file)
if stream:
odoo.tools.osutil.zip_dir(dump_dir, stream, include_dir=False,
fnct_sort=lambda file_name: file_name != 'dump.sql')
else:
t = tempfile.TemporaryFile()
odoo.tools.osutil.zip_dir(dump_dir, t, include_dir=False,
fnct_sort=lambda file_name: file_name != 'dump.sql')
t.seek(0)
return t
odoo.service.db.dump_db = dump_db