rattail-corepos/rattail_corepos/commands.py
2024-05-16 19:16:08 -05:00

176 lines
5.9 KiB
Python

# -*- coding: utf-8; -*-
################################################################################
#
# Rattail -- Retail Software Framework
# Copyright © 2010-2024 Lance Edgar
#
# This file is part of Rattail.
#
# Rattail is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# Rattail 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 General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License along with
# Rattail. If not, see <http://www.gnu.org/licenses/>.
#
################################################################################
"""
Rattail Commands
"""
import typer
from typing_extensions import Annotated
from corepos.enum import CoreDbType
from rattail.commands import rattail_typer
from rattail.commands.typer import importer_command, file_importer_command, typer_get_runas_user
from rattail.commands.importing import (ImportSubcommand, ImportFileSubcommand,
ImportCommandHandler)
@rattail_typer.command()
@file_importer_command
def corepos_import_square(
ctx: typer.Context,
**kwargs
):
"""
Import transaction data from Square into CORE
"""
config = ctx.parent.rattail_config
progress = ctx.parent.rattail_progress
handler = ImportCommandHandler(
config, import_handler_key='to_corepos_db_office_trans.from_square_csv.import')
kwargs['user'] = typer_get_runas_user(ctx)
handler.run(kwargs, progress=progress)
@rattail_typer.command()
@importer_command
def export_corepos(
ctx: typer.Context,
**kwargs
):
"""
Export data from Rattail to CORE-POS
"""
config = ctx.parent.rattail_config
progress = ctx.parent.rattail_progress
handler = ImportCommandHandler(
config, import_handler_key='to_corepos_api.from_rattail.export')
kwargs['user'] = typer_get_runas_user(ctx)
handler.run(kwargs, progress=progress)
@rattail_typer.command()
@importer_command
def import_corepos_api(
ctx: typer.Context,
**kwargs
):
"""
Import data from a CORE POS API
"""
config = ctx.parent.rattail_config
progress = ctx.parent.rattail_progress
handler = ImportCommandHandler(
config, import_handler_key='to_rattail.from_corepos_api.import')
kwargs['user'] = typer_get_runas_user(ctx)
handler.run(kwargs, progress=progress)
@rattail_typer.command()
@importer_command
def import_corepos_db(
ctx: typer.Context,
corepos_dbtype: Annotated[
CoreDbType,
typer.Option(help="Type of CORE-POS DB engine to be used as data host. "
"This determines which config section is used with regard "
"to the --corepos-dbkey arg.")] = 'office_op',
corepos_dbkey: Annotated[
str,
typer.Option(help="Config key for CORE POS database engine to be used as "
"the \"host\", i.e. the source of the data to be imported. "
"This key must be defined in the [rattail_corepos.db] section "
"of your config file.")] = 'default',
**kwargs
):
"""
Import data from a CORE POS database
"""
config = ctx.parent.rattail_config
progress = ctx.parent.rattail_progress
handler = ImportCommandHandler(
config, import_handler_key='to_rattail.from_corepos_db_office_op.import')
kwargs['user'] = typer_get_runas_user(ctx)
kwargs['handler_kwargs'] = {
'corepos_dbtype': corepos_dbtype,
'corepos_dbkey': corepos_dbkey,
}
handler.run(kwargs, progress=progress)
class ExportCore(ImportSubcommand):
"""
Export data from Rattail to CORE-POS
"""
name = 'export-corepos'
description = __doc__.strip()
handler_key = 'to_corepos_api.from_rattail.export'
class ImportCOREPOSAPI(ImportSubcommand):
"""
Import data from a CORE POS API
"""
name = 'import-corepos-api'
description = __doc__.strip()
handler_key = 'to_rattail.from_corepos_api.import'
class ImportCOREPOSDB(ImportSubcommand):
"""
Import data from a CORE POS database
"""
name = 'import-corepos-db'
description = __doc__.strip()
handler_key = 'to_rattail.from_corepos_db_office_op.import'
def add_parser_args(self, parser):
super().add_parser_args(parser)
parser.add_argument('--corepos-dbtype', metavar='TYPE', default='office_op',
choices=['office_op', 'office_trans'],
help="Config *type* for CORE-POS database engine to be used as "
"host. Default type is 'office_op' - this determines which "
"config section is used with regard to the --corepos-dbkey arg.")
parser.add_argument('--corepos-dbkey', metavar='KEY', default='default',
help="Config key for CORE POS database engine to be used as the \"host\", "
"i.e. the source of the data to be imported. This key " "must be "
"defined in the [rattail_corepos.db] section of your config file. "
"Defaults to 'default'.")
def get_handler_kwargs(self, **kwargs):
if 'args' in kwargs:
kwargs['corepos_dbtype'] = kwargs['args'].corepos_dbtype
kwargs['corepos_dbkey'] = kwargs['args'].corepos_dbkey
return kwargs
class CoreImportSquare(ImportFileSubcommand):
"""
Import transaction data from Square into CORE
"""
name = 'corepos-import-square'
description = __doc__.strip()
handler_key = 'to_corepos_db_office_trans.from_square_csv.import'