spinta 0.2.dev24__tar.gz → 0.2.dev25__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (759) hide show
  1. {spinta-0.2.dev24 → spinta-0.2.dev25}/PKG-INFO +1 -1
  2. {spinta-0.2.dev24 → spinta-0.2.dev25}/pyproject.toml +1 -1
  3. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/components.py +8 -1
  4. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/constants.py +10 -0
  5. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/helpers.py +26 -19
  6. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/wipe.py +1 -1
  7. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/components.py +7 -1
  8. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/migrate/actions.py +82 -3
  9. spinta-0.2.dev25/spinta/backends/postgresql/helpers/migrate/citus.py +383 -0
  10. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/admin.py +2 -0
  11. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/components.py +3 -0
  12. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/registry.py +14 -0
  13. spinta-0.2.dev25/spinta/cli/helpers/admin/scripts/add_local_ids.py +80 -0
  14. spinta-0.2.dev25/spinta/cli/helpers/admin/scripts/citus_shard.py +126 -0
  15. spinta-0.2.dev25/spinta/cli/helpers/admin/scripts/remove_local_ids.py +55 -0
  16. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/backends/postgresql/comments.py +62 -26
  17. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/inspect.py +3 -0
  18. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/components.py +5 -1
  19. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/config.py +3 -0
  20. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/config.yml +12 -1
  21. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/scope/components.py +20 -2
  22. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/scope/helpers.py +18 -1
  23. spinta-0.2.dev25/spinta/dimensions/scope/ufuncs.py +51 -0
  24. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/link.py +2 -0
  25. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/helpers.py +1 -1
  26. spinta-0.2.dev25/spinta/testing/citus.py +96 -0
  27. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/cli.py +13 -0
  28. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/pytest.py +35 -22
  29. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/config.py +13 -1
  30. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/model.py +47 -2
  31. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/enums.py +17 -8
  32. {spinta-0.2.dev24 → spinta-0.2.dev25}/LICENSE +0 -0
  33. {spinta-0.2.dev24 → spinta-0.2.dev25}/README.rst +0 -0
  34. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/__init__.py +0 -0
  35. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/__main__.py +0 -0
  36. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/accesslog/__init__.py +0 -0
  37. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/accesslog/file.py +0 -0
  38. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/accesslog/python.py +0 -0
  39. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/adapters/__init__.py +0 -0
  40. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/adapters/rc/__init__.py +0 -0
  41. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/adapters/rc/signature_adapter.py +0 -0
  42. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/adapters/soap_plugins.py +0 -0
  43. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/api/__init__.py +0 -0
  44. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/api/inspect.py +0 -0
  45. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/api/schema.py +0 -0
  46. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/api/validators.py +0 -0
  47. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/asgi.py +0 -0
  48. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/auth.py +0 -0
  49. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/__init__.py +0 -0
  50. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/__init__.py +0 -0
  51. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/__init__.py +0 -0
  52. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/bootstrap.py +0 -0
  53. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/changes.py +0 -0
  54. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/decode.py +0 -0
  55. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/encode.py +0 -0
  56. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/init.py +0 -0
  57. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/load.py +0 -0
  58. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/migrate.py +0 -0
  59. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/read.py +0 -0
  60. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/validate.py +0 -0
  61. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/wait.py +0 -0
  62. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/wipe.py +0 -0
  63. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/commands/write.py +0 -0
  64. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/fs/components.py +0 -0
  65. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/__init__.py +0 -0
  66. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/__init__.py +0 -0
  67. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/auth.py +0 -0
  68. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/bootstrap.py +0 -0
  69. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/changes.py +0 -0
  70. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/check.py +0 -0
  71. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/encode.py +0 -0
  72. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/init.py +0 -0
  73. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/load.py +0 -0
  74. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/manifest.py +0 -0
  75. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/read.py +0 -0
  76. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/wait.py +0 -0
  77. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/wipe.py +0 -0
  78. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/commands/write.py +0 -0
  79. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/memory/components.py +0 -0
  80. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/__init__.py +0 -0
  81. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/__init__.py +0 -0
  82. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/bootstrap.py +0 -0
  83. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/changes.py +0 -0
  84. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/encode.py +0 -0
  85. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/init.py +0 -0
  86. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/load.py +0 -0
  87. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/migrate.py +0 -0
  88. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/read.py +0 -0
  89. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/validate.py +0 -0
  90. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/wait.py +0 -0
  91. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/wipe.py +0 -0
  92. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/commands/write.py +0 -0
  93. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/components.py +0 -0
  94. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/helpers.py +0 -0
  95. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/__init__.py +0 -0
  96. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/array/__init__.py +0 -0
  97. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/array/write.py +0 -0
  98. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/file/__init__.py +0 -0
  99. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/file/write.py +0 -0
  100. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/object/__init__.py +0 -0
  101. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/types/object/write.py +0 -0
  102. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/ufuncs/__init__.py +0 -0
  103. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/ufuncs/components.py +0 -0
  104. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/mongo/ufuncs/ufuncs.py +0 -0
  105. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/__init__.py +0 -0
  106. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/__init__.py +0 -0
  107. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/bootstrap.py +0 -0
  108. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/changes.py +0 -0
  109. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/init.py +0 -0
  110. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/load.py +0 -0
  111. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/read.py +0 -0
  112. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/wait.py +0 -0
  113. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/wipe.py +0 -0
  114. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/commands/write.py +0 -0
  115. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/nobackend/components.py +0 -0
  116. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/__init__.py +0 -0
  117. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/__init__.py +0 -0
  118. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/bootstrap.py +0 -0
  119. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/changes.py +0 -0
  120. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/column.py +0 -0
  121. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/encode.py +0 -0
  122. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/init.py +0 -0
  123. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/link.py +0 -0
  124. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/load.py +0 -0
  125. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/manifest.py +0 -0
  126. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/__init__.py +0 -0
  127. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/constants.py +0 -0
  128. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/migrate.py +0 -0
  129. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/model.py +0 -0
  130. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/property.py +0 -0
  131. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/__init__.py +0 -0
  132. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/array.py +0 -0
  133. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/datatype.py +0 -0
  134. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/file.py +0 -0
  135. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/geometry.py +0 -0
  136. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/object.py +0 -0
  137. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/ref.py +0 -0
  138. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/string.py +0 -0
  139. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/migrate/types/text.py +0 -0
  140. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/read.py +0 -0
  141. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/redirect.py +0 -0
  142. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/summary.py +0 -0
  143. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/validate.py +0 -0
  144. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/wait.py +0 -0
  145. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/commands/write.py +0 -0
  146. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/constants.py +0 -0
  147. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/files.py +0 -0
  148. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/__init__.py +0 -0
  149. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/changes.py +0 -0
  150. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/exceptions.py +0 -0
  151. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/extractors.py +0 -0
  152. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/manifest.py +0 -0
  153. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/migrate/__init__.py +0 -0
  154. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/migrate/cast.py +0 -0
  155. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/migrate/migrate.py +0 -0
  156. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/migrate/name.py +0 -0
  157. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/name.py +0 -0
  158. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/redirect.py +0 -0
  159. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/type.py +0 -0
  160. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/helpers/validate.py +0 -0
  161. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/sqlalchemy.py +0 -0
  162. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/__init__.py +0 -0
  163. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array/__init__.py +0 -0
  164. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array/init.py +0 -0
  165. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array/wipe.py +0 -0
  166. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array/write.py +0 -0
  167. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array_backref/__init__.py +0 -0
  168. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/array_backref/init.py +0 -0
  169. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/backref/__init__.py +0 -0
  170. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/backref/init.py +0 -0
  171. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/denorm/__init__.py +0 -0
  172. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/denorm/init.py +0 -0
  173. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/external_ref/__init__.py +0 -0
  174. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/external_ref/init.py +0 -0
  175. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/file/__init__.py +0 -0
  176. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/file/init.py +0 -0
  177. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/file/read.py +0 -0
  178. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/file/write.py +0 -0
  179. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/geometry/__init__.py +0 -0
  180. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/geometry/encode.py +0 -0
  181. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/geometry/init.py +0 -0
  182. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/geometry/write.py +0 -0
  183. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/object/__init__.py +0 -0
  184. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/object/init.py +0 -0
  185. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/object/read.py +0 -0
  186. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/object/wipe.py +0 -0
  187. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/ref/__init__.py +0 -0
  188. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/ref/init.py +0 -0
  189. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/ref/validate.py +0 -0
  190. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/text/__init__.py +0 -0
  191. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/types/text/init.py +0 -0
  192. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/__init__.py +0 -0
  193. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/components.py +0 -0
  194. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/query/__init__.py +0 -0
  195. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/query/components.py +0 -0
  196. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/query/ufuncs.py +0 -0
  197. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/result/__init__.py +0 -0
  198. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/result/components.py +0 -0
  199. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/result/ufuncs.py +0 -0
  200. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/postgresql/ufuncs/ufuncs.py +0 -0
  201. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/backends/types/__init__.py +0 -0
  202. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/__init__.py +0 -0
  203. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/auth.py +0 -0
  204. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/comment.py +0 -0
  205. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/config.py +0 -0
  206. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/data.py +0 -0
  207. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/get.py +0 -0
  208. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/__init__.py +0 -0
  209. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/__init__.py +0 -0
  210. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/scripts/__init__.py +0 -0
  211. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/scripts/changelog.py +0 -0
  212. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/scripts/deduplicate.py +0 -0
  213. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/admin/scripts/enums.py +0 -0
  214. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/auth.py +0 -0
  215. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/data.py +0 -0
  216. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/enums.py +0 -0
  217. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/errors.py +0 -0
  218. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/__init__.py +0 -0
  219. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/backends/__init__.py +0 -0
  220. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/backends/postgresql/__init__.py +0 -0
  221. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/backends/postgresql/commands.py +0 -0
  222. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/backends/postgresql/components.py +0 -0
  223. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/backends/postgresql/helpers.py +0 -0
  224. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/commands.py +0 -0
  225. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/components.py +0 -0
  226. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/export/helpers.py +0 -0
  227. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/manifest.py +0 -0
  228. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/message.py +0 -0
  229. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/migrate.py +0 -0
  230. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/__init__.py +0 -0
  231. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/components.py +0 -0
  232. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/delete.py +0 -0
  233. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/error.py +0 -0
  234. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/read.py +0 -0
  235. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/state.py +0 -0
  236. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/sync.py +0 -0
  237. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/utils.py +0 -0
  238. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/push/write.py +0 -0
  239. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/script/__init__.py +0 -0
  240. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/script/components.py +0 -0
  241. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/script/core.py +0 -0
  242. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/script/helpers.py +0 -0
  243. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/script/registry.py +0 -0
  244. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/store.py +0 -0
  245. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/__init__.py +0 -0
  246. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/api_helpers.py +0 -0
  247. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/__init__.py +0 -0
  248. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/data_service.py +0 -0
  249. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/dataset.py +0 -0
  250. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/distribution.py +0 -0
  251. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/dsa.py +0 -0
  252. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/synchronization/__init__.py +0 -0
  253. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/synchronization/connection.py +0 -0
  254. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/controllers/synchronization/manifest_catalog_to_agent.py +0 -0
  255. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/enum.py +0 -0
  256. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/sync/helpers.py +0 -0
  257. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/typer.py +0 -0
  258. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/__init__.py +0 -0
  259. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/components.py +0 -0
  260. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/registry.py +0 -0
  261. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/__init__.py +0 -0
  262. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/backends/__init__.py +0 -0
  263. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/backends/postgresql/__init__.py +0 -0
  264. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/backends/postgresql/schemas.py +0 -0
  265. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/clients.py +0 -0
  266. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/__init__.py +0 -0
  267. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/sqlalchemy/__init__.py +0 -0
  268. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/sqlalchemy/helpers.py +0 -0
  269. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/sqlalchemy/initial_setup.py +0 -0
  270. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/sqlalchemy/modified_time.py +0 -0
  271. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/keymaps/sqlalchemy/redirect_support.py +0 -0
  272. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/helpers/upgrade/scripts/redirect.py +0 -0
  273. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/init.py +0 -0
  274. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/keymap.py +0 -0
  275. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/main.py +0 -0
  276. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/manifest.py +0 -0
  277. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/migrate.py +0 -0
  278. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/pii.py +0 -0
  279. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/pull.py +0 -0
  280. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/push.py +0 -0
  281. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/server.py +0 -0
  282. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/show.py +0 -0
  283. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/sync.py +0 -0
  284. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/uncomment.py +0 -0
  285. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/cli/upgrade.py +0 -0
  286. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/client.py +0 -0
  287. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/__init__.py +0 -0
  288. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/auth.py +0 -0
  289. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/helpers.py +0 -0
  290. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/read.py +0 -0
  291. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/search.py +0 -0
  292. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/version.py +0 -0
  293. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/commands/write.py +0 -0
  294. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/compat.py +0 -0
  295. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/__init__.py +0 -0
  296. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/access.py +0 -0
  297. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/config.py +0 -0
  298. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/context.py +0 -0
  299. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/enums.py +0 -0
  300. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/core/ufuncs.py +0 -0
  301. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/__init__.py +0 -0
  302. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/__init__.py +0 -0
  303. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/__init__.py +0 -0
  304. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/__init__.py +0 -0
  305. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/csv/__init__.py +0 -0
  306. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/csv/commands/__init__.py +0 -0
  307. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/csv/commands/read.py +0 -0
  308. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/csv/components.py +0 -0
  309. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/json/__init__.py +0 -0
  310. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/json/commands/__init__.py +0 -0
  311. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/json/commands/read.py +0 -0
  312. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/json/components.py +0 -0
  313. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/memory/__init__.py +0 -0
  314. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/memory/components.py +0 -0
  315. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/__init__.py +0 -0
  316. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/commands/__init__.py +0 -0
  317. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/commands/read.py +0 -0
  318. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/components.py +0 -0
  319. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/ufuncs/__init__.py +0 -0
  320. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/ufuncs/components.py +0 -0
  321. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/soap/ufuncs/ufuncs.py +0 -0
  322. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/xml/__init__.py +0 -0
  323. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/xml/commands/__init__.py +0 -0
  324. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/xml/commands/read.py +0 -0
  325. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/backends/xml/components.py +0 -0
  326. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/commands/__init__.py +0 -0
  327. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/commands/check.py +0 -0
  328. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/commands/read.py +0 -0
  329. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/components.py +0 -0
  330. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/__init__.py +0 -0
  331. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/components.py +0 -0
  332. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/query/__init__.py +0 -0
  333. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/query/components.py +0 -0
  334. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/query/ufuncs.py +0 -0
  335. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/dataframe/ufuncs/ufuncs.py +0 -0
  336. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/helpers.py +0 -0
  337. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/notimpl/__init__.py +0 -0
  338. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/notimpl/commands/__init__.py +0 -0
  339. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/notimpl/commands/load.py +0 -0
  340. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/notimpl/commands/wait.py +0 -0
  341. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/notimpl/components.py +0 -0
  342. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/__init__.py +0 -0
  343. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/__init__.py +0 -0
  344. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/helpers.py +0 -0
  345. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/__init__.py +0 -0
  346. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/components.py +0 -0
  347. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/helpers.py +0 -0
  348. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/ufuncs/__init__.py +0 -0
  349. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/ufuncs/query/__init__.py +0 -0
  350. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/ufuncs/query/components.py +0 -0
  351. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mariadb/ufuncs/query/ufuncs.py +0 -0
  352. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/__init__.py +0 -0
  353. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/components.py +0 -0
  354. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/helpers.py +0 -0
  355. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/ufuncs/__init__.py +0 -0
  356. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/ufuncs/query/__init__.py +0 -0
  357. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/ufuncs/query/components.py +0 -0
  358. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mssql/ufuncs/query/ufuncs.py +0 -0
  359. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/__init__.py +0 -0
  360. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/components.py +0 -0
  361. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/helpers.py +0 -0
  362. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/ufuncs/__init__.py +0 -0
  363. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/ufuncs/query/__init__.py +0 -0
  364. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/ufuncs/query/components.py +0 -0
  365. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/mysql/ufuncs/query/ufuncs.py +0 -0
  366. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/__init__.py +0 -0
  367. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/components.py +0 -0
  368. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/helpers.py +0 -0
  369. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/types/__init__.py +0 -0
  370. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/types/geometry/__init__.py +0 -0
  371. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/types/geometry/encode.py +0 -0
  372. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/ufuncs/__init__.py +0 -0
  373. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/ufuncs/query/__init__.py +0 -0
  374. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/ufuncs/query/components.py +0 -0
  375. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/oracle/ufuncs/query/ufuncs.py +0 -0
  376. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/__init__.py +0 -0
  377. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/components.py +0 -0
  378. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/helpers.py +0 -0
  379. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/ufuncs/__init__.py +0 -0
  380. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/ufuncs/query/__init__.py +0 -0
  381. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/ufuncs/query/components.py +0 -0
  382. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/postgresql/ufuncs/query/ufuncs.py +0 -0
  383. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/__init__.py +0 -0
  384. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/base.py +0 -0
  385. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/commands/__init__.py +0 -0
  386. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/commands/cast.py +0 -0
  387. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/commands/load.py +0 -0
  388. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/commands/read.py +0 -0
  389. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/components.py +0 -0
  390. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/constants.py +0 -0
  391. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/dialect.py +0 -0
  392. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/formats.py +0 -0
  393. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/helpers.py +0 -0
  394. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/identifier.py +0 -0
  395. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/introspection.py +0 -0
  396. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/log4j.properties +0 -0
  397. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/types.py +0 -0
  398. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/ufuncs/__init__.py +0 -0
  399. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/ufuncs/query/__init__.py +0 -0
  400. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/ufuncs/query/components.py +0 -0
  401. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sas/ufuncs/query/ufuncs.py +0 -0
  402. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/__init__.py +0 -0
  403. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/components.py +0 -0
  404. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/helpers.py +0 -0
  405. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/ufuncs/__init__.py +0 -0
  406. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/ufuncs/query/__init__.py +0 -0
  407. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/ufuncs/query/components.py +0 -0
  408. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/backends/sqlite/ufuncs/query/ufuncs.py +0 -0
  409. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/__init__.py +0 -0
  410. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/bootstrap.py +0 -0
  411. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/cast.py +0 -0
  412. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/column.py +0 -0
  413. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/init.py +0 -0
  414. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/load.py +0 -0
  415. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/read.py +0 -0
  416. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/commands/wait.py +0 -0
  417. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/components.py +0 -0
  418. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/helpers.py +0 -0
  419. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/__init__.py +0 -0
  420. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/components.py +0 -0
  421. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/query/__init__.py +0 -0
  422. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/query/components.py +0 -0
  423. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/query/helpers.py +0 -0
  424. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/query/ufuncs.py +0 -0
  425. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/result/__init__.py +0 -0
  426. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/result/components.py +0 -0
  427. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/result/ufuncs.py +0 -0
  428. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sql/ufuncs/ufuncs.py +0 -0
  429. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/__init__.py +0 -0
  430. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/commands/__init__.py +0 -0
  431. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/commands/inspect.py +0 -0
  432. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/commands/load.py +0 -0
  433. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/commands/wait.py +0 -0
  434. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/components.py +0 -0
  435. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/ufuncs/__init__.py +0 -0
  436. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/ufuncs/components.py +0 -0
  437. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/sqldump/ufuncs/ufuncs.py +0 -0
  438. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/wsdl/__init__.py +0 -0
  439. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/wsdl/commads/__init__.py +0 -0
  440. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/wsdl/commads/read.py +0 -0
  441. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/backends/wsdl/components.py +0 -0
  442. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/__init__.py +0 -0
  443. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/check.py +0 -0
  444. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/error.py +0 -0
  445. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/inspect.py +0 -0
  446. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/link.py +0 -0
  447. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/load.py +0 -0
  448. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/commands/wipe.py +0 -0
  449. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/components.py +0 -0
  450. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/enums.py +0 -0
  451. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/helpers.py +0 -0
  452. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/__init__.py +0 -0
  453. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/commands/__init__.py +0 -0
  454. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/commands/manifest.py +0 -0
  455. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/commands/merge.py +0 -0
  456. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/components.py +0 -0
  457. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/inspect/helpers.py +0 -0
  458. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/keymaps/__init__.py +0 -0
  459. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/keymaps/components.py +0 -0
  460. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/keymaps/redis.py +0 -0
  461. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/keymaps/sqlalchemy.py +0 -0
  462. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/keymaps/sync.py +0 -0
  463. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/datasets/utils.py +0 -0
  464. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/__init__.py +0 -0
  465. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/comments/__init__.py +0 -0
  466. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/comments/components.py +0 -0
  467. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/comments/helpers.py +0 -0
  468. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/enum/__init__.py +0 -0
  469. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/enum/commands.py +0 -0
  470. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/enum/components.py +0 -0
  471. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/enum/helpers.py +0 -0
  472. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/enum/ufuncs.py +0 -0
  473. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/lang/__init__.py +0 -0
  474. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/lang/components.py +0 -0
  475. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/lang/helpers.py +0 -0
  476. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/param/__init__.py +0 -0
  477. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/param/components.py +0 -0
  478. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/param/helpers.py +0 -0
  479. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/param/ufuncs.py +0 -0
  480. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/prefix/__init__.py +0 -0
  481. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/prefix/commands/__init__.py +0 -0
  482. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/prefix/commands/load.py +0 -0
  483. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/prefix/components.py +0 -0
  484. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/prefix/helpers.py +0 -0
  485. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dimensions/scope/__init__.py +0 -0
  486. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/dispatcher.py +0 -0
  487. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/exceptions.py +0 -0
  488. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/fetcher.py +0 -0
  489. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/__init__.py +0 -0
  490. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/ascii/__init__.py +0 -0
  491. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/ascii/commands.py +0 -0
  492. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/ascii/components.py +0 -0
  493. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/ascii/helpers.py +0 -0
  494. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/components.py +0 -0
  495. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/csv/__init__.py +0 -0
  496. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/csv/commands.py +0 -0
  497. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/csv/components.py +0 -0
  498. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/helpers.py +0 -0
  499. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/html/__init__.py +0 -0
  500. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/html/commands.py +0 -0
  501. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/html/components.py +0 -0
  502. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/html/helpers.py +0 -0
  503. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/json/__init__.py +0 -0
  504. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/json/commands.py +0 -0
  505. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/json/components.py +0 -0
  506. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/jsonlines/__init__.py +0 -0
  507. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/jsonlines/commands.py +0 -0
  508. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/jsonlines/components.py +0 -0
  509. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/rdf/commands.py +0 -0
  510. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/rdf/components.py +0 -0
  511. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/xlsx/__init__.py +0 -0
  512. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/xlsx/commands.py +0 -0
  513. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/formats/xlsx/components.py +0 -0
  514. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/hacks/__init__.py +0 -0
  515. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/hacks/spyna.py +0 -0
  516. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/hacks/urlparams.py +0 -0
  517. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/handlers.py +0 -0
  518. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/logging_config.py +0 -0
  519. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifest/_ns.yml +0 -0
  520. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifest/_schema/version.yml +0 -0
  521. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifest/_schema.yml +0 -0
  522. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifest/_txn.yml +0 -0
  523. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/__init__.py +0 -0
  524. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/__init__.py +0 -0
  525. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/__init__.py +0 -0
  526. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/bootstrap.py +0 -0
  527. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/configure.py +0 -0
  528. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/load.py +0 -0
  529. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/manifest.py +0 -0
  530. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/migrate.py +0 -0
  531. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/commands/sync.py +0 -0
  532. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/components.py +0 -0
  533. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/backend/helpers.py +0 -0
  534. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/__init__.py +0 -0
  535. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/auth.py +0 -0
  536. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/check.py +0 -0
  537. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/error.py +0 -0
  538. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/init.py +0 -0
  539. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/inspect.py +0 -0
  540. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/load.py +0 -0
  541. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/manifest.py +0 -0
  542. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/migrate.py +0 -0
  543. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/commands/read.py +0 -0
  544. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/components.py +0 -0
  545. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/__init__.py +0 -0
  546. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/commands/__init__.py +0 -0
  547. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/commands/configure.py +0 -0
  548. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/commands/load.py +0 -0
  549. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/components.py +0 -0
  550. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/dict/helpers.py +0 -0
  551. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/helpers.py +0 -0
  552. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal/__init__.py +0 -0
  553. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal/commands/__init__.py +0 -0
  554. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal/commands/configure.py +0 -0
  555. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal/commands/load.py +0 -0
  556. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal/components.py +0 -0
  557. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/__init__.py +0 -0
  558. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/__init__.py +0 -0
  559. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/auth.py +0 -0
  560. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/backend.py +0 -0
  561. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/bootstrap.py +0 -0
  562. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/configure.py +0 -0
  563. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/load.py +0 -0
  564. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/manifest.py +0 -0
  565. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/commands/read.py +0 -0
  566. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/components.py +0 -0
  567. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/internal_sql/helpers.py +0 -0
  568. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/memory/__init__.py +0 -0
  569. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/memory/commands/__init__.py +0 -0
  570. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/memory/commands/configure.py +0 -0
  571. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/memory/commands/load.py +0 -0
  572. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/memory/components.py +0 -0
  573. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/mermaid/__init__.py +0 -0
  574. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/mermaid/components.py +0 -0
  575. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/mermaid/helpers.py +0 -0
  576. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/__init__.py +0 -0
  577. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/commands/__init__.py +0 -0
  578. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/commands/configure.py +0 -0
  579. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/commands/load.py +0 -0
  580. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/components.py +0 -0
  581. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/helpers.py +0 -0
  582. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/openapi_config.py +0 -0
  583. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/open_api/openapi_generator.py +0 -0
  584. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/rdf/commands/bootstrap.py +0 -0
  585. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/rdf/commands/configure.py +0 -0
  586. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/rdf/commands/load.py +0 -0
  587. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/rdf/components.py +0 -0
  588. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/rdf/helpers.py +0 -0
  589. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/__init__.py +0 -0
  590. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/commands/__init__.py +0 -0
  591. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/commands/configure.py +0 -0
  592. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/commands/load.py +0 -0
  593. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/sql/components.py +0 -0
  594. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/__init__.py +0 -0
  595. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/commands/__init__.py +0 -0
  596. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/commands/bootstrap.py +0 -0
  597. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/commands/configure.py +0 -0
  598. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/commands/load.py +0 -0
  599. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/components.py +0 -0
  600. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/constants.py +0 -0
  601. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/formats/__init__.py +0 -0
  602. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/formats/gsheets.py +0 -0
  603. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/tabular/helpers.py +0 -0
  604. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/__init__.py +0 -0
  605. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/commands/__init__.py +0 -0
  606. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/commands/configure.py +0 -0
  607. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/commands/load.py +0 -0
  608. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/components.py +0 -0
  609. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd/helpers.py +0 -0
  610. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/xsd2/commands/load.py +0 -0
  611. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/__init__.py +0 -0
  612. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/__init__.py +0 -0
  613. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/bootstrap.py +0 -0
  614. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/configure.py +0 -0
  615. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/load.py +0 -0
  616. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/manifest.py +0 -0
  617. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/migrate.py +0 -0
  618. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/commands/sync.py +0 -0
  619. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/components.py +0 -0
  620. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/manifests/yaml/helpers.py +0 -0
  621. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/methods.py +0 -0
  622. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/middlewares.py +0 -0
  623. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/naming/__init__.py +0 -0
  624. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/naming/components.py +0 -0
  625. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/naming/helpers.py +0 -0
  626. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/naming/ufuncts.py +0 -0
  627. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/nodes.py +0 -0
  628. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/renderer.py +0 -0
  629. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/spyna.py +0 -0
  630. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/templates/base.html +0 -0
  631. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/templates/data.html +0 -0
  632. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/templates/error.html +0 -0
  633. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/templates/form.html +0 -0
  634. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/__init__.py +0 -0
  635. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/client.py +0 -0
  636. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/config.py +0 -0
  637. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/context.py +0 -0
  638. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/csv.py +0 -0
  639. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/data.py +0 -0
  640. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/datasets.py +0 -0
  641. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/dtypes.py +0 -0
  642. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/manifest.py +0 -0
  643. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/migration.py +0 -0
  644. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/push.py +0 -0
  645. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/request.py +0 -0
  646. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/tabular.py +0 -0
  647. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/types/__init__.py +0 -0
  648. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/types/geometry.py +0 -0
  649. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/ufuncs.py +0 -0
  650. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/testing/utils.py +0 -0
  651. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/__init__.py +0 -0
  652. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/array/__init__.py +0 -0
  653. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/array/check.py +0 -0
  654. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/array/link.py +0 -0
  655. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/array/resolve.py +0 -0
  656. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/backref/__init__.py +0 -0
  657. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/backref/link.py +0 -0
  658. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/command.py +0 -0
  659. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/datatype.py +0 -0
  660. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/denorm/__init__.py +0 -0
  661. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/denorm/check.py +0 -0
  662. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/denorm/link.py +0 -0
  663. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/file/__init__.py +0 -0
  664. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/file/components.py +0 -0
  665. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/file/decode.py +0 -0
  666. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/file/helpers.py +0 -0
  667. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/geometry/__init__.py +0 -0
  668. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/geometry/components.py +0 -0
  669. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/geometry/constants.py +0 -0
  670. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/geometry/helpers.py +0 -0
  671. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/geometry/load.py +0 -0
  672. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/helpers.py +0 -0
  673. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/inherit/__init__.py +0 -0
  674. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/inherit/check.py +0 -0
  675. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/namespace.py +0 -0
  676. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/object/__init__.py +0 -0
  677. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/object/check.py +0 -0
  678. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/object/link.py +0 -0
  679. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/partial/__init__.py +0 -0
  680. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/partial/link.py +0 -0
  681. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/ref/__init__.py +0 -0
  682. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/ref/check.py +0 -0
  683. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/ref/link.py +0 -0
  684. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/ref/resolve.py +0 -0
  685. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/store.py +0 -0
  686. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/text/__init__.py +0 -0
  687. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/text/check.py +0 -0
  688. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/text/components.py +0 -0
  689. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/text/helpers.py +0 -0
  690. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/types/text/load.py +0 -0
  691. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/typing.py +0 -0
  692. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/__init__.py +0 -0
  693. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/binds.py +0 -0
  694. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/changebase/__init__.py +0 -0
  695. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/changebase/components.py +0 -0
  696. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/changebase/helpers.py +0 -0
  697. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/changebase/ufuncs.py +0 -0
  698. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/common.py +0 -0
  699. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/components.py +0 -0
  700. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/helpers.py +0 -0
  701. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/linkbuilder/__init__.py +0 -0
  702. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/linkbuilder/components.py +0 -0
  703. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/linkbuilder/ufuncs.py +0 -0
  704. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/loadbuilder/__init__.py +0 -0
  705. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/loadbuilder/components.py +0 -0
  706. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/loadbuilder/helpers.py +0 -0
  707. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/loadbuilder/ufuncs.py +0 -0
  708. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/propertyresolver/__init__.py +0 -0
  709. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/propertyresolver/components.py +0 -0
  710. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/propertyresolver/ufuncs.py +0 -0
  711. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/querybuilder/__init__.py +0 -0
  712. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/querybuilder/components.py +0 -0
  713. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/querybuilder/helpers.py +0 -0
  714. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/querybuilder/ufuncs.py +0 -0
  715. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/requestparamsbuilder/__init__.py +0 -0
  716. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/requestparamsbuilder/components.py +0 -0
  717. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/requestparamsbuilder/helpers.py +0 -0
  718. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/requestparamsbuilder/ufuncs.py +0 -0
  719. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/resultbuilder/__init__.py +0 -0
  720. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/resultbuilder/components.py +0 -0
  721. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/resultbuilder/helpers.py +0 -0
  722. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/resultbuilder/ufuncs.py +0 -0
  723. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/summaryenv/__init__.py +0 -0
  724. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/summaryenv/components.py +0 -0
  725. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/ufuncs/summaryenv/ufuncs.py +0 -0
  726. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/units/__init__.py +0 -0
  727. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/units/components.py +0 -0
  728. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/units/helpers.py +0 -0
  729. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/urlparams.py +0 -0
  730. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/__init__.py +0 -0
  731. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/aiotools.py +0 -0
  732. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/changes.py +0 -0
  733. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/collections.py +0 -0
  734. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/config.py +0 -0
  735. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/data.py +0 -0
  736. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/encoding.py +0 -0
  737. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/errors.py +0 -0
  738. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/functools.py +0 -0
  739. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/idgen.py +0 -0
  740. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/imports.py +0 -0
  741. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/itertools.py +0 -0
  742. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/json.py +0 -0
  743. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/naming.py +0 -0
  744. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/nestedstruct.py +0 -0
  745. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/nin.py +0 -0
  746. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/passwords.py +0 -0
  747. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/path.py +0 -0
  748. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/refs.py +0 -0
  749. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/response.py +0 -0
  750. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/schema.py +0 -0
  751. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/scopes.py +0 -0
  752. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/sqlalchemy.py +0 -0
  753. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/sqlite.py +0 -0
  754. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/starlette.py +0 -0
  755. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/streams.py +0 -0
  756. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/tree.py +0 -0
  757. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/types.py +0 -0
  758. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/units.py +0 -0
  759. {spinta-0.2.dev24 → spinta-0.2.dev25}/spinta/utils/url.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: spinta
