chrono/chrono/manager/management/commands/import_site.py

47 lines
1.7 KiB
Python

# chrono - agendas system
# Copyright (C) 2016-2017 Entr'ouvert
#
# This program is free software: you can redistribute it and/or modify it
# under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import json
from optparse import make_option
import sys
from django.core.management.base import BaseCommand
from chrono.manager.utils import import_site
class Command(BaseCommand):
args = '<filename>'
help = 'Import an exported site'
option_list = BaseCommand.option_list + (
make_option('--clean', action='store_true', default=False,
help='Clean site before importing'),
make_option('--if-empty', action='store_true', default=False,
help='Import only if site is empty'),
make_option('--overwrite', action='store_true', default=False,
help='Overwrite existing data'),
)
def handle(self, filename, **options):
if filename == '-':
fd = sys.stdin
else:
fd = open(filename)
import_site(json.load(fd),
if_empty=options['if_empty'],
clean=options['clean'],
overwrite=options['overwrite'])