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.
Files changed (276) hide show
  1. {meerschaum-2.7.1/meerschaum.egg-info → meerschaum-2.7.3}/PKG-INFO +1 -1
  2. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/_parse_arguments.py +2 -0
  3. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/_parser.py +17 -11
  4. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/clear.py +1 -1
  5. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/edit.py +1 -1
  6. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/verify.py +18 -21
  7. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/__init__.py +0 -1
  8. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/dashboard.py +2 -11
  9. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/connectors.py +7 -9
  10. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/termpage.html +3 -3
  11. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_version.py +1 -1
  12. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_fetch.py +45 -26
  13. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_instance.py +4 -4
  14. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_pipes.py +135 -103
  15. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_attributes.py +1 -1
  16. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_dtypes.py +9 -9
  17. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_fetch.py +2 -3
  18. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_sync.py +11 -3
  19. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_verify.py +9 -5
  20. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/__init__.py +1 -1
  21. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dataframe.py +10 -2
  22. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dtypes/sql.py +1 -1
  23. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/__init__.py +5 -25
  24. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_pipes.py +9 -6
  25. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/sql.py +156 -87
  26. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/venv/__init__.py +44 -6
  27. {meerschaum-2.7.1 → meerschaum-2.7.3/meerschaum.egg-info}/PKG-INFO +1 -1
  28. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_pipes_dtypes.py +69 -8
  29. {meerschaum-2.7.1 → meerschaum-2.7.3}/LICENSE +0 -0
  30. {meerschaum-2.7.1 → meerschaum-2.7.3}/NOTICE +0 -0
  31. {meerschaum-2.7.1 → meerschaum-2.7.3}/README.md +0 -0
  32. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/__init__.py +0 -0
  33. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/__main__.py +0 -0
  34. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/__init__.py +0 -0
  35. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/arguments/__init__.py +0 -0
  36. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/docs/__init__.py +0 -0
  37. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/docs/index.py +0 -0
  38. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/entry.py +0 -0
  39. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/__init__.py +0 -0
  40. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/__init__.py +0 -0
  41. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/_windows.py +0 -0
  42. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/actions.py +0 -0
  43. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/gui/app/pipes.py +0 -0
  44. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/Shell.py +0 -0
  45. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/ShellCompleter.py +0 -0
  46. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/ValidAutoSuggest.py +0 -0
  47. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/__init__.py +0 -0
  48. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/resources/__init__.py +0 -0
  49. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/shell/updates.py +0 -0
  50. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/TermPageHandler.py +0 -0
  51. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/__init__.py +0 -0
  52. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/_internal/term/tools.py +0 -0
  53. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/__init__.py +0 -0
  54. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/api.py +0 -0
  55. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/attach.py +0 -0
  56. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/bootstrap.py +0 -0
  57. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/copy.py +0 -0
  58. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/deduplicate.py +0 -0
  59. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/delete.py +0 -0
  60. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/drop.py +0 -0
  61. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/install.py +0 -0
  62. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/login.py +0 -0
  63. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/os.py +0 -0
  64. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/pause.py +0 -0
  65. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/python.py +0 -0
  66. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/register.py +0 -0
  67. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/reload.py +0 -0
  68. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/restart.py +0 -0
  69. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/setup.py +0 -0
  70. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sh.py +0 -0
  71. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/show.py +0 -0
  72. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sql.py +0 -0
  73. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/stack.py +0 -0
  74. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/start.py +0 -0
  75. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/stop.py +0 -0
  76. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/sync.py +0 -0
  77. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/tag.py +0 -0
  78. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/uninstall.py +0 -0
  79. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/actions/upgrade.py +0 -0
  80. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/__init__.py +0 -0
  81. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_chain.py +0 -0
  82. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_events.py +0 -0
  83. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_oauth2.py +0 -0
  84. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/_websockets.py +0 -0
  85. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/__init__.py +0 -0
  86. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/ansi_up.js +0 -0
  87. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/banner_1920x320.png +0 -0
  88. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/favicon.ico +0 -0
  89. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/logo_48x48.png +0 -0
  90. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/assets/logo_500x500.png +0 -0
  91. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/__init__.py +0 -0
  92. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/custom.py +0 -0
  93. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/jobs.py +0 -0
  94. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/login.py +0 -0
  95. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/pipes.py +0 -0
  96. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/plugins.py +0 -0
  97. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/callbacks/register.py +0 -0
  98. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/components.py +0 -0
  99. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/graphs.py +0 -0
  100. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/jobs.py +0 -0
  101. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/keys.py +0 -0
  102. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/__init__.py +0 -0
  103. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/dashboard.py +0 -0
  104. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/error.py +0 -0
  105. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/job.py +0 -0
  106. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/login.py +0 -0
  107. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/pipes.py +0 -0
  108. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/plugins.py +0 -0
  109. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pages/register.py +0 -0
  110. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/pipes.py +0 -0
  111. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/plugins.py +0 -0
  112. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/sessions.py +0 -0
  113. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/sync.py +0 -0
  114. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/users.py +0 -0
  115. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/websockets.py +0 -0
  116. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/dash/webterm.py +0 -0
  117. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/__init__.py +0 -0
  118. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_interfaces.py +0 -0
  119. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_locations.py +0 -0
  120. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_metrics.py +0 -0
  121. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/models/_pipes.py +0 -0
  122. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/__init__.py +0 -0
  123. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/__init__.py +0 -0
  124. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/__init__.py +0 -0
  125. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/bootstrap.min.css +0 -0
  126. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/dash.css +0 -0
  127. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/dbc_dark.css +0 -0
  128. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/styles.css +0 -0
  129. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/css/xterm.css +0 -0
  130. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/ico/__init__.py +0 -0
  131. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/ico/logo.ico +0 -0
  132. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/__init__.py +0 -0
  133. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/action_button.js +0 -0
  134. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/main.js +0 -0
  135. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/terminado.js +0 -0
  136. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/js/xterm.js +0 -0
  137. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/static/png/__init__.py +0 -0
  138. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/__init__.py +0 -0
  139. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/index.html +0 -0
  140. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/old_index.html +0 -0
  141. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/resources/templates/secret.html +0 -0
  142. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/__init__.py +0 -0
  143. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_actions.py +0 -0
  144. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_connectors.py +0 -0
  145. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_index.py +0 -0
  146. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_jobs.py +0 -0
  147. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_login.py +0 -0
  148. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_misc.py +0 -0
  149. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_pipes.py +0 -0
  150. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_plugins.py +0 -0
  151. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_users.py +0 -0
  152. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_version.py +0 -0
  153. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/routes/_webterm.py +0 -0
  154. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/api/tables/__init__.py +0 -0
  155. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/__init__.py +0 -0
  156. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_dash.py +0 -0
  157. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_default.py +0 -0
  158. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_edit.py +0 -0
  159. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_environment.py +0 -0
  160. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_formatting.py +0 -0
  161. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_jobs.py +0 -0
  162. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_patch.py +0 -0
  163. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_paths.py +0 -0
  164. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_preprocess.py +0 -0
  165. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_read_config.py +0 -0
  166. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_shell.py +0 -0
  167. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/_sync.py +0 -0
  168. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/paths.py +0 -0
  169. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/resources/__init__.py +0 -0
  170. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/__init__.py +0 -0
  171. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/grafana/__init__.py +0 -0
  172. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/mosquitto/__init__.py +0 -0
  173. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/mosquitto/resources/__init__.py +0 -0
  174. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/stack/resources/__init__.py +0 -0
  175. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/config/static/__init__.py +0 -0
  176. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/_Connector.py +0 -0
  177. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/__init__.py +0 -0
  178. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_APIConnector.py +0 -0
  179. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/__init__.py +0 -0
  180. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_actions.py +0 -0
  181. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_fetch.py +0 -0
  182. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_jobs.py +0 -0
  183. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_login.py +0 -0
  184. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_misc.py +0 -0
  185. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_pipes.py +0 -0
  186. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_plugins.py +0 -0
  187. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_request.py +0 -0
  188. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_uri.py +0 -0
  189. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/api/_users.py +0 -0
  190. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/parse.py +0 -0
  191. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/plugin/PluginConnector.py +0 -0
  192. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/plugin/__init__.py +0 -0
  193. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/poll.py +0 -0
  194. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_SQLConnector.py +0 -0
  195. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/__init__.py +0 -0
  196. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_cli.py +0 -0
  197. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_create_engine.py +0 -0
  198. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_plugins.py +0 -0
  199. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_sql.py +0 -0
  200. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_uri.py +0 -0
  201. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/_users.py +0 -0
  202. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tables/__init__.py +0 -0
  203. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tables/types.py +0 -0
  204. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/sql/tools.py +0 -0
  205. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_ValkeyConnector.py +0 -0
  206. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/__init__.py +0 -0
  207. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_fetch.py +0 -0
  208. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_pipes.py +0 -0
  209. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_plugins.py +0 -0
  210. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/connectors/valkey/_users.py +0 -0
  211. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/__init__.py +0 -0
  212. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_bootstrap.py +0 -0
  213. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_clear.py +0 -0
  214. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_copy.py +0 -0
  215. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_data.py +0 -0
  216. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_deduplicate.py +0 -0
  217. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_delete.py +0 -0
  218. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_drop.py +0 -0
  219. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_edit.py +0 -0
  220. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_register.py +0 -0
  221. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Pipe/_show.py +0 -0
  222. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/Plugin/__init__.py +0 -0
  223. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/User/_User.py +0 -0
  224. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/User/__init__.py +0 -0
  225. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/core/__init__.py +0 -0
  226. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/_Executor.py +0 -0
  227. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/_Job.py +0 -0
  228. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/jobs/systemd.py +0 -0
  229. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/_Plugin.py +0 -0
  230. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/__init__.py +0 -0
  231. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/plugins/bootstrap.py +0 -0
  232. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/__init__.py +0 -0
  233. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/_get_pipes.py +0 -0
  234. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/Daemon.py +0 -0
  235. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/FileDescriptorInterceptor.py +0 -0
  236. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/RotatingFile.py +0 -0
  237. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/StdinFile.py +0 -0
  238. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/__init__.py +0 -0
  239. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/daemon/_names.py +0 -0
  240. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/debug.py +0 -0
  241. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/dtypes/__init__.py +0 -0
  242. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_jobs.py +0 -0
  243. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_pprint.py +0 -0
  244. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/formatting/_shell.py +0 -0
  245. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/interactive.py +0 -0
  246. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/misc.py +0 -0
  247. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/networking.py +0 -0
  248. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/__init__.py +0 -0
  249. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/_packages.py +0 -0
  250. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/packages/lazy_loader.py +0 -0
  251. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/pool.py +0 -0
  252. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/process.py +0 -0
  253. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/prompt.py +0 -0
  254. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/schedule.py +0 -0
  255. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/threading.py +0 -0
  256. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/typing.py +0 -0
  257. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/venv/_Venv.py +0 -0
  258. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/warnings.py +0 -0
  259. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum/utils/yaml.py +0 -0
  260. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/SOURCES.txt +0 -0
  261. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/dependency_links.txt +0 -0
  262. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/entry_points.txt +0 -0
  263. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/requires.txt +0 -0
  264. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/top_level.txt +0 -0
  265. {meerschaum-2.7.1 → meerschaum-2.7.3}/meerschaum.egg-info/zip-safe +0 -0
  266. {meerschaum-2.7.1 → meerschaum-2.7.3}/setup.cfg +0 -0
  267. {meerschaum-2.7.1 → meerschaum-2.7.3}/setup.py +0 -0
  268. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_actions.py +0 -0
  269. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_arguments.py +0 -0
  270. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_deduplicate.py +0 -0
  271. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_jobs.py +0 -0
  272. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_pipe_data.py +0 -0
  273. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_sql.py +0 -0
  274. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_sync.py +0 -0
  275. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_users.py +0 -0
  276. {meerschaum-2.7.1 → meerschaum-2.7.3}/tests/test_verify.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: meerschaum