3
- Version: 0.2.dev24
3
+ Version: 0.2.dev25
4
4
  Summary: A platform for describing, extracting, transforming, loading and serving open data.
5
5
  License: MIT
6
6
  License-File: LICENSE
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "spinta"
3
- version = "0.2dev24"
3
+ version = "0.2dev25"
4
4
  description = "A platform for describing, extracting, transforming, loading and serving open data."
5
5
  authors = ["Mantas Zimnickas <sirexas@gmail.com>"]
6
6
  license = "MIT"
@@ -1,12 +1,13 @@
1
1
  from __future__ import annotations
2
2
 
3
3
  import contextlib
4
+ import dataclasses
4
5
  from typing import Any, Type
5
6
  from typing import Dict
6
7
  from typing import Optional
7
8
  from typing import Set
8
9
 
9
- from spinta.backends.constants import BackendOrigin, BackendFeatures
10
+ from spinta.backends.constants import BackendOrigin, BackendFeatures, DistributionType
10
11
  from spinta.core.ufuncs import Env
11
12
  from spinta.ufuncs.resultbuilder.components import ResultBuilder
12
13
 
@@ -58,3 +59,9 @@ class Backend:
58
59
 
59
60
 
60
61
  SelectTree = Optional[Dict[str, "SelectTree"]]
