meerschaum 2.7.1__tar.gz → 2.7.3__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {meerschaum-2.7.1/meerschaum.egg-info → meerschaum-2.7.3}/PKG-INFO +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/_parse_arguments.py +2 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/_parser.py +17 -11
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/clear.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/edit.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/verify.py +18 -21
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/__init__.py +0 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/dashboard.py +2 -11
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/connectors.py +7 -9
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/termpage.html +3 -3
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_version.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_fetch.py +45 -26
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_instance.py +4 -4
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_pipes.py +135 -103
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_attributes.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_dtypes.py +9 -9
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_fetch.py +2 -3
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_sync.py +11 -3
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_verify.py +9 -5
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/__init__.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dataframe.py +10 -2
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dtypes/sql.py +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/__init__.py +5 -25
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_pipes.py +9 -6
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/sql.py +156 -87
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/venv/__init__.py +44 -6
- {meerschaum-2.7.1 → meerschaum-2.7.3/meerschaum.egg-info}/PKG-INFO +1 -1
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_pipes_dtypes.py +69 -8
- {meerschaum-2.7.1 → meerschaum-2.7.3}/LICENSE +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/NOTICE +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/README.md +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/__main__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/docs/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/docs/index.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/entry.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/_windows.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/actions.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/Shell.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/ShellCompleter.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/ValidAutoSuggest.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/resources/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/updates.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/TermPageHandler.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/tools.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/api.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/attach.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/bootstrap.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/copy.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/deduplicate.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/delete.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/drop.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/install.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/login.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/os.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/pause.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/python.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/register.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/reload.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/restart.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/setup.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sh.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/show.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sql.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/stack.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/start.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/stop.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sync.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/tag.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/uninstall.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/upgrade.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_chain.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_events.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_oauth2.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_websockets.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/ansi_up.js +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/banner_1920x320.png +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/favicon.ico +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/logo_48x48.png +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/logo_500x500.png +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/custom.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/login.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/register.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/components.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/graphs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/keys.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/dashboard.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/error.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/job.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/login.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/register.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/sessions.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/sync.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/websockets.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/webterm.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_interfaces.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_locations.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_metrics.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/bootstrap.min.css +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/dash.css +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/dbc_dark.css +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/styles.css +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/xterm.css +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/ico/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/ico/logo.ico +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/action_button.js +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/main.js +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/terminado.js +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/xterm.js +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/png/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/index.html +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/old_index.html +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/secret.html +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_actions.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_connectors.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_index.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_login.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_misc.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_version.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_webterm.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/tables/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_dash.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_default.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_edit.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_environment.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_formatting.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_patch.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_paths.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_preprocess.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_read_config.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_shell.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_sync.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/paths.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/resources/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/grafana/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/mosquitto/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/mosquitto/resources/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/resources/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/static/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/_Connector.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_APIConnector.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_actions.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_fetch.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_login.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_misc.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_request.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_uri.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/parse.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/plugin/PluginConnector.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/plugin/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/poll.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_SQLConnector.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_cli.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_create_engine.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_sql.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_uri.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tables/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tables/types.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tools.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_ValkeyConnector.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_fetch.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_plugins.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_bootstrap.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_clear.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_copy.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_data.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_deduplicate.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_delete.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_drop.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_edit.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_register.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_show.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Plugin/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/User/_User.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/User/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/_Executor.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/_Job.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/systemd.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/_Plugin.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/bootstrap.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/_get_pipes.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/Daemon.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/FileDescriptorInterceptor.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/RotatingFile.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/StdinFile.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/_names.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/debug.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dtypes/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_pprint.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_shell.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/interactive.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/misc.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/networking.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/__init__.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/_packages.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/lazy_loader.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/pool.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/process.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/prompt.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/schedule.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/threading.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/typing.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/venv/_Venv.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/warnings.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/yaml.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/SOURCES.txt +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/dependency_links.txt +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/entry_points.txt +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/requires.txt +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/top_level.txt +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/zip-safe +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/setup.cfg +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/setup.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_actions.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_arguments.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_deduplicate.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_jobs.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_pipe_data.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_sql.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_sync.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_users.py +0 -0
- {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_verify.py +0 -0
@@ -240,6 +240,8 @@ def parse_synonyms(
|
|
240
240
|
args_dict['instance'] = args_dict['mrsm_instance']
|
241
241
|
if args_dict.get('skip_check_existing', None):
|
242
242
|
args_dict['check_existing'] = False
|
243
|
+
if args_dict.get('skip_enforce_dtypes', None):
|
244
|
+
args_dict['enforce_dtypes'] = False
|
243
245
|
if args_dict.get('venv', None) in ('None', '[None]'):
|
244
246
|
args_dict['venv'] = None
|
245
247
|
chunk_minutes = args_dict.get('chunk_minutes', None)
|
@@ -87,7 +87,7 @@ def parse_datetime(dt_str: str) -> Union[datetime, int, str]:
|
|
87
87
|
dt = round_time(dt, round_delta)
|
88
88
|
else:
|
89
89
|
dt = dateutil_parser.parse(dt_str)
|
90
|
-
except Exception
|
90
|
+
except Exception:
|
91
91
|
dt = None
|
92
92
|
if dt is None:
|
93
93
|
from meerschaum.utils.warnings import error
|
@@ -121,7 +121,7 @@ def parse_help(sysargs: Union[List[str], Dict[str, Any]]) -> None:
|
|
121
121
|
"""Parse the `--help` flag to determine which help message to print."""
|
122
122
|
from meerschaum._internal.arguments._parse_arguments import parse_arguments, parse_line
|
123
123
|
from meerschaum.actions import actions, get_subactions
|
124
|
-
import
|
124
|
+
import textwrap
|
125
125
|
from copy import deepcopy
|
126
126
|
if isinstance(sysargs, list):
|
127
127
|
args = parse_arguments(sysargs)
|
@@ -140,14 +140,14 @@ def parse_help(sysargs: Union[List[str], Dict[str, Any]]) -> None:
|
|
140
140
|
if len(args['action']) > 1:
|
141
141
|
try:
|
142
142
|
subaction = get_subactions(args['action'][0])[args['action'][1]]
|
143
|
-
except Exception
|
143
|
+
except Exception:
|
144
144
|
subaction = None
|
145
145
|
if subaction is not None:
|
146
146
|
return print(textwrap.dedent(subaction.__doc__))
|
147
147
|
|
148
148
|
try:
|
149
149
|
doc = actions[args['action'][0]].__doc__
|
150
|
-
except Exception
|
150
|
+
except Exception:
|
151
151
|
doc = None
|
152
152
|
if doc is None:
|
153
153
|
doc = "No help available for '" + f"{args['action'][0]}" + "'."
|
@@ -309,7 +309,7 @@ groups['sync'].add_argument(
|
|
309
309
|
)
|
310
310
|
groups['sync'].add_argument(
|
311
311
|
'--chunksize', type=int, help=(
|
312
|
-
"Specify the database chunksize. Defaults to
|
312
|
+
"Specify the database chunksize. Defaults to 100,000."
|
313
313
|
),
|
314
314
|
)
|
315
315
|
groups['sync'].add_argument(
|
@@ -336,19 +336,25 @@ groups['sync'].add_argument(
|
|
336
336
|
)
|
337
337
|
groups['sync'].add_argument(
|
338
338
|
'--bounded', '--bound', action="store_true",
|
339
|
-
help
|
339
|
+
help=(
|
340
340
|
"When verifying, do not sync outside "
|
341
|
-
|
341
|
+
"the existing oldest and newest datetime bounds."
|
342
342
|
)
|
343
343
|
)
|
344
344
|
groups['sync'].add_argument(
|
345
345
|
'--skip-check-existing', '--allow-duplicates', action='store_true',
|
346
|
-
help
|
347
|
-
"Skip checking for duplicate rows when syncing. "
|
348
|
-
"This
|
349
|
-
"For example, this setting is highly recommended for use with IoT devices."
|
346
|
+
help=(
|
347
|
+
"Skip checking for duplicate rows when syncing. "
|
348
|
+
"This improves performance when all rows to be synced are unique. "
|
350
349
|
)
|
351
350
|
)
|
351
|
+
groups['sync'].add_argument(
|
352
|
+
'--skip-enforce-dtypes', action='store_true',
|
353
|
+
help=(
|
354
|
+
"Skip enforcing incoming data to a pipe's dtypes. "
|
355
|
+
"This improves performance when all rows are expected to already be of the correct type."
|
356
|
+
),
|
357
|
+
)
|
352
358
|
groups['sync'].add_argument(
|
353
359
|
'--cache', action='store_true',
|
354
360
|
help = (
|
@@ -137,7 +137,7 @@ def _ask_with_rowcounts(
|
|
137
137
|
)
|
138
138
|
total_num_rows = sum([rc for p, rc in pipes_rowcounts.items()])
|
139
139
|
question = (
|
140
|
-
f"Are you sure you want to delete {total_num_rows} rows across {len(pipes)} pipe"
|
140
|
+
f"Are you sure you want to delete {total_num_rows:,} rows across {len(pipes)} pipe"
|
141
141
|
+ ('s' if len(pipes) != 1 else '')
|
142
142
|
+ " in the following range?\n"
|
143
143
|
)
|
@@ -10,9 +10,9 @@ from __future__ import annotations
|
|
10
10
|
from meerschaum.utils.typing import Union, Any, Sequence, SuccessTuple, Optional, Tuple, List
|
11
11
|
|
12
12
|
def verify(
|
13
|
-
|
14
|
-
|
15
|
-
|
13
|
+
action: Optional[List[str]] = None,
|
14
|
+
**kwargs: Any
|
15
|
+
) -> SuccessTuple:
|
16
16
|
"""
|
17
17
|
Verify the states of pipes, packages, and more.
|
18
18
|
"""
|
@@ -36,19 +36,17 @@ def _verify_pipes(**kwargs) -> SuccessTuple:
|
|
36
36
|
|
37
37
|
|
38
38
|
def _verify_packages(
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
39
|
+
debug: bool = False,
|
40
|
+
venv: Optional[str] = 'mrsm',
|
41
|
+
**kw
|
42
|
+
) -> SuccessTuple:
|
43
43
|
"""
|
44
44
|
Verify the versions of packages.
|
45
45
|
"""
|
46
46
|
from meerschaum.utils.packages import (
|
47
|
-
attempt_import,
|
47
|
+
attempt_import, all_packages, is_installed, venv_contains_package,
|
48
48
|
_monkey_patch_get_distribution, manually_import_module,
|
49
49
|
)
|
50
|
-
from meerschaum.utils.formatting import pprint
|
51
|
-
from meerschaum.utils.debug import dprint
|
52
50
|
|
53
51
|
venv_packages, base_packages, miss_packages = [], [], []
|
54
52
|
|
@@ -80,10 +78,10 @@ def _verify_packages(
|
|
80
78
|
|
81
79
|
|
82
80
|
def _verify_venvs(
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
81
|
+
action: Optional[List[str]],
|
82
|
+
debug: bool = False,
|
83
|
+
**kw
|
84
|
+
) -> SuccessTuple:
|
87
85
|
"""
|
88
86
|
Verify your virtual environments.
|
89
87
|
"""
|
@@ -94,15 +92,14 @@ def _verify_venvs(
|
|
94
92
|
|
95
93
|
|
96
94
|
def _verify_plugins(
|
97
|
-
|
98
|
-
|
99
|
-
|
95
|
+
action: Optional[List[str]] = None,
|
96
|
+
**kwargs: Any
|
97
|
+
) -> SuccessTuple:
|
100
98
|
"""
|
101
99
|
Verify that all of the available plugins are able to be imported as expected.
|
102
100
|
"""
|
103
|
-
from meerschaum.utils.formatting import print_options,
|
104
|
-
from meerschaum.plugins import
|
105
|
-
from meerschaum.config import get_config
|
101
|
+
from meerschaum.utils.formatting import print_options, print_tuple
|
102
|
+
from meerschaum.plugins import get_plugins_names, Plugin
|
106
103
|
from meerschaum.utils.misc import items_str
|
107
104
|
|
108
105
|
plugins_names_to_verify = action or get_plugins_names()
|
@@ -135,7 +132,7 @@ def _verify_plugins(
|
|
135
132
|
f"Successfully imported {len(plugins_names_to_verify)} plugins."
|
136
133
|
if success
|
137
134
|
else (
|
138
|
-
|
135
|
+
"Failed to import plugin"
|
139
136
|
+ ('s' if len(failed_to_import) != 1 else '')
|
140
137
|
+ f" {items_str(failed_to_import)}."
|
141
138
|
)
|
@@ -486,19 +486,18 @@ def update_flags(input_flags_dropdown_values, n_clicks, input_flags_texts):
|
|
486
486
|
Output('location-keys-dropdown', 'value'),
|
487
487
|
Output('instance-select', 'value'),
|
488
488
|
Output('instance-alert-div', 'children'),
|
489
|
-
Output('instance-store', 'data'),
|
490
489
|
Input('connector-keys-dropdown', 'value'),
|
491
490
|
Input('metric-keys-dropdown', 'value'),
|
492
491
|
Input('location-keys-dropdown', 'value'),
|
493
492
|
Input('instance-select', 'value'),
|
494
|
-
|
493
|
+
*keys_state ### NOTE: Necessary for `ctx.states`.
|
495
494
|
)
|
496
495
|
def update_keys_options(
|
497
496
|
connector_keys: Optional[List[str]],
|
498
497
|
metric_keys: Optional[List[str]],
|
499
498
|
location_keys: Optional[List[str]],
|
500
499
|
instance_keys: Optional[str],
|
501
|
-
|
500
|
+
*keys
|
502
501
|
):
|
503
502
|
"""
|
504
503
|
Update the keys dropdown menus' options.
|
@@ -507,8 +506,6 @@ def update_keys_options(
|
|
507
506
|
trigger = ctx.triggered[0]['prop_id'].split('.')[0]
|
508
507
|
instance_click = trigger == 'instance-select'
|
509
508
|
|
510
|
-
session_instance = instance_store_data.get('session_instance', None)
|
511
|
-
|
512
509
|
### Update the instance first.
|
513
510
|
update_instance_keys = False
|
514
511
|
if not instance_keys:
|
@@ -517,11 +514,6 @@ def update_keys_options(
|
|
517
514
|
instance_keys = str(get_api_connector())
|
518
515
|
update_instance_keys = True
|
519
516
|
|
520
|
-
instance_store_data_to_return = (
|
521
|
-
{**(instance_store_data or {}), **{'session_instance': instance_keys}}
|
522
|
-
if update_instance_keys or session_instance != instance_keys
|
523
|
-
else dash.no_update
|
524
|
-
)
|
525
517
|
if not trigger and not update_instance_keys:
|
526
518
|
raise PreventUpdate
|
527
519
|
|
@@ -626,7 +618,6 @@ def update_keys_options(
|
|
626
618
|
location_keys,
|
627
619
|
(instance_keys if update_instance_keys else dash.no_update),
|
628
620
|
instance_alerts,
|
629
|
-
instance_store_data_to_return,
|
630
621
|
)
|
631
622
|
|
632
623
|
dash_app.clientside_callback(
|
@@ -7,15 +7,16 @@ Functions for interacting with Meerschaum connectors via the Web Interface.
|
|
7
7
|
"""
|
8
8
|
|
9
9
|
from __future__ import annotations
|
10
|
-
|
10
|
+
|
11
|
+
import meerschaum as mrsm
|
12
|
+
from meerschaum.utils.typing import WebState, Union
|
11
13
|
from meerschaum.connectors.parse import parse_instance_keys
|
12
|
-
from meerschaum.config import get_config
|
13
14
|
from meerschaum.api import debug, get_api_connector
|
14
15
|
|
15
|
-
def get_web_connector(state
|
16
|
-
|
17
|
-
|
18
|
-
|
16
|
+
def get_web_connector(state: WebState) -> Union[
|
17
|
+
mrsm.connectors.api.APIConnector,
|
18
|
+
mrsm.connectors.sql.SQLConnector,
|
19
|
+
]:
|
19
20
|
"""
|
20
21
|
Parse the web instance keys into a connector.
|
21
22
|
"""
|
@@ -24,7 +25,4 @@ def get_web_connector(state : WebState) -> Union[
|
|
24
25
|
if not state.get('instance-select.value', None)
|
25
26
|
else state['instance-select.value']
|
26
27
|
)
|
27
|
-
|
28
28
|
return parse_instance_keys(instance_keys, debug=debug)
|
29
|
-
|
30
|
-
|
@@ -37,7 +37,7 @@ window.addEventListener(
|
|
37
37
|
connector_keys_str += " " + quote_str + ck + quote_str;
|
38
38
|
}
|
39
39
|
}
|
40
|
-
if (
|
40
|
+
if (connector_keys_str === " -c"){
|
41
41
|
connector_keys_str = "";
|
42
42
|
}
|
43
43
|
let metric_keys_str = " -m";
|
@@ -47,7 +47,7 @@ window.addEventListener(
|
|
47
47
|
metric_keys_str += " " + quote_str + mk + quote_str;
|
48
48
|
}
|
49
49
|
}
|
50
|
-
if (
|
50
|
+
if (metric_keys_str === " -m"){
|
51
51
|
metric_keys_str = "";
|
52
52
|
}
|
53
53
|
let location_keys_str = " -l";
|
@@ -57,7 +57,7 @@ window.addEventListener(
|
|
57
57
|
location_keys_str += " " + quote_str + lk + quote_str;
|
58
58
|
}
|
59
59
|
}
|
60
|
-
if (
|
60
|
+
if (location_keys_str === " -l"){
|
61
61
|
location_keys_str = "";
|
62
62
|
}
|
63
63
|
|
@@ -9,6 +9,7 @@ Implement the Connector fetch() method
|
|
9
9
|
from __future__ import annotations
|
10
10
|
|
11
11
|
from datetime import datetime, timedelta
|
12
|
+
|
12
13
|
import meerschaum as mrsm
|
13
14
|
from meerschaum.utils.typing import Optional, Union, Callable, Any, List, Dict
|
14
15
|
|
@@ -144,37 +145,37 @@ def get_pipe_metadef(
|
|
144
145
|
-------
|
145
146
|
A pipe's meta definition fetch query string.
|
146
147
|
"""
|
147
|
-
from meerschaum.utils.
|
148
|
-
from meerschaum.utils.warnings import warn, error
|
148
|
+
from meerschaum.utils.warnings import warn
|
149
149
|
from meerschaum.utils.sql import sql_item_name, dateadd_str, build_where
|
150
|
+
from meerschaum.utils.dtypes.sql import get_db_type_from_pd_type
|
150
151
|
from meerschaum.utils.misc import is_int
|
151
152
|
from meerschaum.config import get_config
|
152
153
|
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
dt_name = sql_item_name(_dt, self.flavor, None) if _dt else None
|
154
|
+
dt_col = pipe.columns.get('datetime', None)
|
155
|
+
if not dt_col:
|
156
|
+
dt_col = pipe.guess_datetime()
|
157
|
+
dt_name = sql_item_name(dt_col, self.flavor, None) if dt_col else None
|
158
158
|
is_guess = True
|
159
159
|
else:
|
160
|
-
|
161
|
-
dt_name = sql_item_name(_dt, self.flavor, None)
|
160
|
+
dt_name = sql_item_name(dt_col, self.flavor, None)
|
162
161
|
is_guess = False
|
162
|
+
dt_typ = pipe.dtypes.get(dt_col, 'datetime') if dt_col else None
|
163
|
+
db_dt_typ = get_db_type_from_pd_type(dt_typ, self.flavor) if dt_typ else None
|
163
164
|
|
164
165
|
if begin not in (None, '') or end is not None:
|
165
166
|
if is_guess:
|
166
|
-
if
|
167
|
+
if dt_col is None:
|
167
168
|
warn(
|
168
169
|
f"Unable to determine a datetime column for {pipe}."
|
169
170
|
+ "\n Ignoring begin and end...",
|
170
|
-
stack
|
171
|
+
stack=False,
|
171
172
|
)
|
172
173
|
begin, end = '', None
|
173
174
|
else:
|
174
175
|
warn(
|
175
176
|
f"A datetime wasn't specified for {pipe}.\n"
|
176
|
-
+ f" Using column \"{
|
177
|
-
stack
|
177
|
+
+ f" Using column \"{dt_col}\" for datetime bounds...",
|
178
|
+
stack=False
|
178
179
|
)
|
179
180
|
|
180
181
|
apply_backtrack = begin == '' and check_existing
|
@@ -200,6 +201,7 @@ def get_pipe_metadef(
|
|
200
201
|
datepart='minute',
|
201
202
|
number=((-1 * btm) if apply_backtrack else 0),
|
202
203
|
begin=begin,
|
204
|
+
db_type=db_dt_typ,
|
203
205
|
)
|
204
206
|
if begin
|
205
207
|
else None
|
@@ -210,11 +212,13 @@ def get_pipe_metadef(
|
|
210
212
|
datepart='minute',
|
211
213
|
number=0,
|
212
214
|
begin=end,
|
215
|
+
db_type=db_dt_typ,
|
213
216
|
)
|
214
217
|
if end
|
215
218
|
else None
|
216
219
|
)
|
217
220
|
|
221
|
+
definition_name = sql_item_name('definition', self.flavor, None)
|
218
222
|
meta_def = (
|
219
223
|
_simple_fetch_query(pipe, self.flavor) if (
|
220
224
|
(not (pipe.columns or {}).get('id', None))
|
@@ -225,26 +229,26 @@ def get_pipe_metadef(
|
|
225
229
|
has_where = 'where' in meta_def.lower()[meta_def.lower().rfind('definition'):]
|
226
230
|
if dt_name and (begin_da or end_da):
|
227
231
|
definition_dt_name = (
|
228
|
-
dateadd_str(self.flavor, 'minute', 0, f"
|
232
|
+
dateadd_str(self.flavor, 'minute', 0, f"{definition_name}.{dt_name}", db_type=db_dt_typ)
|
229
233
|
if not is_int((begin_da or end_da))
|
230
|
-
else f"
|
234
|
+
else f"{definition_name}.{dt_name}"
|
231
235
|
)
|
232
236
|
meta_def += "\n" + ("AND" if has_where else "WHERE") + " "
|
233
237
|
has_where = True
|
234
238
|
if begin_da:
|
235
|
-
meta_def += f"{definition_dt_name}
|
239
|
+
meta_def += f"\n {definition_dt_name}\n >=\n {begin_da}\n"
|
236
240
|
if begin_da and end_da:
|
237
|
-
meta_def += "
|
241
|
+
meta_def += " AND"
|
238
242
|
if end_da:
|
239
|
-
meta_def += f"{definition_dt_name}
|
243
|
+
meta_def += f"\n {definition_dt_name}\n <\n {end_da}\n"
|
240
244
|
|
241
245
|
if params is not None:
|
242
246
|
params_where = build_where(params, self, with_where=False)
|
243
|
-
meta_def += "\n" + ("AND" if has_where else "WHERE") + "
|
247
|
+
meta_def += "\n " + ("AND" if has_where else "WHERE") + " "
|
244
248
|
has_where = True
|
245
249
|
meta_def += params_where
|
246
250
|
|
247
|
-
return meta_def
|
251
|
+
return meta_def.rstrip()
|
248
252
|
|
249
253
|
|
250
254
|
def get_pipe_query(pipe: mrsm.Pipe, warn: bool = True) -> Union[str, None]:
|
@@ -256,7 +260,11 @@ def get_pipe_query(pipe: mrsm.Pipe, warn: bool = True) -> Union[str, None]:
|
|
256
260
|
- query
|
257
261
|
- sql
|
258
262
|
"""
|
263
|
+
import re
|
264
|
+
import textwrap
|
259
265
|
from meerschaum.utils.warnings import warn as _warn
|
266
|
+
from meerschaum.utils.misc import parse_arguments_str
|
267
|
+
from meerschaum.utils.sql import sql_item_name
|
260
268
|
if pipe.parameters.get('fetch', {}).get('definition', None):
|
261
269
|
definition = pipe.parameters['fetch']['definition']
|
262
270
|
elif pipe.parameters.get('definition', None):
|
@@ -272,7 +280,23 @@ def get_pipe_query(pipe: mrsm.Pipe, warn: bool = True) -> Union[str, None]:
|
|
272
280
|
+ " Set the key `query` in `pipe.parameters` to a valid SQL query."
|
273
281
|
)
|
274
282
|
return None
|
275
|
-
|
283
|
+
|
284
|
+
def replace_pipe_match(pipe_match):
|
285
|
+
try:
|
286
|
+
args_str = pipe_match.group(1)
|
287
|
+
args, kwargs = parse_arguments_str(args_str)
|
288
|
+
pipe = mrsm.Pipe(*args, **kwargs)
|
289
|
+
except Exception as e:
|
290
|
+
if warn:
|
291
|
+
_warn(f"Failed to parse pipe from SQL definition:\n{e}")
|
292
|
+
raise e
|
293
|
+
|
294
|
+
target = pipe.target
|
295
|
+
schema = pipe.instance_connector.get_pipe_schema(pipe)
|
296
|
+
return sql_item_name(target, pipe.instance_connector.flavor, schema)
|
297
|
+
|
298
|
+
definition = re.sub(r'\{\{Pipe\((.*?)\)\}\}', replace_pipe_match, definition)
|
299
|
+
return textwrap.dedent(definition.lstrip().rstrip())
|
276
300
|
|
277
301
|
|
278
302
|
def set_pipe_query(pipe: mrsm.Pipe, query: str) -> None:
|
@@ -331,11 +355,7 @@ def _join_fetch_query(
|
|
331
355
|
pipe_instance_name = sql_item_name(
|
332
356
|
pipe.target, pipe.instance_connector.flavor, pipe.instance_connector.schema
|
333
357
|
)
|
334
|
-
# pipe_remote_name = sql_item_name(pipe.target, pipe.connector.flavor)
|
335
358
|
sync_times_table = pipe.target + "_sync_times"
|
336
|
-
sync_times_instance_name = sql_item_name(
|
337
|
-
sync_times_table, pipe.instance_connector.flavor, None
|
338
|
-
)
|
339
359
|
sync_times_remote_name = sql_item_name(
|
340
360
|
sync_times_table, pipe.connector.flavor, None
|
341
361
|
)
|
@@ -393,4 +413,3 @@ def _join_fetch_query(
|
|
393
413
|
WHERE definition.{dt_remote_name} > st.{dt_remote_name}
|
394
414
|
""" + (f" OR st.{id_remote_name} IS NULL" if new_ids else "")
|
395
415
|
return query
|
396
|
-
|
@@ -96,15 +96,15 @@ def _drop_temporary_tables(self, debug: bool = False) -> SuccessTuple:
|
|
96
96
|
sqlalchemy.select(temp_tables_table.c.table)
|
97
97
|
.where(temp_tables_table.c.ready_to_drop.is_not(None))
|
98
98
|
)
|
99
|
-
tables_to_drop =
|
99
|
+
tables_to_drop = {
|
100
100
|
table
|
101
101
|
for table, ready_to_drop in _in_memory_temp_tables.items()
|
102
102
|
if ready_to_drop
|
103
|
-
|
103
|
+
}
|
104
104
|
if not tables_to_drop:
|
105
105
|
df = self.read(query, silent=True, debug=debug)
|
106
106
|
tables_to_drop = (
|
107
|
-
|
107
|
+
set(df['table'])
|
108
108
|
if df is not None
|
109
109
|
else []
|
110
110
|
)
|
@@ -126,7 +126,7 @@ def _drop_temporary_tables(self, debug: bool = False) -> SuccessTuple:
|
|
126
126
|
sqlalchemy.delete(temp_tables_table)
|
127
127
|
.where(temp_tables_table.c.table.in_(dropped_tables))
|
128
128
|
)
|
129
|
-
|
129
|
+
_ = self.exec(delete_query, silent=True, debug=debug)
|
130
130
|
|
131
131
|
success = len(failed_tables) == 0
|
132
132
|
msg = (
|