3
- Version: 2.7.1
3
+ Version: 2.7.3
4
4
  Summary: Sync Time-Series Pipes with Meerschaum
5
5
  Home-page: https://meerschaum.io
6
6
  Author: Bennett Meares
@@ -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 as e:
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 importlib, inspect, textwrap
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 as e:
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 as e:
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 10,000."
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
- + "the existing oldest and newest datetime bounds."
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 drastically improves performance when all rows to be synced are unique. " +
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
  )
@@ -498,7 +498,7 @@ def _edit_jobs(
498
498
  num_edited += 1
499
499
 
500
500
  msg = (
501
- "Successfully edit job"
501
+ "Successfully edited job"
502
502
  + ('s' if len(jobs) != 1 else '')
503
503
  + ' '
504
504
  + items_str(list(jobs.keys()))
@@ -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
- action: Optional[List[str]] = None,
14
- **kwargs: Any
15
- ) -> SuccessTuple:
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
- debug: bool = False,
40
- venv: Optional[str] = 'mrsm',
41
- **kw
42
- ) -> SuccessTuple:
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, need_update, all_packages, is_installed, venv_contains_package,
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
- action: Optional[List[str]],
84
- debug: bool = False,
85
- **kw
86
- ) -> SuccessTuple:
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
- action: Optional[List[str]] = None,
98
- **kwargs: Any
99
- ) -> SuccessTuple:
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, UNICODE, print_tuple
104
- from meerschaum.plugins import import_plugins, get_plugins_names, Plugin
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
- f"Failed to import plugin"
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
  )