62
+
63
+
64
+ @dataclasses.dataclass
65
+ class DistributionStrategy:
66
+ distribution_type: DistributionType
67
+ property: str | None = None
@@ -35,3 +35,13 @@ class BackendFeatures(enum.Enum):
35
35
 
36
36
  # Backend supports
37
37
  EXPAND = "EXPAND"
38
+
39
+ # Backend supports sharding
40
+ DISTRIBUTE = "DISTRIBUTE"
41
+
42
+
43
+ class DistributionType(enum.Enum):
44
+ SCHEMA = "schema"
45
+ TABLE = "table"
46
+ COPY = "copy"
47
+ UNDISTRIBUTED = "undistributed"
@@ -344,7 +344,7 @@ def get_ns_reserved_props(action: Action) -> list[str]:
344
344
  return []
345
345
 
346
346
 
347
- @dataclasses.dataclass
347
+ @dataclasses.dataclass(frozen=True)
348
348
  class TableIdentifier:
349
349
  """
350
350
  Represents a table identifier across logical (app) and PostgreSQL layers.
@@ -391,35 +391,42 @@ class TableIdentifier:
391
391
  table_arg: str | None = dataclasses.field(default=None)
392
392
  default_pg_schema: str | None = dataclasses.field(default=None)
393
393
 
394
- logical_name: str = dataclasses.field(init=False)
394
+ logical_name: str = dataclasses.field(init=False, compare=False)
395
395
  # Name with namespace connected with '/', like it is used with Model class
396
- logical_qualified_name: str = dataclasses.field(init=False)
396
+ logical_qualified_name: str = dataclasses.field(init=False, compare=False)
397
397
 
398
- pg_table_name: str = dataclasses.field(init=False)
399
- pg_schema_name: str | None = dataclasses.field(init=False)
398
+ pg_table_name: str = dataclasses.field(init=False, compare=False)
399
+ pg_schema_name: str | None = dataclasses.field(init=False, compare=False)
400
400
  # Used for hashed schema and table names
401
- pg_qualified_name: str = dataclasses.field(init=False)
401
+ pg_qualified_name: str = dataclasses.field(init=False, compare=False)
402
402
  # Escaped qualified name, used for queries
403
- pg_escaped_qualified_name: str = dataclasses.field(init=False)
403
+ pg_escaped_qualified_name: str = dataclasses.field(init=False, compare=False)
404
404
 
405
405
  def __post_init__(self):
406
- self.logical_name = self.base_name + self.table_type.value
406
+ logical_name = self.base_name + self.table_type.value
407
407
  if self.table_arg:
408
- self.logical_name += "/" + self.table_arg
408
+ logical_name += "/" + self.table_arg
409
409
 
410
- self.logical_qualified_name = f"{self.schema}/{self.logical_name}" if self.schema else self.logical_name
410
+ logical_qualified_name = f"{self.schema}/{logical_name}" if self.schema else logical_name
411
411
 
412
- self.pg_table_name = get_pg_name(self.logical_name)
413
- self.pg_schema_name = get_pg_name(self.schema) if self.schema else self.default_pg_schema
414
- self.pg_qualified_name = (
415
- f"{self.pg_schema_name}.{self.pg_table_name}" if self.pg_schema_name else self.pg_table_name
416
- )
417
- self.pg_escaped_qualified_name = (
418
- f"{pg_identifier_preparer.quote(self.pg_schema_name)}.{pg_identifier_preparer.quote(self.pg_table_name)}"
419
- if self.pg_schema_name
420
- else pg_identifier_preparer.quote(self.pg_table_name)
412
+ pg_table_name = get_pg_name(logical_name)
413
+ pg_schema_name = get_pg_name(self.schema) if self.schema else self.default_pg_schema
414
+ pg_qualified_name = f"{pg_schema_name}.{pg_table_name}" if pg_schema_name else pg_table_name
415
+ pg_escaped_qualified_name = (
416
+ f"{pg_identifier_preparer.quote(pg_schema_name)}.{pg_identifier_preparer.quote(pg_table_name)}"
417
+ if pg_schema_name
418
+ else pg_identifier_preparer.quote(pg_table_name)
421
419
  )
422
420
 
421
+ # This is needed because we want to make this dataclass hashable (frozen=True, does that)
422
+ # But because it becomes immutable, we need to set all the attributes manually (the same way dataclass __init__ does).
423
+ object.__setattr__(self, "logical_name", logical_name)
424
+ object.__setattr__(self, "logical_qualified_name", logical_qualified_name)
425
+ object.__setattr__(self, "pg_table_name", pg_table_name)
426
+ object.__setattr__(self, "pg_schema_name", pg_schema_name)
427
+ object.__setattr__(self, "pg_qualified_name", pg_qualified_name)
428
+ object.__setattr__(self, "pg_escaped_qualified_name", pg_escaped_qualified_name)
429
+
423
430
  def change_table_type(self, new_type: TableType, table_arg: str | None = None) -> "TableIdentifier":
424
431
  return dataclasses.replace(self, table_type=new_type, table_arg=table_arg)
425
432
 
@@ -48,7 +48,7 @@ def wipe(context: Context, model: Model, backend: PostgreSQL):
48
48
  if changelog_table_identifier.pg_schema_name
49
49
  else f'"{seqname}"'
50
50
  )
51
- connection.execute(f"ALTER SEQUENCE {seq_escaped_named} RESTART")
51
+ connection.execute(sa.func.setval(seq_escaped_named, 1, False))
52
52
 
53
53
  # Delete data table
54
54
  table = backend.get_table(model)
@@ -26,7 +26,13 @@ class PostgreSQL(Backend):
26
26
  },
27
27
  }
28
28
 
29
- features = {BackendFeatures.FILE_BLOCKS, BackendFeatures.WRITE, BackendFeatures.EXPAND, BackendFeatures.PAGINATION}
29
+ features = {
30
+ BackendFeatures.FILE_BLOCKS,
31
+ BackendFeatures.WRITE,
32
+ BackendFeatures.EXPAND,
33
+ BackendFeatures.PAGINATION,
34
+ BackendFeatures.DISTRIBUTE,
35
+ }
30
36
 
31
37
  engine: Engine = None
32
38
  schema: sa.MetaData = None
@@ -3,7 +3,7 @@ from sqlalchemy.dialects.postgresql import UUID
3
3
  from sqlalchemy.dialects import postgresql
4
4
 
5
5
  import sqlalchemy as sa
6
- from typing import TYPE_CHECKING
6
+ from typing import TYPE_CHECKING, Generator
7
7
 
8
8
  from spinta.backends.helpers import TableIdentifier
9
9
  from spinta.backends.postgresql.helpers.name import name_changed
@@ -91,6 +91,19 @@ class RenameTableMigrationAction(MigrationAction):
91
91
  )
92
92
 
93
93
 
94
+ class SetTableCommentMigrationAction(MigrationAction):
95
+ def __init__(self, table_identifier: TableIdentifier, comment: str) -> None:
96
+ self.table_identifier = table_identifier
97
+ self.comment = comment
98
+
99
+ def execute(self, op: "Operations") -> None:
100
+ op.create_table_comment(
101
+ table_name=self.table_identifier.pg_table_name,
102
+ comment=self.comment,
103
+ schema=self.table_identifier.pg_schema_name,
104
+ )
105
+
106
+
94
107
  class AddColumnMigrationAction(MigrationAction):
95
108
  def __init__(self, table_identifier: TableIdentifier, column: sa.Column) -> None:
96
109
  self.table_identifier = table_identifier
@@ -149,6 +162,21 @@ class AlterColumnMigrationAction(MigrationAction):
149
162
  )
150
163
 
151
164
 
165
+ class SetColumnCommentMigrationAction(MigrationAction):
166
+ def __init__(self, table_identifier: TableIdentifier, column: str, comment: str) -> None:
167
+ self.table_identifier = table_identifier
168
+ self.comment = comment
169
+ self.column = column
170
+
171
+ def execute(self, op: "Operations") -> None:
172
+ op.alter_column(
173
+ table_name=self.table_identifier.pg_table_name,
174
+ column_name=self.column,
175
+ comment=self.comment,
176
+ schema=self.table_identifier.pg_schema_name,
177
+ )
178
+
179
+
152
180
  class DropConstraintMigrationAction(MigrationAction):
153
181
  def __init__(self, table_identifier: TableIdentifier, constraint_name: str) -> None:
154
182
  self.table_identifier = table_identifier
@@ -547,6 +575,50 @@ class CreateSchemaMigrationAction(MigrationAction):
547
575
  op.execute(self.query)
548
576
 
549
577
 
578
+ class DistributeSchema(MigrationAction):
579
+ def __init__(self, schema_name: str) -> None:
580
+ self.schema_name = schema_name
581
+ self.query = f"SELECT citus_schema_distribute('{pg_identifier_preparer.quote(schema_name)}')"
582
+
583
+ def execute(self, op: "Operations") -> None:
584
+ op.execute(self.query)
585
+
586
+
587
+ class DistributeReference(MigrationAction):
588
+ def __init__(self, table_identifier: TableIdentifier) -> None:
589
+ self.query = f"SELECT create_reference_table('{table_identifier.pg_escaped_qualified_name}')"
590
+
591
+ def execute(self, op: "Operations") -> None:
592
+ op.execute(self.query)
593
+
594
+
595
+ class DistributeTable(MigrationAction):
596
+ def __init__(self, table_identifier: TableIdentifier, column: str) -> None:
597
+ self.query = f"SELECT create_distributed_table('{table_identifier.pg_escaped_qualified_name}', '{column}')"
598
+
599
+ def execute(self, op: "Operations") -> None:
600
+ op.execute(self.query)
601
+
602
+
603
+ class UndistributeSchema(MigrationAction):
604
+ def __init__(self, schema_name: str) -> None:
605
+ self.schema_name = schema_name
606
+ self.query = f"SELECT citus_schema_undistribute('{pg_identifier_preparer.quote(schema_name)}')"
607
+
608
+ def execute(self, op: "Operations") -> None:
609
+ op.execute(self.query)
610
+
611
+
612
+ class UndistributeTable(MigrationAction):
613
+ def __init__(self, table_identifier: TableIdentifier) -> None:
614
+ self.query = (
615
+ f"SELECT undistribute_table('{table_identifier.pg_escaped_qualified_name}', cascade_via_foreign_keys=>true)"
616
+ )
617
+
618
+ def execute(self, op: "Operations") -> None:
619
+ op.execute(self.query)
620
+
621
+
550
622
  class MigrationHandler:
551
623
  def __init__(self) -> None:
552
624
  self.migrations: list[MigrationAction] = []
@@ -571,8 +643,15 @@ class MigrationHandler:
571
643
  return True
572
644
  return False
573
645
 
574
- def run_migrations(self, op: "Operations") -> None:
646
+ def gather_migrations(self) -> Generator[MigrationAction, None, None]:
575
647
  for migration in self.migrations:
576
- migration.execute(op)
648
+ yield migration
577
649
  for migration in self.foreign_key_migration:
650
+ yield migration
651
+
652
+ def run_migrations(self, op: "Operations") -> None:
653
+ for migration in self.gather_migrations():
578
654
  migration.execute(op)
655
+
656
+ def count(self) -> int:
657
+ return len(list(self.gather_migrations()))
@@ -0,0 +1,383 @@
1
+ import dataclasses
2
+ from collections import defaultdict
3
+ from copy import deepcopy
4
+
5
+ import sqlalchemy as sa
6
+ from tqdm import tqdm
7
+ from multipledispatch import dispatch
8
+
9
+ from spinta.backends import Backend
10
+ from spinta.backends.constants import DistributionType
11
+ from spinta.backends.helpers import TableIdentifier
12
+ from spinta.backends.helpers import get_table_identifier
13
+ from spinta.backends.postgresql.components import PostgreSQL
14
+ from spinta.backends.postgresql.helpers.migrate.actions import (
15
+ MigrationHandler,
16
+ UndistributeSchema,
17
+ UndistributeTable,
18
+ DistributeReference,
19
+ DistributeTable,
20
+ DistributeSchema,
21
+ )
22
+ from spinta.cli.helpers.message import cli_message
23
+ from spinta.components import Context, Model
24
+ from spinta.exceptions import NotImplementedFeature
25
+
26
+
27
+ @dataclasses.dataclass
28
+ class ShardingPlan:
29
+ schemas: set[str] = dataclasses.field(default_factory=set)
30
+ references: set[TableIdentifier] = dataclasses.field(default_factory=set)
31
+ distributed: dict[TableIdentifier, str] = dataclasses.field(default_factory=dict)
32
+ local: set[TableIdentifier] = dataclasses.field(default_factory=set)
33
+
34
+ _lookup: dict[TableIdentifier | str, DistributionType] = dataclasses.field(init=False, default_factory=dict)
35
+
36
+ def __sub__(self, other) -> "ShardingPlan":
37
+ return ShardingPlan(
38
+ schemas=self.schemas - other.schemas,
39
+ references=self.references - other.references,
40
+ distributed=dict(self.distributed.items() - other.distributed.items()),
41
+ local=self.local - other.local,
42
+ )
43
+
44
+ def __post_init__(self) -> None:
45
+ for schema in self.schemas:
46
+ self._lookup[schema] = DistributionType.SCHEMA
47
+
48
+ for table_identifier in self.distributed.keys():
49
+ self._lookup[table_identifier] = DistributionType.TABLE
50
+
51
+ for table_identifier in self.references:
52
+ self._lookup[table_identifier] = DistributionType.COPY
53
+
54
+ for table_identifier in self.local:
55
+ self._lookup[table_identifier] = DistributionType.UNDISTRIBUTED
56
+
57
+ def distribution_type(self, key: TableIdentifier | str) -> DistributionType | None:
58
+ return self._lookup.get(key, None)
59
+
60
+ def discard(self, key: TableIdentifier | str) -> None:
61
+ distribution_type = self._lookup.pop(key, None)
62
+ if distribution_type is None:
63
+ return
64
+
65
+ match distribution_type:
66
+ case DistributionType.SCHEMA:
67
+ self.schemas.discard(key)
68
+ case DistributionType.TABLE:
69
+ self.distributed.pop(key)
70
+ case DistributionType.COPY:
71
+ self.references.discard(key)
72
+ case DistributionType.UNDISTRIBUTED:
73
+ self.local.discard(key)
74
+
75
+
76
+ def _generate_current_distribution_query(schemas: list[str] | None = None) -> (str, dict):
77
+ base_query = """
78
+ SELECT
79
+ n.nspname AS schema_name,
80
+ c.relname AS table_name,
81
+ format('%I.%I', n.nspname, c.relname) AS full_table_name,
82
+ d.description AS table_comment,
83
+ COALESCE(ct.citus_table_type, 'local') AS distribution_type,
84
+ ct.distribution_column
85
+ FROM pg_class c
86
+ JOIN pg_namespace n ON n.oid = c.relnamespace
87
+ LEFT JOIN citus_tables ct ON ct.table_name = c.oid::regclass
88
+ LEFT JOIN pg_description d ON d.objoid = c.oid AND d.objsubid = 0
89
+ WHERE c.relkind = 'r'
90
+ AND n.nspname NOT LIKE 'pg_%'
91
+ AND n.nspname <> 'information_schema'
92
+ """
93
+
94
+ params = {}
95
+ if schemas:
96
+ base_query += " AND n.nspname = ANY(:schemas)"
97
+ params["schemas"] = schemas
98
+
99
+ base_query += " ORDER BY n.nspname, c.relname"
100
+ return base_query, params
101
+
102
+
103
+ @dispatch(Context)
104
+ def gather_current_sharding_plan(context: Context, **kwargs) -> dict[str, ShardingPlan]:
105
+ store = context.get("store")
106
+ backends = store.backends
107
+
108
+ plans: dict[str, ShardingPlan] = defaultdict(ShardingPlan)
109
+ for backend_name, backend in backends.items():
110
+ plans[backend_name] = gather_current_sharding_plan(context, backend, **kwargs)
111
+ return plans
112
+
113
+
114
+ @dispatch(Context, Backend)
115
+ def gather_current_sharding_plan(context: Context, backend: Backend, **kwargs) -> ShardingPlan:
116
+ # Currently, only postgresql backend supports citus distribution, instead of erroring, return empty plan.
117
+ return ShardingPlan()
118
+
119
+
120
+ @dispatch(Context, PostgreSQL)
121
+ def gather_current_sharding_plan(
122
+ context: Context, backend: PostgreSQL, schemas: list[str] | None = None, **kwargs
123
+ ) -> ShardingPlan:
124
+ plan = ShardingPlan()
125
+ with backend.begin() as conn:
126
+ query, params = _generate_current_distribution_query(schemas)
127
+ rows = conn.execute(sa.text(query), params).fetchall()
128
+
129
+ for row in rows:
130
+ if not row["table_comment"]:
131
+ continue
132
+
133
+ table_identifier = get_table_identifier(row["table_comment"])
134
+ match row["distribution_type"]:
135
+ case "schema":
136
+ plan.schemas.add(row["schema_name"])
137
+ case "distributed":
138
+ plan.distributed[table_identifier] = row["distribution_column"]
139
+ case "reference":
140
+ plan.references.add(table_identifier)
141
+ case _:
142
+ plan.local.add(table_identifier)
143
+ return plan
144
+
145
+
146
+ def create_sharding_plan(context: Context, models: list[Model], **kwargs) -> dict[str, ShardingPlan]:
147
+ plans = defaultdict(ShardingPlan)
148
+ for model in models:
149
+ if not isinstance(model.backend, PostgreSQL):
150
+ continue
151
+
152
+ if not model.external or not model.external.dataset:
153
+ continue
154
+
155
+ distribution_strategy = model.distribution_strategy
156
+ plan = plans[model.backend.name]
157
+ table_identifier = get_table_identifier(model)
158
+ match distribution_strategy.distribution_type:
159
+ case DistributionType.SCHEMA:
160
+ plan.schemas.add(table_identifier.pg_schema_name)
161
+ case DistributionType.TABLE:
162
+ plan.distributed[table_identifier] = distribution_strategy.property
163
+ case DistributionType.COPY:
164
+ plan.references.add(table_identifier)
165
+ case _:
166
+ plan.local.add(table_identifier)
167
+
168
+ return plans
169
+
170
+
171
+ def invalidate_default_distribution(
172
+ context: Context, backend: PostgreSQL, plan: ShardingPlan, verbose: bool = False, **kwargs
173
+ ) -> ShardingPlan:
174
+ default_distribution = context.get("config").default_distribution_strategy
175
+ if not default_distribution:
176
+ return plan
177
+
178
+ match default_distribution.distribution_type:
179
+ case DistributionType.SCHEMA:
180
+ return invalidate_default_schema_distributions(context, backend, plan)
181
+ case _:
182
+ if verbose:
183
+ cli_message(
184
+ f"Skipped invalidation of default distribution for {default_distribution.distribution_type.value} type"
185
+ )
186
+
187
+ return plan
188
+
189
+
190
+ def valid_schema_distribution_foreign_key(plan: ShardingPlan, schema: str, foreign_key: dict) -> bool:
191
+ if foreign_key["referred_schema"] == schema:
192
+ return True
193
+
194
+ for reference in plan.references:
195
+ if (
196
+ reference.pg_schema_name == foreign_key["referred_schema"]
197
+ and reference.pg_table_name == foreign_key["referred_table"]
198
+ ):
199
+ return True
200
+
201
+ return False
202
+
203
+
204
+ @dispatch(Context, Backend, ShardingPlan)
205
+ def invalidate_default_schema_distributions(
206
+ context: Context, backend: Backend, plan: ShardingPlan, **kwargs
207
+ ) -> ShardingPlan:
208
+ raise NotImplementedFeature(f"Ability to invalidate default schema distribution for {backend.type!r} backend type")
209
+
210
+
211
+ @dispatch(Context, PostgreSQL, ShardingPlan)
212
+ def invalidate_default_schema_distributions(
213
+ context: Context, backend: PostgreSQL, plan: ShardingPlan, **kwargs
214
+ ) -> ShardingPlan:
215
+ if not plan.schemas:
216
+ return plan
217
+
218
+ invalid_schemas = set()
219
+
220
+ inspector = sa.inspect(backend.engine)
221
+
222
+ plan_copy = deepcopy(plan)
223
+ for schema in plan.schemas:
224
+ tables = inspector.get_table_names(schema=schema)
225
+
226
+ for table in tables:
227
+ foreign_keys = inspector.get_foreign_keys(table, schema=schema)
228
+ if not foreign_keys:
229
+ continue
230
+
231
+ for key in foreign_keys:
232
+ if not valid_schema_distribution_foreign_key(plan, schema, key):
233
+ invalid_schemas.add(key["referred_schema"])
234
+ invalid_schemas.add(schema)
235
+
236
+ if not invalid_schemas:
237
+ return plan
238
+
239
+ for invalid_schema in invalid_schemas:
240
+ plan_copy.schemas.discard(invalid_schema)
241
+
242
+ return plan_copy
243
+
244
+
245
+ def _build_fk_graph(conn: sa.engine.Connection) -> dict[tuple[str, str], set[tuple[str, str]]]:
246
+ graph: dict[tuple[str, str], set[tuple[str, str]]] = defaultdict(set)
247
+
248
+ rows = conn.execute("""
249
+ SELECT
250
+ src_ns.nspname AS source_schema,
251
+ src.relname AS source_table,
252
+ tgt_ns.nspname AS target_schema,
253
+ tgt.relname AS target_table
254
+ FROM pg_constraint con
255
+ JOIN pg_class src
256
+ ON src.oid = con.conrelid
257
+ JOIN pg_namespace src_ns
258
+ ON src_ns.oid = src.relnamespace
259
+ JOIN pg_class tgt
260
+ ON tgt.oid = con.confrelid
261
+ JOIN pg_namespace tgt_ns
262
+ ON tgt_ns.oid = tgt.relnamespace
263
+ WHERE con.contype = 'f'
264
+ """)
265
+
266
+ for src_schema, src_table, tgt_schema, tgt_table in rows.fetchall():
267
+ src = (src_schema, src_table)
268
+ tgt = (tgt_schema, tgt_table)
269
+
270
+ if src == tgt:
271
+ continue
272
+
273
+ graph[src].add(tgt)
274
+ graph[tgt].add(src)
275
+
276
+ visited: set[tuple[str, str]] = set()
277
+ key_to_component: dict[tuple[str, str], set[tuple[str, str]]] = {}
278
+
279
+ for node in graph:
280
+ if node in visited:
281
+ continue
282
+
283
+ stack = [node]
284
+ component: set[tuple[str, str]] = set()
285
+
286
+ while stack:
287
+ cur = stack.pop()
288
+ if cur in visited:
289
+ continue
290
+
291
+ visited.add(cur)
292
+ component.add(cur)
293
+ stack.extend(graph[cur] - visited)
294
+
295
+ for n in component:
296
+ key_to_component[n] = component
297
+
298
+ return key_to_component
299
+
300
+
301
+ def build_fk_components(
302
+ conn: sa.engine.Connection, tables: set[TableIdentifier]
303
+ ) -> dict[TableIdentifier, set[TableIdentifier]]:
304
+ """
305
+ Build FK-connected components using FULL DB graph,
306
+ then return mapping only for given `tables`.
307
+ """
308
+
309
+ target_map = {(t.pg_schema_name, t.pg_table_name): t for t in tables}
310
+ graph = _build_fk_graph(conn)
311
+
312
+ result = {}
313
+ for key, table in target_map.items():
314
+ full_component = graph.get(key, {key})
315
+ result[table] = {target_map[k] for k in full_component if k in target_map}
316
+
317
+ return result
318
+
319
+
320
+ def undistribute_all(
321
+ context: Context,
322
+ backend: PostgreSQL,
323
+ plan: ShardingPlan,
324
+ handler: MigrationHandler,
325
+ progress_bar: tqdm | None = None,
326
+ **kwargs,
327
+ ) -> None:
328
+ for schema in plan.schemas:
329
+ handler.add_action(UndistributeSchema(schema_name=schema))
330
+ if progress_bar is not None:
331
+ progress_bar.update(1)
332
+
333
+ if not (plan.references or plan.distributed):
334
+ return
335
+
336
+ processed = set()
337
+ undistributed_tables = plan.references | set(table for table in plan.distributed.keys())
338
+ with backend.begin() as conn:
339
+ component_map = build_fk_components(conn, undistributed_tables)
340
+
341
+ for table in plan.distributed.keys():
342
+ if table in processed:
343
+ continue
344
+
345
+ handler.add_action(UndistributeTable(table_identifier=table))
346
+ if progress_bar is not None:
347
+ progress_bar.update(1)
348
+ component = component_map[table]
349
+ processed.update(component)
350
+
351
+ for table in plan.references:
352
+ if table in processed:
353
+ continue
354
+
355
+ handler.add_action(UndistributeTable(table_identifier=table))
356
+ if progress_bar is not None:
357
+ progress_bar.update(1)
358
+ component = component_map[table]
359
+ processed.update(component)
360
+
361
+
362
+ def distribute_all(
363
+ context: Context,
364
+ backend: PostgreSQL,
365
+ plan: ShardingPlan,
366
+ handler: MigrationHandler,
367
+ progress_bar: tqdm | None = None,
368
+ **kwargs,
369
+ ) -> None:
370
+ for table in plan.references:
371
+ handler.add_action(DistributeReference(table_identifier=table))
372
+ if progress_bar is not None:
373
+ progress_bar.update(1)
374
+
375
+ for table, column in plan.distributed.items():
376
+ handler.add_action(DistributeTable(table_identifier=table, column=column))
377
+ if progress_bar is not None:
378
+ progress_bar.update(1)
379
+
380
+ for schema in plan.schemas:
381
+ handler.add_action(DistributeSchema(schema_name=schema))
382
+ if progress_bar is not None:
383
+ progress_bar.update(1)
@@ -30,6 +30,7 @@ def admin(
30
30
  """
31
31
  ),
32
32
  ),
33
+ manifests: Optional[List[str]] = Option(None, help=("Source manifest files for scripts that need them")),
33
34
  ensure_config_dir: bool = Option(True, "--ensure-config", help=("Ensures that all config files are created.")),
34
35
  force: bool = Option(False, "-f", "--force", help=("Skips all checks when running scripts.")),
35
36
  destructive: bool = Option(
@@ -90,5 +91,6 @@ def admin(
90
91
  check_only=check_only,
91
92
  input_path=input_path,
92
93
  output_path=output_path,
94
+ manifests=manifests,
93
95
  status_cache=status_cache,
94
96
  )
@@ -16,3 +16,6 @@ class Script(enum.Enum):
16
16
  DEDUPLICATE = "deduplicate"
17
17
  CHANGELOG = "changelog"
18
18
  ENUM_LIST = "enum_list"
19
+ CITUS_DISTRIBUTION = "citus_distribution"
20
+ ADD_LOCAL_IDS = "add_local_ids"
21
+ REMOVE_LOCAL_IDS = "remove_local_ids"