ApiLogicServer 15.0.65__py3-none-any.whl → 15.1.2__py3-none-any.whl

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 (523) hide show
  1. api_logic_server_cli/api_logic_server.py +4 -3
  2. api_logic_server_cli/api_logic_server_info.yaml +3 -3
  3. api_logic_server_cli/create_from_model/model_creation_services.py +1 -1
  4. api_logic_server_cli/database/basic_demo.sqlite +0 -0
  5. api_logic_server_cli/prototypes/base/.github/.copilot-instructions.md +25 -2
  6. api_logic_server_cli/prototypes/base/readme.md +1 -1
  7. api_logic_server_cli/prototypes/basic_demo/customizations/database/db.sqlite +0 -0
  8. api_logic_server_cli/prototypes/basic_demo/iteration/database/db.sqlite +0 -0
  9. api_logic_server_cli/prototypes/manager/.vscode/launch.json +2 -1
  10. api_logic_server_cli/prototypes/manager/samples/basic_demo/.devcontainer-option/For_VSCode.dockerfile +10 -0
  11. api_logic_server_cli/prototypes/manager/samples/basic_demo/.devcontainer-option/devcontainer.json +64 -0
  12. api_logic_server_cli/prototypes/manager/samples/basic_demo/.devcontainer-option/readme.md +1 -0
  13. api_logic_server_cli/prototypes/manager/samples/basic_demo/.devcontainer-option/setup.sh +10 -0
  14. api_logic_server_cli/prototypes/manager/samples/basic_demo/.env +4 -0
  15. api_logic_server_cli/prototypes/manager/samples/basic_demo/.github/.copilot-instructions.md +581 -0
  16. api_logic_server_cli/prototypes/manager/samples/basic_demo/.gitignore +9 -0
  17. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/ApiLogicServer.xml +24 -0
  18. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/Report_Behave_Logic.xml +24 -0
  19. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/Run_Behave.xml +24 -0
  20. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/Windows_Run_Behave.xml +24 -0
  21. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/run___No_Security.xml +25 -0
  22. api_logic_server_cli/prototypes/manager/samples/basic_demo/.idea/runConfigurations/run_docker.xml +59 -0
  23. api_logic_server_cli/prototypes/manager/samples/basic_demo/.vscode/launch.json +314 -0
  24. api_logic_server_cli/prototypes/manager/samples/basic_demo/.vscode/settings.json +40 -0
  25. api_logic_server_cli/prototypes/manager/samples/basic_demo/.vscode/venv_init.sh +64 -0
  26. api_logic_server_cli/prototypes/manager/samples/basic_demo/_config.yml +8 -0
  27. api_logic_server_cli/prototypes/manager/samples/basic_demo/_layouts/redirect.html +15 -0
  28. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/__init__.py +0 -0
  29. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/auto_discovery.py +27 -0
  30. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/mcp_discovery.py +97 -0
  31. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/mcp_expose_api_models.py +53 -0
  32. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/new_service.py +21 -0
  33. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/newer_service.py +21 -0
  34. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/ontimize_api.py +495 -0
  35. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/order_b2b_service.py +60 -0
  36. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/api_discovery/system.py +77 -0
  37. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/customize_api.py +63 -0
  38. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/expose_api_models.py +52 -0
  39. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/json_encoder.py +17 -0
  40. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/readme_customize_api.md +103 -0
  41. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/api_utils.py +171 -0
  42. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/custom_endpoint.py +1085 -0
  43. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/expression_parser.py +685 -0
  44. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/gen_csv_report.py +41 -0
  45. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/gen_pdf_report.py +215 -0
  46. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/opt_locking/opt_locking.py +158 -0
  47. api_logic_server_cli/prototypes/manager/samples/basic_demo/api/system/opt_locking/readme.md +225 -0
  48. api_logic_server_cli/prototypes/manager/samples/basic_demo/api_logic_server_run.py +162 -0
  49. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/__init__.py +0 -0
  50. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/activate_logicbank.py +46 -0
  51. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/config.py +772 -0
  52. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/default.env +16 -0
  53. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/logging-reduced.yml +112 -0
  54. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/logging.yml +123 -0
  55. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/mypy.ini +25 -0
  56. api_logic_server_cli/prototypes/manager/samples/basic_demo/config/server_setup.py +459 -0
  57. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/api/api_discovery/openapi.py +92 -0
  58. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/config/default.env +13 -0
  59. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/database/db.sqlite +0 -0
  60. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/database/models.py +130 -0
  61. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/docs/mcp_learning/mcp_discovery.json +108 -0
  62. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/logic/cocktail-napkin.jpg +0 -0
  63. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/logic/declare_logic.py +106 -0
  64. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/logic/logic_discovery/email_request.py +49 -0
  65. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/logic/logic_discovery/simple_constraints.py +25 -0
  66. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/security/declare_security.py +60 -0
  67. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/admin/admin.yaml +162 -0
  68. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/admin/home.js +48 -0
  69. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/README.md +17 -0
  70. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/README_create_react_app.md +70 -0
  71. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/package-lock.json +18469 -0
  72. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/package.json +47 -0
  73. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/favicon.ico +0 -0
  74. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/index.html +43 -0
  75. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/logo192.png +0 -0
  76. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/logo512.png +0 -0
  77. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/manifest.json +25 -0
  78. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/public/robots.txt +3 -0
  79. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/App.css +38 -0
  80. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/App.js +61 -0
  81. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/App.test.js +8 -0
  82. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Config-reference.js +527 -0
  83. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Config.js +527 -0
  84. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Customer-reference.js +216 -0
  85. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Customer.js +230 -0
  86. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Item.js +170 -0
  87. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Order.js +207 -0
  88. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/Product.js +140 -0
  89. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/SysEmail.js +157 -0
  90. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/SysMcp.js +110 -0
  91. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/app_loader.js +24 -0
  92. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/index.css +13 -0
  93. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/index.js +17 -0
  94. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/logo.svg +1 -0
  95. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/.eslintrc +5 -0
  96. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/.yarnrc.yml +4 -0
  97. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/default-settings.js +25 -0
  98. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/default-settings.ts +25 -0
  99. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/errors.js +116 -0
  100. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/errors.ts +116 -0
  101. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/index.test.tsx +7 -0
  102. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/index.tsx +11 -0
  103. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/ra-jsonapi-client.js +577 -0
  104. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/ra-jsonapi-client.ts +577 -0
  105. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/resourceLookup.js +124 -0
  106. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/resourceLookup.ts +124 -0
  107. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/rav4-jsonapi-client/styles.module.css +9 -0
  108. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/reportWebVitals.js +13 -0
  109. api_logic_server_cli/prototypes/manager/samples/basic_demo/customizations/ui/reference_react_app/src/setupTests.js +5 -0
  110. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/__init__.py +0 -0
  111. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/alembic_run.py +98 -0
  112. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/env.py +78 -0
  113. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/readme_alembic.md +36 -0
  114. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/script.py.mako +24 -0
  115. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/versions/ae6a5c2fdc47_autogenerated.py +34 -0
  116. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic/versions/readme.md +1 -0
  117. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/alembic.ini +103 -0
  118. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/authentication_db.sqlite +0 -0
  119. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/bind_dbs.py +25 -0
  120. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/customize_models.py +19 -0
  121. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/database_discovery/authentication_models.py +183 -0
  122. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/database_discovery/auto_discovery.py +27 -0
  123. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/db.sqlite +0 -0
  124. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/db_debug/db_debug.py +90 -0
  125. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/mcp_db.sqlite +0 -0
  126. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/mcp_models.py +58 -0
  127. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/models.py +132 -0
  128. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/system/SAFRSBaseX.py +139 -0
  129. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/test_data/alp_init.py +40 -0
  130. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/test_data/readme.md +13 -0
  131. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/test_data/response2code.py +148 -0
  132. api_logic_server_cli/prototypes/manager/samples/basic_demo/database/test_data/test_data_preamble.py +83 -0
  133. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/auth-db/authdb_mysql.Dockerfile +65 -0
  134. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/auth-db/authdb_mysql.sql +112 -0
  135. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/auth-db/authdb_postgres.sql +57 -0
  136. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-compose-dev-azure/azure-deploy.sh +98 -0
  137. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-compose-dev-local/docker-compose-dev-local.yml +38 -0
  138. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-compose-dev-local/docker-compose.sh +34 -0
  139. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-image/build_image.dockerfile +20 -0
  140. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-image/build_image.sh +67 -0
  141. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-image/env.list +35 -0
  142. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-image/run_image.sh +23 -0
  143. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-standard-image/docker-compose-standard-image.yml +33 -0
  144. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/docker-standard-image/env.list +55 -0
  145. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/h2/keycloakdb.mv.db +0 -0
  146. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/h2/keycloakdb.trace.db +236 -0
  147. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/import/kcals-realm.json +1807 -0
  148. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/import/kcals-users-0.json +24 -0
  149. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/import/master-realm.json +1953 -0
  150. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/import/master-users-0.json +23 -0
  151. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/data/tmp/kc-gzip-cache/nnbna/js/keycloak.js.gz +0 -0
  152. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/docker-compose-dev-network.yml +31 -0
  153. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/docker-compose-nginx.yml +48 -0
  154. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/docker-compose.yml +24 -0
  155. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/import/kcals-realm.json +1898 -0
  156. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/import/kcals-users-0.json +319 -0
  157. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/import/master-realm.json +1953 -0
  158. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/import/master-users-0.json +23 -0
  159. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/nginx/cert.pem +25 -0
  160. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/nginx/key.pem +28 -0
  161. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/nginx/nginx.conf +73 -0
  162. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/startup_log_nginx.txt +0 -0
  163. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/startup_log_no_nginx.txt +0 -0
  164. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/unused/auth_provider.py +80 -0
  165. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/keycloak/unused/unused-docker-compose-keycloak.sh +13 -0
  166. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/python-anywhere/python_anywhere_wsgi.py +116 -0
  167. api_logic_server_cli/prototypes/manager/samples/basic_demo/devops/readme-devops.md +31 -0
  168. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/db.dbml +14 -0
  169. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/graphics/readme.md +12 -0
  170. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/logic/readme.md +19 -0
  171. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/logic_suggestions/readme_logic_suggestions.md +3 -0
  172. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/mcp_learning/mcp.prompt +39 -0
  173. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/mcp_learning/mcp_schema.json +30 -0
  174. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/models-not-code.png +0 -0
  175. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/runtime engines.png +0 -0
  176. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/system-creation-vibe.md +158 -0
  177. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/admin_app_1_context.prompt.md +43 -0
  178. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/admin_app_2_functionality.prompt.md +69 -0
  179. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/admin_app_3_architecture.prompt.md +29 -0
  180. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/logic_bank_api.prompt +342 -0
  181. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/logic_example.py +41 -0
  182. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/react_map.prompt.md +13 -0
  183. api_logic_server_cli/prototypes/manager/samples/basic_demo/docs/training/react_tree.prompt.md +10 -0
  184. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/kafka/kafka_consumer.py +60 -0
  185. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/kafka/kafka_producer.py +127 -0
  186. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/kafka/kafka_readme.md +3 -0
  187. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_context_results.txt +142 -0
  188. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_discovery_response.json +150 -0
  189. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_request.prompt +46 -0
  190. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_schema.txt +47 -0
  191. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_tool_context_response.json +34 -0
  192. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/examples/mcp_tool_context_response_get.json +18 -0
  193. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/mcp_client_executor.py +545 -0
  194. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/mcp_server_discovery.json +9 -0
  195. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/mcp/readme-mcp.md +9 -0
  196. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/n8n/N8N_WebHook_from_ApiLogicServer.json +394 -0
  197. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/n8n/n8n_producer.py +172 -0
  198. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/n8n/n8n_readme.md +67 -0
  199. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/row_dict_maps/OrderB2BMapper.py +54 -0
  200. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/row_dict_maps/row_dict_maps_readme.md +3 -0
  201. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/system/FlaskKafka.py +105 -0
  202. api_logic_server_cli/prototypes/manager/samples/basic_demo/integration/system/RowDictMapper.py +416 -0
  203. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/api/api_discovery/order_b2b.py +92 -0
  204. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/database/db.sqlite +0 -0
  205. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/docs/er_diagram.png +0 -0
  206. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/integration/row_dict_maps/OrderB2B.py +36 -0
  207. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/integration/row_dict_maps/OrderShipping.py +30 -0
  208. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/logic/declare_logic.py +147 -0
  209. api_logic_server_cli/prototypes/manager/samples/basic_demo/iteration/ui/admin/admin.yaml +175 -0
  210. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/declarative-vs-procedural-comparison.html +110 -0
  211. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/declare_logic.py +81 -0
  212. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/load_verify_rules.py +217 -0
  213. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/app_integration.py +23 -0
  214. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/auto_discovery.py +52 -0
  215. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/check_credit.py +44 -0
  216. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/mcp_client_executor_request.py +50 -0
  217. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/readme_logic_discovery.md +9 -0
  218. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/logic_discovery/use_case.py +31 -0
  219. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/procedural/credit_service.py +204 -0
  220. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/procedural/declarative-vs-procedural-comparison.md +295 -0
  221. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/procedural/declarative-vs-procedural-comparison.png +0 -0
  222. api_logic_server_cli/prototypes/manager/samples/basic_demo/logic/readme_logic.md +249 -0
  223. api_logic_server_cli/prototypes/manager/samples/basic_demo/readme.md +495 -0
  224. api_logic_server_cli/prototypes/manager/samples/basic_demo/readme_project.md +43 -0
  225. api_logic_server_cli/prototypes/manager/samples/basic_demo/readme_standard.md +492 -0
  226. api_logic_server_cli/prototypes/manager/samples/basic_demo/readme_vibe.md +353 -0
  227. api_logic_server_cli/prototypes/manager/samples/basic_demo/requirements.txt +3 -0
  228. api_logic_server_cli/prototypes/manager/samples/basic_demo/run.ps1 +30 -0
  229. api_logic_server_cli/prototypes/manager/samples/basic_demo/run.sh +55 -0
  230. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/__init__.py +0 -0
  231. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/__init__.py +0 -0
  232. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/abstract_authentication_provider.py +34 -0
  233. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/keycloak/auth_provider.py +238 -0
  234. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/memory/auth_provider.py +161 -0
  235. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/memory/auth_provider_no_swagger.py +98 -0
  236. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/authentication_provider/sql/auth_provider.py +127 -0
  237. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/declare_security.py +49 -0
  238. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/readme_security.md +16 -0
  239. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/system/authentication.py +129 -0
  240. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/system/authorization.py +473 -0
  241. api_logic_server_cli/prototypes/manager/samples/basic_demo/security/system/custom_swagger.json +62 -0
  242. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/__init__.py +0 -0
  243. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/__init__.py +0 -0
  244. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/behave_logic_report.py +256 -0
  245. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/behave_run.py +64 -0
  246. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/features/about.feature +12 -0
  247. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/features/steps/about.py +20 -0
  248. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/features/steps/test_utils.py +133 -0
  249. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/logs/behave.log +0 -0
  250. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/reports/Behave Logic Report Intro micro.md +4 -0
  251. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/reports/Behave Logic Report Intro.md +75 -0
  252. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/api_logic_server_behave/reports/Behave Logic Report Sample.md +1180 -0
  253. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/basic/server_test.py +33 -0
  254. api_logic_server_cli/prototypes/manager/samples/basic_demo/test/readme_test.md +395 -0
  255. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/__init__.py +0 -0
  256. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/admin/admin.yaml +173 -0
  257. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/admin/admin_loader.py +217 -0
  258. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/admin/authentication_admin.yaml +99 -0
  259. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/admin/home.js +48 -0
  260. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/admin/mcp_admin.yaml +53 -0
  261. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/.browserslistrc +12 -0
  262. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/.dockerignore +47 -0
  263. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/.editorconfig +16 -0
  264. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/.eslintrc.json +51 -0
  265. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/.gitignore +47 -0
  266. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/README.md +42 -0
  267. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/angular.json +206 -0
  268. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/app_model.yaml +303 -0
  269. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/docker-compose-ontimize.yml +54 -0
  270. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/e2e/protractor.conf.js +32 -0
  271. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/e2e/src/app.e2e-spec.ts +23 -0
  272. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/e2e/src/app.po.ts +11 -0
  273. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/e2e/tsconfig.json +13 -0
  274. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/karma.conf.js +32 -0
  275. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/nginx/nginx.conf +29 -0
  276. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/ngsw-config.json +29 -0
  277. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/package-lock.json +22651 -0
  278. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/package.json +69 -0
  279. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app-routing.module.ts +25 -0
  280. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.component.html +1 -0
  281. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.component.scss +1 -0
  282. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.component.spec.ts +35 -0
  283. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.component.ts +9 -0
  284. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.config.ts +43 -0
  285. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/app.module.ts +37 -0
  286. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login-routing.module.ts +12 -0
  287. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login.component.html +58 -0
  288. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login.component.scss +155 -0
  289. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login.component.ts +81 -0
  290. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login.module.ts +18 -0
  291. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/login/login.theme.scss +51 -0
  292. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/Customer-routing.module.ts +37 -0
  293. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/Customer.module.ts +19 -0
  294. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/detail/Customer-detail.component.html +90 -0
  295. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/detail/Customer-detail.component.scss +0 -0
  296. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/detail/Customer-detail.component.ts +32 -0
  297. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/home/Customer-home.component.html +44 -0
  298. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/home/Customer-home.component.scss +0 -0
  299. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/home/Customer-home.component.ts +23 -0
  300. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/new/Customer-new.component.html +26 -0
  301. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/new/Customer-new.component.scss +0 -0
  302. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Customer/new/Customer-new.component.ts +18 -0
  303. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/Item-routing.module.ts +30 -0
  304. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/Item.module.ts +19 -0
  305. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/detail/Item-detail.component.html +72 -0
  306. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/detail/Item-detail.component.scss +0 -0
  307. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/detail/Item-detail.component.ts +32 -0
  308. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/home/Item-home.component.html +55 -0
  309. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/home/Item-home.component.scss +0 -0
  310. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/home/Item-home.component.ts +23 -0
  311. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/new/Item-new.component.html +60 -0
  312. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/new/Item-new.component.scss +0 -0
  313. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Item/new/Item-new.component.ts +18 -0
  314. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/Order-routing.module.ts +37 -0
  315. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/Order.module.ts +19 -0
  316. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/detail/Order-detail.component.html +114 -0
  317. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/detail/Order-detail.component.scss +0 -0
  318. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/detail/Order-detail.component.ts +32 -0
  319. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/home/Order-home.component.html +48 -0
  320. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/home/Order-home.component.scss +0 -0
  321. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/home/Order-home.component.ts +23 -0
  322. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/new/Order-new.component.html +43 -0
  323. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/new/Order-new.component.scss +0 -0
  324. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Order/new/Order-new.component.ts +18 -0
  325. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/Product-routing.module.ts +37 -0
  326. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/Product.module.ts +19 -0
  327. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/detail/Product-detail.component.html +91 -0
  328. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/detail/Product-detail.component.scss +0 -0
  329. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/detail/Product-detail.component.ts +32 -0
  330. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/home/Product-home.component.html +35 -0
  331. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/home/Product-home.component.scss +0 -0
  332. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/home/Product-home.component.ts +23 -0
  333. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/new/Product-new.component.html +20 -0
  334. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/new/Product-new.component.scss +0 -0
  335. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/Product/new/Product-new.component.ts +18 -0
  336. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about-routing.module.ts +13 -0
  337. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about.component.html +39 -0
  338. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about.component.scss +35 -0
  339. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about.component.ts +17 -0
  340. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about.module.ts +18 -0
  341. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/about/about.theme.scss +14 -0
  342. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/home/home-routing.module.ts +17 -0
  343. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/home/home.component.html +1 -0
  344. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/home/home.component.scss +3 -0
  345. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/home/home.component.ts +21 -0
  346. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/home/home.module.ts +18 -0
  347. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main-routing.module.ts +32 -0
  348. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main-theme.scss +56 -0
  349. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main.component.html +8 -0
  350. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main.component.scss +1 -0
  351. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main.component.ts +20 -0
  352. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/main.module.ts +22 -0
  353. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/settings/settings-routing.module.ts +14 -0
  354. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/settings/settings.component.html +14 -0
  355. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/settings/settings.component.scss +44 -0
  356. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/settings/settings.component.ts +46 -0
  357. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/main/settings/settings.module.ts +18 -0
  358. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Customer-card/Customer-card.component.html +1 -0
  359. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Customer-card/Customer-card.component.scss +0 -0
  360. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Customer-card/Customer-card.component.ts +16 -0
  361. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Item-card/Item-card.component.html +1 -0
  362. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Item-card/Item-card.component.scss +0 -0
  363. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Item-card/Item-card.component.ts +16 -0
  364. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Order-card/Order-card.component.html +1 -0
  365. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Order-card/Order-card.component.scss +0 -0
  366. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Order-card/Order-card.component.ts +16 -0
  367. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Product-card/Product-card.component.html +1 -0
  368. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Product-card/Product-card.component.scss +0 -0
  369. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/Product-card/Product-card.component.ts +16 -0
  370. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/app.menu.config.ts +45 -0
  371. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/app.services.config.ts +5 -0
  372. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/constant.ts +4 -0
  373. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/app/shared/shared.module.ts +15 -0
  374. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/.gitkeep +0 -0
  375. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/css/app.scss +20 -0
  376. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/css/loader.css +173 -0
  377. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/i18n/en.json +44 -0
  378. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/i18n/es.json +42 -0
  379. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize128.png +0 -0
  380. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize16.png +0 -0
  381. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize256.png +0 -0
  382. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize32.png +0 -0
  383. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize48.png +0 -0
  384. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize64.png +0 -0
  385. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize72.png +0 -0
  386. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/icons/ontimize96.png +0 -0
  387. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/github.png +0 -0
  388. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/login_bg.png +0 -0
  389. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/no-image-transparent.png +0 -0
  390. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/no-image.png +0 -0
  391. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/ontimize.png +0 -0
  392. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/ontimize_web_log.png +0 -0
  393. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/sidenav-closed.png +0 -0
  394. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/sidenav-closed.svg +1 -0
  395. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/sidenav-opened.png +0 -0
  396. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/sidenav-opened.svg +1 -0
  397. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/images/user_profile.png +0 -0
  398. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/js/domchange.js +110 -0
  399. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/assets/js/keyboard.js +24 -0
  400. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/environments/environment.prod.ts +11 -0
  401. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/environments/environment.ts +15 -0
  402. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/favicon.ico +0 -0
  403. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/index.html +30 -0
  404. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/main.ts +15 -0
  405. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/manifest.webmanifest +59 -0
  406. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/polyfills.ts +66 -0
  407. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/styles.scss +1 -0
  408. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/src/test.ts +16 -0
  409. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/tsconfig.app.json +18 -0
  410. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/tsconfig.json +25 -0
  411. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/app/tsconfig.spec.json +18 -0
  412. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/andrew.jpg +0 -0
  413. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/anne.jpg +0 -0
  414. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/janet.jpg +0 -0
  415. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/laura.jpg +0 -0
  416. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/margaret.jpg +0 -0
  417. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/michael.jpg +0 -0
  418. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/nancy.jpg +0 -0
  419. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/robert.jpg +0 -0
  420. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Employee/steven.jpg +0 -0
  421. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/beverages.gif +0 -0
  422. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/cereals.gif +0 -0
  423. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/condiments.gif +0 -0
  424. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/confections.gif +0 -0
  425. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/diary.gif +0 -0
  426. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/meat.gif +0 -0
  427. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/produce.gif +0 -0
  428. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/images/Product/seafood.gif +0 -0
  429. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/README.md +16 -0
  430. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/README_create_react_app.md +70 -0
  431. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/package-lock.json +18469 -0
  432. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/package.json +47 -0
  433. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/favicon.ico +0 -0
  434. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/index.html +43 -0
  435. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/logo192.png +0 -0
  436. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/logo512.png +0 -0
  437. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/manifest.json +25 -0
  438. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/public/robots.txt +3 -0
  439. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/App.css +38 -0
  440. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/App.js +80 -0
  441. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/App.test.js +8 -0
  442. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/Config.js +527 -0
  443. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/Customer.js +218 -0
  444. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/Item.js +190 -0
  445. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/Order.js +189 -0
  446. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/Product.js +159 -0
  447. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/app_loader.js +24 -0
  448. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/index.css +13 -0
  449. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/index.js +17 -0
  450. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/logo.svg +1 -0
  451. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/.eslintrc +5 -0
  452. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/.yarnrc.yml +4 -0
  453. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/default-settings.js +25 -0
  454. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/default-settings.ts +25 -0
  455. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/errors.js +116 -0
  456. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/errors.ts +116 -0
  457. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/index.test.tsx +7 -0
  458. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/index.tsx +11 -0
  459. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/ra-jsonapi-client.js +577 -0
  460. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/ra-jsonapi-client.ts +577 -0
  461. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/resourceLookup.js +124 -0
  462. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/resourceLookup.ts +124 -0
  463. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/rav4-jsonapi-client/styles.module.css +9 -0
  464. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/reportWebVitals.js +13 -0
  465. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app/src/setupTests.js +5 -0
  466. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/README.md +20 -0
  467. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/README_create_react_app.md +72 -0
  468. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/package-lock.json +18469 -0
  469. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/package.json +47 -0
  470. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/product-cards.png +0 -0
  471. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/favicon.ico +0 -0
  472. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/index.html +43 -0
  473. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/logo192.png +0 -0
  474. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/logo512.png +0 -0
  475. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/manifest.json +25 -0
  476. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/public/robots.txt +3 -0
  477. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/App.css +38 -0
  478. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/App.js +80 -0
  479. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/App.test.js +8 -0
  480. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/Config.js +527 -0
  481. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/Customer.js +218 -0
  482. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/Item.js +190 -0
  483. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/Order.js +189 -0
  484. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/Product.js +241 -0
  485. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/app_loader.js +24 -0
  486. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/index.css +13 -0
  487. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/index.js +17 -0
  488. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/logo.svg +1 -0
  489. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/.eslintrc +5 -0
  490. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/.yarnrc.yml +4 -0
  491. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/default-settings.js +25 -0
  492. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/default-settings.ts +25 -0
  493. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/errors.js +116 -0
  494. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/errors.ts +116 -0
  495. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/index.test.tsx +7 -0
  496. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/index.tsx +11 -0
  497. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/ra-jsonapi-client.js +577 -0
  498. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/ra-jsonapi-client.ts +577 -0
  499. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/resourceLookup.js +124 -0
  500. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/resourceLookup.ts +124 -0
  501. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/rav4-jsonapi-client/styles.module.css +9 -0
  502. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/reportWebVitals.js +13 -0
  503. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/my-react-app-cards/src/setupTests.js +5 -0
  504. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/templates/bar_chart.jinja +64 -0
  505. api_logic_server_cli/prototypes/manager/samples/basic_demo/ui/templates/content.html +3 -0
  506. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/py.py +121 -0
  507. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/readme_venv.md +20 -0
  508. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/requirements-no-cli.txt +33 -0
  509. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/venv-linux.sh +28 -0
  510. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/venv.ps1 +21 -0
  511. api_logic_server_cli/prototypes/manager/samples/basic_demo/venv_setup/venv.sh +28 -0
  512. api_logic_server_cli/prototypes/manager/samples/dbs/readme_dbs.md +4 -4
  513. api_logic_server_cli/prototypes/manager/samples/readme_samples.md +13 -6
  514. api_logic_server_cli/prototypes/manager/system/Manager_workspace.code-workspace +3 -2
  515. api_logic_server_cli/sqlacodegen_wrapper/sqlacodegen/sqlacodegen/codegen.py +7 -4
  516. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/METADATA +1 -1
  517. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/RECORD +521 -21
  518. api_logic_server_cli/prototypes/manager/.vscode/.copilot-instructions.md +0 -58
  519. api_logic_server_cli/prototypes/manager/.vscode/ApiLogicServer.code-workspace +0 -15
  520. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/WHEEL +0 -0
  521. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/entry_points.txt +0 -0
  522. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/licenses/LICENSE +0 -0
  523. {apilogicserver-15.0.65.dist-info → apilogicserver-15.1.2.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,685 @@
1
+ """
2
+ Advanced Expression Parsing - return SQL Where clause
3
+ version: 11.00.08 - api_logic_server_cli/prototypes/ont_app/prototype/api/expression_parser.py
4
+ """
5
+ """
6
+ JSON:API filtering strategies
7
+ """
8
+ import sqlalchemy
9
+ import safrs
10
+ import json
11
+ from flask import request
12
+ from sqlalchemy.orm import joinedload, Query
13
+ from operator import not_, and_, or_, eq, ne, lt, le, gt, ge
14
+ from sqlalchemy import or_ as OR_
15
+ from sqlalchemy import and_ as AND_
16
+ from decimal import Decimal
17
+
18
+ BASIC_EXPRESSION = "@basic_expression"
19
+ """Ontimize Advanced Filter Expressions"""
20
+ FILTER_EXPRESSION = "@filter_expression"
21
+ """Ontimize Advanced Filter Expressions"""
22
+ # Ontimize Advanced Filter Expressions
23
+ ONTIMIZE_OPERATORS = {
24
+ 'LESS' : " < ",
25
+ 'LESS_EQUAL' : " <= ",
26
+ 'EQUAL' : " = ",
27
+ 'EQ' : " = ",
28
+ 'GT' : " > ",
29
+ 'GE' : " >= ",
30
+ "LT" : " < ",
31
+ "LE" : " <= ",
32
+ "NE" : " <> ",
33
+ "IN" : " IN ",
34
+ "NOT_IN" : " NOT IN ",
35
+ 'MORE_EQUAL' : " >= ",
36
+ 'MORE' : " > ",
37
+ 'NULL' : " IS NULL ",
38
+ 'IS_NULL' : " IS NULL ",
39
+ 'NOT_EQUAL' : "<>",
40
+ 'NOT_NULL' : " IS NOT NULL ",
41
+ 'NOTNULL' : " IS NOT NULL ",
42
+ 'LIKE' : " LIKE ",
43
+ 'NOT_LIKE' : " NOT LIKE ",
44
+ 'NOTLIKE' : " NOT LIKE ",
45
+ 'OR' : " OR ",
46
+ 'AND' : " AND ",
47
+ 'OR_NOT' : " OR NOT ",
48
+ 'AND_NOT' : " AND NOT "
49
+ }
50
+
51
+
52
+ class DotDict(dict):
53
+ """dot.notation access to dictionary attributes"""
54
+
55
+ # thanks: https://stackoverflow.com/questions/2352181/how-to-use-a-dot-to-access-members-of-dictionary/28463329
56
+ __getattr__ = dict.get
57
+ __setattr__ = dict.__setitem__
58
+ __delattr__ = dict.__delitem__
59
+
60
+
61
+ def parsePayload(clz, payload: str):
62
+ """
63
+ Parse the Ontimize payload
64
+ :expressions list using by advancedFilter in jsonapi_filter
65
+ :filter any
66
+ :columns list
67
+ :sqltypes list
68
+ :offset number
69
+ :pagesize number
70
+ :orderBy string
71
+ :data JSON
72
+ """
73
+ columns = []
74
+ pagesize = 20
75
+ offset = 0
76
+ orderBy = None
77
+ _filter = None
78
+ data = None
79
+ filters = {}
80
+ sqltypes = None
81
+ if len(request.args) > 0:
82
+ for arg, value in request.args.items():
83
+ if arg.startswith("fields"):
84
+ columns.append(value)
85
+ elif arg == 'page[limit]':
86
+ pagesize = int(value) if value else 999
87
+ elif arg == 'page[offset]':
88
+ offset = int(value)
89
+ elif arg == 'sort':
90
+ orderBy = value
91
+ elif arg.startswith("filter"):
92
+ filters[arg] = value
93
+ expressions, _filter = advancedFilter(clz, request.args)
94
+ else:
95
+ sqltypes = payload.get("sqltypes") or None
96
+ expressions, sqlWhere = advancedFilter(clz, payload)
97
+ _filter, filter = parseFilter(clz, payload.get("filter", {}), sqltypes)
98
+ columns: list = payload.get("columns") or []
99
+ offset: int = payload.get("offset") or 0
100
+ pagesize: int = payload.get("pageSize") or 100
101
+ orderBy: list = fixup_sort(clz, payload.get("orderBy", None)) or []
102
+ data = fixup_data(payload.get("data", None), sqltypes)
103
+
104
+ return expressions, _filter, columns, sqltypes, offset, pagesize, orderBy, data
105
+
106
+
107
+ def parseFilter(clz: any, filter: dict, sqltypes: any):
108
+ # sourcery skip: merge-duplicate-blocks, remove-pass-elif
109
+ filters = []
110
+ sql_where = ""
111
+ join = ""
112
+ expr = None
113
+ for f, value in filter.items():
114
+ if f in [BASIC_EXPRESSION]:
115
+ if expr := ExpressionParser(filter, BASIC_EXPRESSION, sqltypes):
116
+ sql_where += join + expr.get_sql_where()
117
+ filters = expr.get_filters()
118
+ join = " OR "
119
+ elif f in [FILTER_EXPRESSION]:
120
+ if expr := ExpressionParser(filter, FILTER_EXPRESSION, sqltypes):
121
+ sql_where += join + expr.get_sql_where()
122
+ filters = expr.get_filters()
123
+ join = " OR "
124
+ else:
125
+ from config.config import Config
126
+ _quote = '`' if Config.BACKTIC_AS_QUOTE else '"'
127
+ attr = ""
128
+ if f in clz._s_jsonapi_attrs and f != "id":
129
+ attr = clz._s_jsonapi_attrs[f]._proxy_key
130
+ elif f == "id":
131
+ attr = f'{_quote}{clz.__tablename__}{_quote}.{_quote}id{_quote}'
132
+ _quote = ""
133
+ elif attr == "":
134
+ attr = f'{_quote}{clz.__tablename__}{_quote}.{_quote}{f}{_quote}'
135
+ _quote = ""
136
+ q = "'" if isinstance(value, str) else ""
137
+ sql_where += f'{join} {_quote}{attr}{_quote} = {q}{value}{q}'
138
+ #name = clz._s_jsonapi_attrs[f] if f !: "id" else clz.id
139
+ filters.append({"join": join,"lop": attr, "op": "eq", "rop": value})
140
+ join = " AND "
141
+
142
+ return sql_where, filters
143
+
144
+ def fixup_sort(clz, data):
145
+ sort = None
146
+ if data and isinstance(data, list):
147
+ for d in data:
148
+ sort = []
149
+ column_name = d["columnName"]
150
+ for attr_name, value in clz._s_jsonapi_attrs.items():
151
+ if column_name.upper() == attr_name.upper():
152
+ sort.append({"columnName":attr_name, "ascendent": d["ascendent"]})
153
+ continue
154
+ return sort
155
+ def fixup_data(data, sqltypes):
156
+ new_data = None
157
+ if data and isinstance(data, dict):
158
+ new_data = {}
159
+ for key, value in data.items():
160
+ new_data[key] = value
161
+ if sqltypes and key in sqltypes and isinstance(value, str):
162
+ if sqltypes[key] in [-5,2,4,5,-6]: #BIGINT, TINYINT, INT, SMALLINT, INTEGER
163
+ if new_data[key].isdigit():
164
+ new_data[key] = int(value)
165
+ else:
166
+ del new_data[key]
167
+ elif sqltypes[key] in [6]: #DECIMAL
168
+ new_data[key] = Decimal(value)
169
+ if sqltypes and key in sqltypes and sqltypes[key] in [91,93] and isinstance(value, int): #DATE, TIMESTAMP
170
+ from datetime import datetime
171
+ fmt = "%Y-%m-%d" if sqltypes[key] == 91 else "%Y-%m-%d %H:%M:%S"
172
+ new_data[key] = datetime.fromtimestamp(value / 1000) #.strftime(fmt)
173
+ return new_data
174
+
175
+ def _parseFilter(filter: dict, sqltypes: any):
176
+ # {filter":{"@basic_expression":{"lop":"BALANCE","op":"<=","rop":35000}}
177
+ filter_result = ""
178
+ a = ""
179
+ for f, value in filter.items():
180
+ q = "'"
181
+ # {'lop': 'CustomerId', 'op': 'LIKE', 'rop': '%A%'}}
182
+ if f == BASIC_EXPRESSION and "lop" in value.keys() and "rop" in value.keys():
183
+ lop = value["lop"]
184
+ op = value["op"]
185
+ rop = f"{q}{value['rop']}{q}"
186
+ return f'"{lop}" {op} {rop}'
187
+ else:
188
+ q = "'" if isinstance(value, str) else ""
189
+ filter_result += f'{a} "{f}" = {q}{value}{q}'
190
+ a = " and "
191
+ return None if filter_result == "" else filter_result
192
+
193
+ class ExpressionHolder():
194
+ def __init__(self, expr: any, join: str):
195
+ self.expr = expr
196
+ self.join = join
197
+
198
+ class BasicExpression:
199
+ def __init__(self, lop: any = None, op: str = None, rop: any = None, sqltypes = None):
200
+ self.lop_ext = []
201
+ self.rop_ext = []
202
+ self.sql_where = ""
203
+ self.join_condition = ""
204
+ self.sqltypes = sqltypes
205
+ self.filters = []
206
+
207
+ # Left Operator
208
+ if isinstance(lop, dict):
209
+ _lop = lop["lop"]
210
+ _op = lop["lop"]["op"] if hasattr(lop, "op") else lop["op"]
211
+ _rop = lop["lop"]["rop"] if hasattr(lop, "rop") else lop["rop"]
212
+
213
+ be = BasicExpression(_lop, _op, _rop)
214
+ be.join_condition = _op
215
+ self.lop_ext.append(be)
216
+ # Right Operator
217
+ if isinstance(rop, dict):
218
+ _lop = rop["lop"]
219
+ _op = rop["lop"]["op"] if hasattr(rop, "op") else rop["op"]
220
+ _rop = rop["lop"]["rop"] if hasattr(rop, "rop") else rop["rop"]
221
+
222
+ be = BasicExpression(_lop, _op, _rop)
223
+ be.join_condition = _op
224
+ self.rop_ext.append(be)
225
+ #basic {lop: "BALANCE", op: "<=", rop: 35000}
226
+ attr_name = lop
227
+ #if attr_name !: "id" and attr_name not in cls._s_jsonapi_attrs:
228
+ # raise ValidationError(f'Invalid filter "lop:{lop}, op: {op}, rop: {rop}", unknown attribute "{attr_name}"')
229
+ #attr = clz._s_jsonapi_attrs[attr_name] if attr_name !: "id" else clz.id
230
+ ont_op = self.get_ontimize_operator(op)
231
+ self.lop = attr_name
232
+ self.op = ont_op
233
+ self.rop = rop
234
+
235
+ def get_ontimize_operator(self, op: str = '='):
236
+ op_ = op.strip().upper()
237
+ return ONTIMIZE_OPERATORS[op_] if op_ in ONTIMIZE_OPERATORS else op_
238
+
239
+ def get_sql_where(self):
240
+ self.where(self)
241
+ return self.sql_where
242
+
243
+ def where(self, expr):
244
+ if isinstance(expr, BasicExpression):
245
+ for row in expr.lop_ext:
246
+ self.where(row)
247
+ for row in expr.rop_ext:
248
+ self.where(row)
249
+
250
+ if isinstance(expr.lop, str) and not isinstance(expr.rop, dict):
251
+ self.sql_where += self._parseExpression(expr=expr)
252
+ self.join_condition = " OR "
253
+
254
+ def _parseExpression(self, expr) -> str:
255
+ if expr.op != None and expr.rop != None:
256
+ value = expr.rop
257
+
258
+ if self.sqltypes and expr.lop in self.sqltypes and self.sqltypes[expr.lop] in [91,93]:
259
+ from datetime import datetime
260
+ if self.sqltypes[expr.lop] == 93:
261
+ value = datetime.fromtimestamp(value / 1000).strftime("%Y-%m-%d %H:%M:%S")
262
+ else:
263
+ value = datetime.fromtimestamp(value / 1000).strftime("%Y-%m-%d")
264
+ q = "" if expr.is_numeric(value) else "'"
265
+
266
+ self.filters.append({"join": self.join_condition,"lop": expr.lop, "op": expr.op, "rop": f"{q}{value}{q}"})
267
+ return f'{self.join_condition} "{expr.lop}" {expr.op} {q}{value}{q}'
268
+ return ""
269
+
270
+ def is_numeric(self, value):
271
+ return False if value and isinstance(value, str) else True
272
+ def convert_attrname(attrname, attrs):
273
+ return next(
274
+ (a[0] for a in attrs.items() if a[0].upper() == attrname.upper()),
275
+ attrname,
276
+ )
277
+ def advancedFilter(cls, args) -> any:
278
+ filters = []
279
+ expressions = []
280
+ from safrs import ValidationError
281
+ import re
282
+ import urllib.parse
283
+ import operator
284
+ sqlWhere = ""
285
+ for req_arg, item in args.items():
286
+ if not req_arg.startswith("filter"):
287
+ continue
288
+ try:
289
+ val = item
290
+ if isinstance(item, str):
291
+ val = json.loads(item)
292
+ except Exception as e:
293
+ print(f"json load filter item: {item} exception:",e)
294
+ val = item
295
+
296
+ if isinstance(val, list):
297
+ # this is from sra ? default and/or to join
298
+ # '[{"name":"Id","op":"ilike","val":"%AL%"},{"name":"CompanyName","op":"ilike","val":"%AL%"}]'
299
+ for item in val:
300
+ name = item['name']
301
+ attr = cls._s_jsonapi_attrs[name] if name !="id" else cls.id
302
+ op = item['op'].lower()
303
+ if op in ["in"]:
304
+ expressions.append(attr.in_(item['val']))
305
+ elif op in ["like","ilike"]:
306
+ expressions.append(attr.like( item['val']))
307
+ else:
308
+ expressions.append(attr.eq(clean(item['val'])))
309
+ for e in expressions : print(e," : ", e.right.value)
310
+ return expressions, sqlWhere
311
+ else:
312
+ if isinstance(val, dict):
313
+ #if FILTER_EXPRESSION in item or BASIC_EXPRESSION in item:
314
+ if "filter" in val:
315
+ # Ontimize Advanced Filter
316
+ #{'lop': 'CustomerId', 'op': 'LIKE', 'rop': '%A%'}
317
+ #TODO - modify this to return expressions (and_ & or_)
318
+ sqlWhere, filters = parseFilter(cls, val['filter'], None)
319
+ return expressions, sqlWhere
320
+ elif "@basic_expression" in val:
321
+ sqlWhere = _parseFilter(val, None)
322
+ return expressions, sqlWhere
323
+ elif req_arg == 'filter[@basic_expression]' or req_arg == 'filter[@BASIC_EXPRESSION]':
324
+ filters.append({"lop": val['lop'], "op": val["op"], "rop": val["rop"]})
325
+ elif "rop" in val:
326
+ filters.append(val)
327
+ else:
328
+ #{'id': '1', 'name': 'John'}
329
+ for f, value in val.items():
330
+ filters.append({"lop": f, "op": "eq", "rop": value})
331
+
332
+ not_in_filter = re.search(r"filter\[(\w+)\]\[(\w+)\]", req_arg)
333
+ json_filter = filter_attr = re.search(r"filter\[(\w+)\]", req_arg)
334
+ equal_exp = filter_attr = re.search(r"equal\((\w+),(\w+)\)", req_arg)
335
+ notequal_exp = filter_attr = re.search(r"notequal\((\w+),(\w+)\)", req_arg)
336
+ if json_filter:
337
+ #filter[attrname]=value
338
+ name = json_filter.group(1)
339
+ op = "eq"
340
+ filters.append({"lop": name, "op": op, "rop": val})
341
+
342
+ elif not_in_filter:
343
+ #filter[attrname][in| notin]=value
344
+ name = not_in_filter.group(1)
345
+ op = not_in_filter.group(2)
346
+ if op in ["in", "notin"]:
347
+ val = json.loads(val)
348
+ filters.append({"lop": name, "op": op, "rop": val})
349
+ elif equal_exp:
350
+ #equal(attrname,value)
351
+ name = equal_exp.group(1)
352
+ attr_val = equal_exp.group(2)
353
+ filters.append({"lop": name, "op": "eq", "rop": attr_val})
354
+ elif notequal_exp:
355
+ #notequal(attrname,value)
356
+ name = notequal_exp.group(1)
357
+ attr_val = notequal_exp.group(2)
358
+ filters.append({"lop": name, "op": "ne", "rop": attr_val})
359
+ else:
360
+ #attrname=value
361
+ if filter_attr and filter_attr not in ["page","orderBy","pageSize","offset","limit","sort","order","fields","include"]:
362
+ filters.append({"lop": req_arg, "op": "eq", "rop": val})
363
+
364
+ #query = cls._s_query
365
+ join = ""
366
+ expression_holder= []
367
+ for flt in filters:
368
+ attr_name = convert_attrname(flt.get("lop"), cls._s_jsonapi_attrs)
369
+ attr_val = flt.get("rop")
370
+ if attr_name not in ["id","ID","Id"] and attr_name not in cls._s_jsonapi_attrs:
371
+ raise ValidationError(f'Invalid filter "{flt}", unknown attribute "{attr_name}"')
372
+ if attr_name in ["id","ID","Id"]:
373
+ for a in cls._s_jsonapi_attrs.items():
374
+ if "primary_key=True" in str(a):
375
+ attr_name = a[0]
376
+ op_name = flt.get("op", "").strip().upper()
377
+ if op_name not in ONTIMIZE_OPERATORS:
378
+ raise ValidationError(f'Invalid filter {flt}, unknown operator: {op_name}')
379
+ #join = flt.get("join", "").strip("_").lower()
380
+ attr = cls._s_jsonapi_attrs[attr_name] if attr_name != "id" else cls.id
381
+ if op_name in ["IN"]:
382
+ expr = ExpressionHolder(expr=attr.in_(clean(attr_val)), join=join)
383
+ expression_holder.append(expr)
384
+ elif op_name in ["LIKE", "ILIKE", "MATCH"]:
385
+ expressions.append(attr.ilike( clean(attr_val) ))
386
+ expr = ExpressionHolder(expr=attr.ilike(clean(attr_val)), join=join)
387
+ expression_holder.append(expr)
388
+ sqlWhere += f'{join} "{attr_name}" LIKE {clean(attr_val)}'
389
+ elif op_name in ["NOTLIKE","NOTIN"]:
390
+ expr = ExpressionHolder(expr=attr.not_in_(clean(attr_val)), join=join)
391
+ expression_holder.append(expr)
392
+ elif op_name in ["EQ","NE","LT","LE","GT","GE"]:
393
+ op = ONTIMIZE_OPERATORS[op_name] if op_name in ONTIMIZE_OPERATORS else "="
394
+ sqlWhere += f'{join} "{attr_name}" {op} {clean(attr_val)}'
395
+ elif op_name in ["NULL","IS_NULL","NOTNULL","NOT_NULL"]:
396
+ op = ONTIMIZE_OPERATORS[op_name] if op_name in ONTIMIZE_OPERATORS else "IS NULL"
397
+ sqlWhere += f'{join} "{attr_name}" {op}'
398
+ join = " AND " if join == "" else join
399
+ final_expr = []
400
+ expressions = []
401
+ for expr in expression_holder:
402
+ join = expr.join
403
+ expressions.append(expr.expr)
404
+ if 'or' in join:
405
+ final_expr.append(OR_(*expr.expr))
406
+ elif 'and' in join:
407
+ final_expr.append(AND_(*expr.expr))
408
+ else:
409
+ final_expr.append(expr.expr)
410
+ for e in expressions : print(e," : ", e.right.value)
411
+ return expressions, sqlWhere #query.filter(or_(*expressions))
412
+
413
+ def clean(val):
414
+ if val and isinstance(val, str) and (val.startswith("'") and val.endswith("'")):
415
+ return f"'{val[1:-1 ]}'"
416
+ elif val and isinstance(val, str) and (val.startswith('"') and val.endswith('"')):
417
+ return f"'{val[1:-1 ]}'"
418
+ elif val and isinstance(val, str):
419
+ return f"'{val}'"
420
+ else:
421
+ return val
422
+
423
+ class ExpressionParser:
424
+
425
+ def __init__(self, filter, expression_type, sqltypes=None):
426
+ self.basic_expr = None
427
+ self.filter = self.parse(filter, expression_type)
428
+ self.build_sql_where(sqltypes)
429
+ self.expressions = []
430
+
431
+ def get_expr(self):
432
+ # return self.build_sql_where(self.basic_expr) if self.basic_expr else "1=1"
433
+ self.build_sql_where(self.basic_expr)
434
+
435
+ def get_filters(self):
436
+ return self.basic_expr.filters if self.basic_expr else []
437
+
438
+ def get_expressions(self):
439
+ return self.basic_expr.expressions if self.basic_expr else []
440
+
441
+ def parse(self, filter, expression_type):
442
+ if isinstance(filter, dict):
443
+ return next(
444
+ (filter[f] for f in filter if f in [expression_type]),
445
+ None,
446
+ )
447
+ return filter
448
+
449
+ def get_sql_where(self):
450
+ return self.basic_expr.get_sql_where() if self.basic_expr else "1=1"
451
+
452
+ def build_sql_where(self, sqltypes=None):
453
+ expr = self.filter
454
+ if expr is None:
455
+ return
456
+ lop = expr["lop"]
457
+ op = expr["op"].lower()
458
+ rop = expr["rop"]
459
+
460
+ self.basic_expr = BasicExpression(lop, op, rop, sqltypes)
461
+
462
+
463
+ if __name__ == "__main__":
464
+
465
+ filter = {
466
+ "@basic_expression": {
467
+ "lop": {
468
+ "lop": {
469
+ "lop": {
470
+ "lop": {
471
+ "lop": {
472
+ "lop": "FirstName",
473
+ "op": "LIKE",
474
+ "rop": "%St%",
475
+ },
476
+ "op": "OR",
477
+ "rop": {
478
+ "lop": "LastName",
479
+ "op": "LIKE",
480
+ "rop": "%G%",
481
+ },
482
+ },
483
+ "op": "OR",
484
+ "rop": {
485
+ "lop": "City",
486
+ "op": "eq",
487
+ "rop": "London",
488
+ },
489
+ },
490
+ "op": "OR",
491
+ "rop": {"lop": "Country", "op": "eq", "rop": "UK"},
492
+ },
493
+ "op": "OR",
494
+ "rop": {"lop": "Title", "op": "LIKE", "rop": "Sales%"},
495
+ },
496
+ "op": "AND",
497
+ "rop": {"lop": "LastName", "op": "NOT LIKE", "rop": "%B%"},
498
+ }
499
+ }
500
+
501
+ # {'filter': {'@basic_expression': {'lop': {'lop': {'lop': {'lop': {'lop': {'lop': 'EMPLOYEENAME', 'op': 'LIKE', 'rop': '%fort%'}, 'op': 'OR', 'rop': {'lop': 'EMPLOYEESURNAME', 'op': 'LIKE', 'rop': '%fort%'}}, 'op': 'OR', 'rop': {'lop': 'EMPLOYEEADDRESS', 'op': 'LIKE', 'rop': '%fort%'}}, 'op': 'OR', 'rop': {'lop': 'EMPLOYEEEMAIL', 'op': 'LIKE', 'rop': '%fort%'}}, 'op': 'OR', 'rop': {'lop': 'OFFICEID', 'op': 'LIKE', 'rop': '%fort%'}}, 'op': 'AND', 'rop': {'lop': 'EMPLOYEENAME', 'op': 'LIKE', 'rop': '%pamella%'}}}, 'columns': ['EMPLOYEEID', 'EMPLOYEETYPEID', 'EMPLOYEENAME', 'EMPLOYEESURNAME', 'EMPLOYEEADDRESS', 'EMPLOYEESTARTDATE', 'EMPLOYEEEMAIL', 'OFFICEID', 'EMPLOYEEPHOTO', 'EMPLOYEEPHONE', 'NAME'], 'sqltypes': {}, 'offset': 0, 'pageSize': 16, 'orderBy': []}
502
+ simple = {
503
+ "filter": {"@basic_expression": {"lop": "BALANCE", "op": "<=", "rop": 35000}}
504
+ }
505
+ filter_expr = {
506
+ "filter": {
507
+ "@filter_expression": {
508
+ "lop": {
509
+ "lop": {
510
+ "lop": {
511
+ "lop": {
512
+ "lop": "SURNAME",
513
+ "op": "=",
514
+ "rop": "Christopoulos",
515
+ },
516
+ "op": "OR",
517
+ "rop": {
518
+ "lop": "SURNAME",
519
+ "op": "=",
520
+ "rop": "Vazquez Santos",
521
+ },
522
+ },
523
+ "op": "OR",
524
+ "rop": {"lop": "SURNAME", "op": "=", "rop": "Santos Rodríguez"},
525
+ },
526
+ "op": "OR",
527
+ "rop": {"lop": "SURNAME", "op": "=", "rop": "Dominguez "},
528
+ },
529
+ "op": "AND",
530
+ "rop": {
531
+ "lop": {"lop": "STARTDATE", "op": "=", "rop": 1279152000000},
532
+ "op": "OR",
533
+ "rop": {"lop": "STARTDATE", "op": "=", "rop": 1278460800000},
534
+ },
535
+ }
536
+ }
537
+ }
538
+ full_expr = {
539
+ "filter": {
540
+ "@filter_expression": {
541
+ "lop": {
542
+ "lop": {
543
+ "lop": {
544
+ "lop": {
545
+ "lop": "SURNAME",
546
+ "op": "=",
547
+ "rop": "Christopoulos",
548
+ },
549
+ "op": "OR",
550
+ "rop": {
551
+ "lop": "SURNAME",
552
+ "op": "=",
553
+ "rop": "Vazquez Santos",
554
+ },
555
+ },
556
+ "op": "OR",
557
+ "rop": {"lop": "SURNAME", "op": "=", "rop": "Santos Rodríguez"},
558
+ },
559
+ "op": "OR",
560
+ "rop": {"lop": "SURNAME", "op": "=", "rop": "Dominguez"},
561
+ },
562
+ "op": "AND",
563
+ "rop": {
564
+ "lop": {"lop": "STARTDATE", "op": "=", "rop": 1279152000000},
565
+ "op": "OR",
566
+ "rop": {"lop": "STARTDATE", "op": "=", "rop": 1278460800000},
567
+ },
568
+ },
569
+ "@basic_expression": {
570
+ "lop": {
571
+ "lop": {
572
+ "lop": {"lop": "NAME", "op": "LIKE", "rop": "%name%"},
573
+ "op": "OR",
574
+ "rop": {"lop": "SURNAME", "op": "LIKE", "rop": "%surname%"},
575
+ },
576
+ "op": "OR",
577
+ "rop": {"lop": "EMAIL", "op": "LIKE", "rop": "%email%"},
578
+ },
579
+ "op": "OR",
580
+ "rop": {"lop": "ADDRESS", "op": "LIKE", "rop": "%address%"},
581
+ },
582
+ },
583
+ "columns": [
584
+ "CUSTOMERID",
585
+ "NAME",
586
+ "SURNAME",
587
+ "ADDRESS",
588
+ "STARTDATE",
589
+ "EMAIL",
590
+ "CUSTOMERTYPEID",
591
+ ],
592
+ "sqltypes": {
593
+ "SURNAME": 12,
594
+ "CUSTOMERID": 4,
595
+ "STARTDATE": 93,
596
+ "ADDRESS": 12,
597
+ "EMAIL": 12,
598
+ },
599
+ "offset": 0,
600
+ "pageSize": 24,
601
+ "orderBy": [{"columnName": "SURNAME", "ascendent": False}],
602
+ }
603
+ # fltr = json.loads(filter)
604
+ #ep = ExpressionParser(simple["filter"])
605
+ #ep = ExpressionParser(filter["filter"])
606
+ # print(ep.generate_sql_where(filter))
607
+ # print(ep.get_sql_where())
608
+ # ep = ExpressionParser(filter_expr["filter"])
609
+ # print(ep.get_sql_where())
610
+
611
+ #filter, columns, sqltypes, offset, pagesize, orderBy, data = parsePayload(full_expr)
612
+ #print(filter)
613
+
614
+ ''' TEST CASES
615
+ No Filter
616
+ filter[AttrName]=Value (numeric)
617
+ where “AttrName” like :parm_1 [Value]
618
+ filter[AttrName][like]=”%value%” (string)
619
+ where “AttrName” like :parm_1 [‘%Value%’]
620
+ filter[AttrName]=value (date or timestamp)
621
+ where “AttrName” like :parm_1 [‘YYYY-mm-dd’]
622
+ filter[AttrName][in]=”(a,b,c)”
623
+ where “AttrName” in :parm_1 [ ‘(a,b,c)’ ]
624
+ filter[AttrName]=”Value”&filter[AttrName2]=”%Value1%”
625
+ where “AttrName” like :parm_1 or “AttrName2” like :parm_2 [Value,Value1]
626
+ filter={“lop”:”AttrName”,”op”:”eq”,”rop”:”Value”}
627
+ where “AttrName” = :parm_1 [value]
628
+ [{“lop”:”AttrName”,”op”:”ilike”,”val”:”%val%”}] #safrs search
629
+ where "Attrname" like :parm_1 [‘%val%’]
630
+
631
+ '''
632
+ filter2 = {
633
+ "@basic_expression": {
634
+ "lop": {
635
+ "lop": {
636
+ "lop": {
637
+ "lop": {
638
+ "lop": {
639
+ "lop": "EMPLOYEENAME",
640
+ "op": "LIKE",
641
+ "rop": "%empname%",
642
+ },
643
+ "op": "OR",
644
+ "rop": {
645
+ "lop": "EMPLOYEESURNAME",
646
+ "op": "LIKE",
647
+ "rop": "%surname%",
648
+ },
649
+ },
650
+ "op": "OR",
651
+ "rop": {
652
+ "lop": "EMPLOYEEADDRESS",
653
+ "op": "LIKE",
654
+ "rop": "%address%",
655
+ },
656
+ },
657
+ "op": "OR",
658
+ "rop": {"lop": "EMPLOYEEEMAIL", "op": "LIKE", "rop": "%email%"},
659
+ },
660
+ "op": "OR",
661
+ "rop": {"lop": "OFFICEID", "op": "LIKE", "rop": "%officeid%"},
662
+ },
663
+ "op": "AND",
664
+ "rop": {"lop": "EMPLOYEENAME", "op": "LIKE", "rop": "%pamella%"},
665
+ }
666
+ }
667
+ filter = {"filter":{"@filter_expression":{"lop":{"lop":"Id","op":"eq","rop":10259},"op":"and","rop":{"lop":"CustomerId","op":"eq","rop":"CENTC"}}}}
668
+ filter = 'filter[@basic_expression]={"lop":{"lop":{"lop":{"lop":"NAME","op":"LIKE","rop":"%25ala%25"},"op":"OR","rop":{"lop":"SURNAME","op":"LIKE","rop":"%25ala%25"}},"op":"OR","rop":{"lop":"EMAIL","op":"LIKE","rop":"%25ala%25"}},"op":"OR","rop":{"lop":"ADDRESS","op":"LIKE","rop":"%25ala%25"}}'
669
+ filter = {"filter":{"@basic_expression":
670
+ {"lop":{"lop":{"lop":
671
+ {"lop":"CompanyName","op":"LIKE","rop":"%25Al%25"},"op":"OR","rop":
672
+ {"lop":"ContactName","op":"LIKE","rop":"%25A%25"}},"op":"OR","rop":
673
+ {"lop":"OrderCount","op":"NE","rop": 1}},"op":"OR","rop":
674
+ {"lop":"Country","op":"IS_NULL","rop":""}}}}
675
+ import urllib
676
+ #print(urllib.parse.quote(json.dumps(filter)))
677
+ x = urllib.parse.quote("filter[FirstName][like]A")
678
+ #print(x)
679
+ # from database.models import models
680
+ #filter = {"filter": {"@basic_expression": {"lop": "BALANCE", "op": "=", "rop": 35000}}}
681
+ print(urllib.parse.quote(json.dumps(filter)))
682
+ sqlWhere, filters, expressions = parseFilter(None, filter,None)
683
+ print(sqlWhere)
684
+ print(filters)
685
+ print(expressions)