@@ -60,7 +60,6 @@ dash_app = enrich.DashProxy(
60
60
  dash_app.layout = html.Div([
61
61
  location,
62
62
  dcc.Store(id='session-store', storage_type='local', data={}),
63
- dcc.Store(id='instance-store', storage_type='session', data={}),
64
63
  html.Div([], id='page-layout-div'),
65
64
  ])
66
65
 
@@ -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
- State('instance-store', 'data'),
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
- instance_store_data: Optional[Dict[str, Any]],
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
- from meerschaum.utils.typing import WebState, Union, Optional
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 : WebState) -> Union[
16
- meerschaum.connectors.api.APIConnector,
17
- meerschaum.connectors.sql.SQLConnector,
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 (connector_keys.length === 0){
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 (metric_keys.length === 0){
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 (location_keys.length === 0){
60
+ if (location_keys_str === " -l"){
61
61
  location_keys_str = "";
62
62
  }
63
63
 
@@ -2,4 +2,4 @@
2
2
  Specify the Meerschaum release version.
3
3
  """
4
4
 
5
- __version__ = "2.7.1"
5
+ __version__ = "2.7.3"
@@ -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.debug import dprint
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
- definition = get_pipe_query(pipe)
154
-
155
- if not pipe.columns.get('datetime', None):
156
- _dt = pipe.guess_datetime()
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
- _dt = pipe.get_columns('datetime')
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 _dt is None:
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 = False,
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 \"{_dt}\" for datetime bounds...",
177
- stack = False
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"definition.{dt_name}")
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"definition.{dt_name}"
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} >= {begin_da}"
239
+ meta_def += f"\n {definition_dt_name}\n >=\n {begin_da}\n"
236
240
  if begin_da and end_da:
237
- meta_def += " AND "
241
+ meta_def += " AND"
238
242
  if end_da:
239
- meta_def += f"{definition_dt_name} < {end_da}"
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
- return definition
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
- list(df['table'])
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
- delete_result = self.exec(delete_query, silent=True, debug=debug)
129
+ _ = self.exec(delete_query, silent=True, debug=debug)
130
130
 
131
131
  success = len(failed_tables) == 0
132
132
  msg = (