gibson-cli 0.8.0__tar.gz → 0.8.2__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 (148) hide show
  1. {gibson_cli-0.8.0/gibson_cli.egg-info → gibson_cli-0.8.2}/PKG-INFO +13 -10
  2. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/README.md +12 -9
  3. gibson_cli-0.8.2/bin/build.sh +1 -0
  4. gibson_cli-0.8.2/bin/release.sh +5 -0
  5. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/api/BaseApi.py +3 -3
  6. gibson_cli-0.8.2/gibson/api/DataApi.py +18 -0
  7. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/api/ProjectApi.py +2 -2
  8. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/bin/gibson.py +5 -0
  9. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Version.py +1 -1
  10. gibson_cli-0.8.2/gibson/services/mcp/server.py +136 -0
  11. {gibson_cli-0.8.0 → gibson_cli-0.8.2/gibson_cli.egg-info}/PKG-INFO +13 -10
  12. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson_cli.egg-info/SOURCES.txt +1 -1
  13. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/pyproject.toml +1 -1
  14. gibson_cli-0.8.0/bin/build.sh +0 -2
  15. gibson_cli-0.8.0/bin/gibson +0 -26
  16. gibson_cli-0.8.0/bin/release.sh +0 -1
  17. gibson_cli-0.8.0/gibson/services/mcp/server.py +0 -87
  18. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/.gitignore +0 -0
  19. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/.pre-commit-config.yaml +0 -0
  20. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/bin/clean.sh +0 -0
  21. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/api/Cli.py +0 -0
  22. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/BaseCommand.py +0 -0
  23. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Build.py +0 -0
  24. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Conf.py +0 -0
  25. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Count.py +0 -0
  26. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Dev.py +0 -0
  27. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Forget.py +0 -0
  28. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Help.py +0 -0
  29. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Merge.py +0 -0
  30. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Modify.py +0 -0
  31. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Question.py +0 -0
  32. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Remove.py +0 -0
  33. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Show.py +0 -0
  34. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/Tree.py +0 -0
  35. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/auth/Auth.py +0 -0
  36. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/auth/Login.py +0 -0
  37. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/auth/Logout.py +0 -0
  38. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Api.py +0 -0
  39. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Base.py +0 -0
  40. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Code.py +0 -0
  41. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Entity.py +0 -0
  42. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Model.py +0 -0
  43. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Models.py +0 -0
  44. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Schema.py +0 -0
  45. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Schemas.py +0 -0
  46. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Test.py +0 -0
  47. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/code/Tests.py +0 -0
  48. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/importer/Import.py +0 -0
  49. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/importer/OpenApi.py +0 -0
  50. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/list/Entities.py +0 -0
  51. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/list/List.py +0 -0
  52. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/list/Projects.py +0 -0
  53. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/mcp/McpServer.py +0 -0
  54. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/new/Module.py +0 -0
  55. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/new/New.py +0 -0
  56. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/new/Project.py +0 -0
  57. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/rename/Entity.py +0 -0
  58. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/rename/Rename.py +0 -0
  59. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/rewrite/Rewrite.py +0 -0
  60. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/tests/test_command_BaseCommand.py +0 -0
  61. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/command/tests/test_command_Conf.py +0 -0
  62. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Api.py +0 -0
  63. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Code.py +0 -0
  64. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Custom.py +0 -0
  65. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Datastore.py +0 -0
  66. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Dependencies.py +0 -0
  67. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Dev.py +0 -0
  68. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Frameworks.py +0 -0
  69. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Modeler.py +0 -0
  70. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Paths.py +0 -0
  71. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Platform.py +0 -0
  72. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Project.py +0 -0
  73. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/Version.py +0 -0
  74. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/dev/Api.py +0 -0
  75. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/dev/Base.py +0 -0
  76. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/dev/Model.py +0 -0
  77. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/dev/Schema.py +0 -0
  78. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/tests/test_conf_Dependencies.py +0 -0
  79. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/conf/tests/test_conf_Platform.py +0 -0
  80. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Colors.py +0 -0
  81. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/CommandRouter.py +0 -0
  82. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Completions.py +0 -0
  83. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Configuration.py +0 -0
  84. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Conversation.py +0 -0
  85. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Diff.py +0 -0
  86. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Env.py +0 -0
  87. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Memory.py +0 -0
  88. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/PythonPath.py +0 -0
  89. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/Spinner.py +0 -0
  90. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/TimeKeeper.py +0 -0
  91. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/core/utils.py +0 -0
  92. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/data/bash-completion.tmpl +0 -0
  93. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/data/mysql/default-ref-table.tmpl +0 -0
  94. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/data/mysql/default-table.tmpl +0 -0
  95. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/data/postgresql/default-ref-table.tmpl +0 -0
  96. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/data/postgresql/default-table.tmpl +0 -0
  97. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/db/TableExceptions.py +0 -0
  98. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/db/tests/test_db_TableExceptions.py +0 -0
  99. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/dev/Dev.py +0 -0
  100. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/Header.py +0 -0
  101. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/WorkspaceFooter.py +0 -0
  102. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/WorkspaceHeader.py +0 -0
  103. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/tests/test_display_Header.py +0 -0
  104. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/tests/test_display_WorkspaceFooter.py +0 -0
  105. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/display/tests/test_display_WorkspaceHeader.py +0 -0
  106. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/lang/Python.py +0 -0
  107. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/lang/tests/test_lang_Python.py +0 -0
  108. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/auth/Server.py +0 -0
  109. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/DataDictionary.py +0 -0
  110. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/EntityKeys.py +0 -0
  111. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/Manager.py +0 -0
  112. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/tests/test_code_context_schema_DataDictionary.py +0 -0
  113. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/tests/test_code_context_schema_EntityKeys.py +0 -0
  114. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/context/schema/tests/test_code_context_schema_Manager.py +0 -0
  115. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/Authenticator.py +0 -0
  116. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/BaseCustomization.py +0 -0
  117. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/CustomizationManager.py +0 -0
  118. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/Index.py +0 -0
  119. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/tests/test_code_customization_Authenticator.py +0 -0
  120. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/services/code/customization/tests/test_code_customization_BaseCustomization.py +0 -0
  121. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/Entity.py +0 -0
  122. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/Entity.py +0 -0
  123. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/constraints/ReferenceConstraint.py +0 -0
  124. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/ForeignKey.py +0 -0
  125. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/Index.py +0 -0
  126. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/IndexAttribute.py +0 -0
  127. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/tests/test_structure_mysql_keys_ForeignKey.py +0 -0
  128. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/tests/test_structure_mysql_keys_Index.py +0 -0
  129. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/keys/tests/test_structure_mysql_keys_IndexAttribute.py +0 -0
  130. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/testing.py +0 -0
  131. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/mysql/tests/test_structure_mysql_Entity.py +0 -0
  132. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/Entity.py +0 -0
  133. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/References.py +0 -0
  134. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/table/ForeignKey.py +0 -0
  135. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/table/tests/test_structure_postgresql_table_ForeignKey.py +0 -0
  136. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/testing.py +0 -0
  137. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/postgresql/tests/test_structure_postgresql_Entity.py +0 -0
  138. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/structure/tests/test_structure_Entity.py +0 -0
  139. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/tests/test_Env.py +0 -0
  140. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/tests/test_Memory.py +0 -0
  141. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson/tests/test_utils.py +0 -0
  142. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson_cli.egg-info/dependency_links.txt +0 -0
  143. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson_cli.egg-info/entry_points.txt +0 -0
  144. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson_cli.egg-info/requires.txt +0 -0
  145. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/gibson_cli.egg-info/top_level.txt +0 -0
  146. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/requirements.txt +0 -0
  147. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/setup.cfg +0 -0
  148. {gibson_cli-0.8.0 → gibson_cli-0.8.2}/venv/bin/activate_this.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: gibson-cli
3
- Version: 0.8.0
3
+ Version: 0.8.2
4
4
  Summary: Gibson Command Line Interface
5
5
  Author-email: GibsonAI <noc@gibsonai.com>
6
6
  Project-URL: Homepage, https://gibsonai.com/
@@ -73,7 +73,6 @@ Requires-Dist: watchfiles==0.21.0
73
73
  Requires-Dist: websockets==12.0
74
74
  Requires-Dist: yaspin==3.1.0
75
75
 
76
-
77
76
  [![GibsonAI](https://github.com/user-attachments/assets/26bc1002-f878-4995-a6c5-eb8d5eb69c28)](https://gibsonai.com/)
78
77
 
79
78
  # Gibson CLI
@@ -90,19 +89,23 @@ Portions of the Gibson backend code are written by Gibson. So far, versus a hum
90
89
 
91
90
  ## Installation / Upgrading
92
91
 
93
- Install the latest version of the CLI using `pip`
92
+ ### With [uv](https://docs.astral.sh/uv/) (recommended)
94
93
 
95
94
  ```sh
96
- pip3 install gibson-cli --upgrade
95
+ uv tool install gibson-cli@latest
97
96
  ```
98
97
 
99
- Note: the first time you install any package from PyPI via `pip` that includes an executable, it is placed in a directory that is likely not in your `PATH`. There are a number of ways to do this, but one method is to run the following command:
98
+ If you're unable to run `gibson` after installing with uv, try running `uv tool update-shell` to ensure your `PATH` includes the uv tool executables directory.
99
+
100
+ ### With pip
100
101
 
101
102
  ```sh
102
- echo 'export PATH="$PATH:${$(which python3)%python3}"' >> ~/.zshrc # or ~/.bashrc
103
+ pip3 install gibson-cli --upgrade
103
104
  ```
104
105
 
105
- You will only need to do this once.
106
+ Note: you'll want to run this **outside** of a virtual environment (globally on your machine)
107
+
108
+ If you're unable to run `gibson` after installing with pip, ensure your `PATH` contains the directory where pip installs executables. This can differ based on your operating system, python installation location, and pip version.
106
109
 
107
110
  ## Key Terms
108
111
 
@@ -390,8 +393,8 @@ Update the configuration to look like the following:
390
393
  {
391
394
  "mcpServers": {
392
395
  "gibson": {
393
- "command": "gibson",
394
- "args": ["mcp", "run"]
396
+ "command": "uvx",
397
+ "args": ["--from", "gibson-cli@latest", "gibson", "mcp", "run"]
395
398
  }
396
399
  }
397
400
  }
@@ -402,4 +405,4 @@ That's it! Just make sure you're logged in to the CLI (if you're reading this, y
402
405
  ## Contributing
403
406
 
404
407
  - Clone this repository somewhere in your file system
405
- - `pip3 install [path to this repository]`
408
+ - `uv tool install [path to repository] -e`
@@ -1,4 +1,3 @@
1
-
2
1
  [![GibsonAI](https://github.com/user-attachments/assets/26bc1002-f878-4995-a6c5-eb8d5eb69c28)](https://gibsonai.com/)
3
2
 
4
3
  # Gibson CLI
@@ -15,19 +14,23 @@ Portions of the Gibson backend code are written by Gibson. So far, versus a hum
15
14
 
16
15
  ## Installation / Upgrading
17
16
 
18
- Install the latest version of the CLI using `pip`
17
+ ### With [uv](https://docs.astral.sh/uv/) (recommended)
19
18
 
20
19
  ```sh
21
- pip3 install gibson-cli --upgrade
20
+ uv tool install gibson-cli@latest
22
21
  ```
23
22
 
24
- Note: the first time you install any package from PyPI via `pip` that includes an executable, it is placed in a directory that is likely not in your `PATH`. There are a number of ways to do this, but one method is to run the following command:
23
+ If you're unable to run `gibson` after installing with uv, try running `uv tool update-shell` to ensure your `PATH` includes the uv tool executables directory.
24
+
25
+ ### With pip
25
26
 
26
27
  ```sh
27
- echo 'export PATH="$PATH:${$(which python3)%python3}"' >> ~/.zshrc # or ~/.bashrc
28
+ pip3 install gibson-cli --upgrade
28
29
  ```
29
30
 
30
- You will only need to do this once.
31
+ Note: you'll want to run this **outside** of a virtual environment (globally on your machine)
32
+
33
+ If you're unable to run `gibson` after installing with pip, ensure your `PATH` contains the directory where pip installs executables. This can differ based on your operating system, python installation location, and pip version.
31
34
 
32
35
  ## Key Terms
33
36
 
@@ -315,8 +318,8 @@ Update the configuration to look like the following:
315
318
  {
316
319
  "mcpServers": {
317
320
  "gibson": {
318
- "command": "gibson",
319
- "args": ["mcp", "run"]
321
+ "command": "uvx",
322
+ "args": ["--from", "gibson-cli@latest", "gibson", "mcp", "run"]
320
323
  }
321
324
  }
322
325
  }
@@ -327,4 +330,4 @@ That's it! Just make sure you're logged in to the CLI (if you're reading this, y
327
330
  ## Contributing
328
331
 
329
332
  - Clone this repository somewhere in your file system
330
- - `pip3 install [path to this repository]`
333
+ - `uv tool install [path to repository] -e`
@@ -0,0 +1 @@
1
+ uv build
@@ -0,0 +1,5 @@
1
+ sh bin/clean.sh
2
+ sh bin/build.sh
3
+ uv publish
4
+ # python3 -m twine upload --repository pypi dist/*
5
+ sh bin/clean.sh
@@ -25,7 +25,7 @@ class BaseApi:
25
25
 
26
26
  return r
27
27
 
28
- def get(self, endpoint):
28
+ def get(self, endpoint: str = ""):
29
29
  r = requests.get(self.url(endpoint), headers=self.headers())
30
30
 
31
31
  if r.status_code == 401 and self.refresh_auth_tokens():
@@ -46,7 +46,7 @@ class BaseApi:
46
46
 
47
47
  return headers
48
48
 
49
- def patch(self, endpoint, json: dict):
49
+ def patch(self, endpoint: str = "", json: dict = None):
50
50
  r = requests.patch(self.url(endpoint), headers=self.headers(), json=json)
51
51
 
52
52
  if r.status_code == 401 and self.refresh_auth_tokens():
@@ -66,7 +66,7 @@ class BaseApi:
66
66
 
67
67
  return r
68
68
 
69
- def put(self, endpoint, json: dict):
69
+ def put(self, endpoint: str = "", json: dict = None):
70
70
  r = requests.put(self.url(endpoint), headers=self.headers(), json=json)
71
71
 
72
72
  if r.status_code == 401 and self.refresh_auth_tokens():
@@ -0,0 +1,18 @@
1
+ from gibson.api.BaseApi import BaseApi
2
+ from gibson.core.Configuration import Configuration
3
+
4
+
5
+ class DataApi(BaseApi):
6
+ PREFIX = "-"
7
+
8
+ def __init__(self, configuration: Configuration, api_key: str):
9
+ self.configuration = configuration
10
+ self.api_key = api_key or self.configuration.project.api.key
11
+
12
+ def headers(self):
13
+ headers = super().headers()
14
+ headers["X-Gibson-API-Key"] = self.api_key
15
+ return headers
16
+
17
+ def query(self, query: str):
18
+ return self.post("query", {"query": query}).json()
@@ -10,7 +10,7 @@ class ProjectApi(BaseApi):
10
10
  self.configuration.require_login()
11
11
 
12
12
  def list(self):
13
- return self.get("all")["projects"]
13
+ return self.get()["projects"]
14
14
 
15
15
  def create(self):
16
16
  return self.post().json()
@@ -43,4 +43,4 @@ class ProjectApi(BaseApi):
43
43
  if not name:
44
44
  raise ValueError("Name is required")
45
45
 
46
- return self.put(f"{uuid}", {"name": name}).json()
46
+ return self.patch(f"{uuid}", {"name": name}).json()
@@ -1,10 +1,15 @@
1
1
  #!/usr/bin/env python3
2
2
 
3
+ import os
4
+
3
5
  from gibson.core.CommandRouter import CommandRouter
4
6
  from gibson.core.Configuration import Configuration
7
+ from gibson.display.Header import Header
5
8
 
6
9
 
7
10
  def main():
11
+ if os.getenv("GIBSON_CLI_DEV"):
12
+ print(f"{Header().render('dev mode')}\n")
8
13
  try:
9
14
  configuration = Configuration()
10
15
  if configuration.settings is None:
@@ -10,7 +10,7 @@ class Version(BaseCommand):
10
10
  try:
11
11
  r = requests.get("https://pypi.org/pypi/gibson-cli/json")
12
12
  latest_version = r.json()["info"]["version"]
13
- except:
13
+ except Exception:
14
14
  latest_version = VersionConf.num
15
15
 
16
16
  if latest_version != VersionConf.num:
@@ -0,0 +1,136 @@
1
+ from typing import Dict, List
2
+
3
+ from mcp.server.fastmcp import FastMCP
4
+ from requests.exceptions import HTTPError
5
+
6
+ from gibson.api.DataApi import DataApi
7
+ from gibson.api.ProjectApi import ProjectApi
8
+ from gibson.core.Configuration import Configuration
9
+
10
+ mcp = FastMCP("GibsonAI")
11
+
12
+ # Note: Resources are not yet supported by Cursor, everything must be implemented as a tool
13
+ # See https://docs.cursor.com/context/model-context-protocol#limitations
14
+
15
+
16
+ @mcp.tool()
17
+ def get_projects() -> List[Dict]:
18
+ """Get all GibsonAI projects"""
19
+ project_api = ProjectApi(Configuration())
20
+ try:
21
+ return project_api.list()
22
+ except HTTPError as e:
23
+ return {"status_code": e.response.status_code, "error": e.response.json()}
24
+
25
+
26
+ @mcp.tool()
27
+ def create_project() -> Dict:
28
+ """Create a new GibsonAI project"""
29
+ project_api = ProjectApi(Configuration())
30
+ try:
31
+ return project_api.create()
32
+ except HTTPError as e:
33
+ return {"status_code": e.response.status_code, "error": e.response.json()}
34
+
35
+
36
+ @mcp.tool()
37
+ def get_project_details(uuid: str) -> Dict:
38
+ """Get a GibsonAI project's details"""
39
+ project_api = ProjectApi(Configuration())
40
+ try:
41
+ return project_api.lookup(uuid=uuid)
42
+ except HTTPError as e:
43
+ return {"status_code": e.response.status_code, "error": e.response.json()}
44
+
45
+
46
+ @mcp.tool()
47
+ def get_project_hosted_api_details(uuid: str) -> str:
48
+ """
49
+ Get a GibsonAI project's hosted API details
50
+ This includes necessary context for an LLM to understand and generate API calls related to fetching or modifying the project's data
51
+ """
52
+ project_api = ProjectApi(Configuration())
53
+ try:
54
+ return project_api.mcp(uuid=uuid)
55
+ except HTTPError as e:
56
+ return {"status_code": e.response.status_code, "error": e.response.json()}
57
+
58
+
59
+ @mcp.tool()
60
+ def update_project(uuid: str, project_name: str) -> Dict:
61
+ """
62
+ Update a GibsonAI project's details
63
+ This currently only updates the project's name
64
+ Returns the updated project details
65
+ """
66
+ project_api = ProjectApi(Configuration())
67
+ try:
68
+ return project_api.update(uuid=uuid, name=project_name)
69
+ except HTTPError as e:
70
+ return {"status_code": e.response.status_code, "error": e.response.json()}
71
+
72
+
73
+ @mcp.tool()
74
+ def submit_data_modeling_request(uuid: str, data_modeling_request: str) -> Dict:
75
+ """
76
+ Submit a data modeling request for a GibsonAI project
77
+ This tool fully handles all data modeling, you should provide the user's request as-is
78
+ Returns the response from the LLM
79
+ """
80
+ project_api = ProjectApi(Configuration())
81
+ try:
82
+ return project_api.submit_message(uuid=uuid, message=data_modeling_request)
83
+ except HTTPError as e:
84
+ return {"status_code": e.response.status_code, "error": e.response.json()}
85
+
86
+
87
+ @mcp.tool()
88
+ def deploy_project(uuid: str) -> None:
89
+ """
90
+ Deploy a GibsonAI project's hosted databases
91
+ This deploys both the development and production databases simultaneously and automatically handles the migrations
92
+ """
93
+ project_api = ProjectApi(Configuration())
94
+ try:
95
+ return project_api.deploy(uuid=uuid)
96
+ except HTTPError as e:
97
+ return {"status_code": e.response.status_code, "error": e.response.json()}
98
+
99
+
100
+ @mcp.tool()
101
+ def get_project_schema(uuid: str) -> str:
102
+ """
103
+ Get the schema for a GibsonAI project
104
+ This includes any changes made to the schema since the last deployment
105
+ """
106
+ project_api = ProjectApi(Configuration())
107
+ try:
108
+ return project_api.schema(uuid=uuid)
109
+ except HTTPError as e:
110
+ return {"status_code": e.response.status_code, "error": e.response.json()}
111
+
112
+
113
+ @mcp.tool()
114
+ def get_deployed_schema(uuid: str) -> str:
115
+ """
116
+ Get the deployed schema for a GibsonAI project
117
+ This is the schema that is currently live on the project's hosted databases
118
+ """
119
+ project_api = ProjectApi(Configuration())
120
+ try:
121
+ return project_api.database_schema(uuid=uuid)
122
+ except HTTPError as e:
123
+ return {"status_code": e.response.status_code, "error": e.response.json()}
124
+
125
+
126
+ @mcp.tool()
127
+ def query_database(api_key: str, query: str) -> List[Dict] | None | Dict:
128
+ """
129
+ Query a GibsonAI project's hosted database using SQL
130
+ Note: the environment-specific API key must be provided
131
+ """
132
+ data_api = DataApi(Configuration(), api_key=api_key)
133
+ try:
134
+ return data_api.query(query=query)
135
+ except HTTPError as e:
136
+ return {"status_code": e.response.status_code, "error": e.response.json()}
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: gibson-cli
3
- Version: 0.8.0
3
+ Version: 0.8.2
4
4
  Summary: Gibson Command Line Interface
5
5
  Author-email: GibsonAI <noc@gibsonai.com>
6
6
  Project-URL: Homepage, https://gibsonai.com/
@@ -73,7 +73,6 @@ Requires-Dist: watchfiles==0.21.0
73
73
  Requires-Dist: websockets==12.0
74
74
  Requires-Dist: yaspin==3.1.0
75
75
 
76
-
77
76
  [![GibsonAI](https://github.com/user-attachments/assets/26bc1002-f878-4995-a6c5-eb8d5eb69c28)](https://gibsonai.com/)
78
77
 
79
78
  # Gibson CLI
@@ -90,19 +89,23 @@ Portions of the Gibson backend code are written by Gibson. So far, versus a hum
90
89
 
91
90
  ## Installation / Upgrading
92
91
 
93
- Install the latest version of the CLI using `pip`
92
+ ### With [uv](https://docs.astral.sh/uv/) (recommended)
94
93
 
95
94
  ```sh
96
- pip3 install gibson-cli --upgrade
95
+ uv tool install gibson-cli@latest
97
96
  ```
98
97
 
99
- Note: the first time you install any package from PyPI via `pip` that includes an executable, it is placed in a directory that is likely not in your `PATH`. There are a number of ways to do this, but one method is to run the following command:
98
+ If you're unable to run `gibson` after installing with uv, try running `uv tool update-shell` to ensure your `PATH` includes the uv tool executables directory.
99
+
100
+ ### With pip
100
101
 
101
102
  ```sh
102
- echo 'export PATH="$PATH:${$(which python3)%python3}"' >> ~/.zshrc # or ~/.bashrc
103
+ pip3 install gibson-cli --upgrade
103
104
  ```
104
105
 
105
- You will only need to do this once.
106
+ Note: you'll want to run this **outside** of a virtual environment (globally on your machine)
107
+
108
+ If you're unable to run `gibson` after installing with pip, ensure your `PATH` contains the directory where pip installs executables. This can differ based on your operating system, python installation location, and pip version.
106
109
 
107
110
  ## Key Terms
108
111
 
@@ -390,8 +393,8 @@ Update the configuration to look like the following:
390
393
  {
391
394
  "mcpServers": {
392
395
  "gibson": {
393
- "command": "gibson",
394
- "args": ["mcp", "run"]
396
+ "command": "uvx",
397
+ "args": ["--from", "gibson-cli@latest", "gibson", "mcp", "run"]
395
398
  }
396
399
  }
397
400
  }
@@ -402,4 +405,4 @@ That's it! Just make sure you're logged in to the CLI (if you're reading this, y
402
405
  ## Contributing
403
406
 
404
407
  - Clone this repository somewhere in your file system
405
- - `pip3 install [path to this repository]`
408
+ - `uv tool install [path to repository] -e`
@@ -5,10 +5,10 @@ pyproject.toml
5
5
  requirements.txt
6
6
  bin/build.sh
7
7
  bin/clean.sh
8
- bin/gibson
9
8
  bin/release.sh
10
9
  gibson/api/BaseApi.py
11
10
  gibson/api/Cli.py
11
+ gibson/api/DataApi.py
12
12
  gibson/api/ProjectApi.py
13
13
  gibson/bin/gibson.py
14
14
  gibson/command/BaseCommand.py
@@ -15,7 +15,7 @@ classifiers = [
15
15
  "Intended Audience :: Developers",
16
16
  "Programming Language :: Python :: 3.10",
17
17
  ]
18
- version = "0.8.0"
18
+ version = "0.8.2"
19
19
 
20
20
  [tool.setuptools.packages.find]
21
21
  where = ["."]
@@ -1,2 +0,0 @@
1
- rm -rf dist gibson_cli.egg-info
2
- PYTHONMEM=1G python3 -m build
@@ -1,26 +0,0 @@
1
- #!/Library/Frameworks/Python.framework/Versions/3.9/bin/python3.9
2
- # -*- coding: utf-8 -*-
3
-
4
- # This file is identical to what pip creates when you install an executable package, but it adds a dev mode banner.
5
- # To easily switch between dev mode and installed mode, add the following functions to your .zshrc or .bashrc:
6
- #
7
- # cli_dev_on() {
8
- # export PATH="$HOME/src/gibson/cli/bin:$PATH"
9
- # export PYTHONPATH="$HOME/src/gibson/cli:$PYTHONPATH"
10
- # }
11
- #
12
- # cli_dev_off() {
13
- # export PATH=${PATH#$HOME/src/gibson/cli/bin:}
14
- # export PYTHONPATH=${PYTHONPATH#:$HOME/src/gibson/cli:}
15
- # }
16
-
17
- import re
18
- import sys
19
-
20
- from gibson.bin.gibson import main
21
- from gibson.display.Header import Header
22
-
23
- if __name__ == "__main__":
24
- print(f"{Header().render('dev mode')}\n")
25
- sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
26
- sys.exit(main())
@@ -1 +0,0 @@
1
- python3 -m twine upload --repository pypi dist/*
@@ -1,87 +0,0 @@
1
- from typing import Dict, List
2
-
3
- from mcp.server.fastmcp import FastMCP
4
-
5
- from gibson.api.ProjectApi import ProjectApi
6
- from gibson.core.Configuration import Configuration
7
-
8
- mcp = FastMCP("GibsonAI")
9
-
10
- project_api = ProjectApi(Configuration())
11
-
12
- # Note: Resources are not yet supported by Cursor, everything must be implemented as a tool
13
- # See https://docs.cursor.com/context/model-context-protocol#limitations
14
-
15
-
16
- @mcp.tool()
17
- def get_projects() -> List[Dict]:
18
- """Get all GibsonAI projects"""
19
- return project_api.list()
20
-
21
-
22
- @mcp.tool()
23
- def create_project() -> Dict:
24
- """Create a new GibsonAI project"""
25
- return project_api.create()
26
-
27
-
28
- @mcp.tool()
29
- def get_project_details(uuid: str) -> Dict:
30
- """Get a GibsonAI project's details"""
31
- return project_api.lookup(uuid=uuid)
32
-
33
-
34
- @mcp.tool()
35
- def get_project_hosted_api_details(uuid: str) -> str:
36
- """
37
- Get a GibsonAI project's hosted API details
38
- This includes necessary context for an LLM to understand and generate API calls related to fetching or modifying the project's data
39
- """
40
- return project_api.mcp(uuid=uuid)
41
-
42
-
43
- @mcp.tool()
44
- def update_project(uuid: str, project_name: str) -> Dict:
45
- """
46
- Update a GibsonAI project's details
47
- This currently only updates the project's name
48
- Returns the updated project details
49
- """
50
- return project_api.update(uuid=uuid, name=project_name)
51
-
52
-
53
- @mcp.tool()
54
- def submit_data_modeling_request(uuid: str, data_modeling_request: str) -> Dict:
55
- """
56
- Submit a data modeling request for a GibsonAI project
57
- This tool fully handles all data modeling, you should provide the user's request as-is
58
- Returns the response from the LLM
59
- """
60
- return project_api.submit_message(uuid=uuid, message=data_modeling_request)
61
-
62
-
63
- @mcp.tool()
64
- def deploy_project(uuid: str) -> None:
65
- """
66
- Deploy a GibsonAI project's hosted databases
67
- This deploys both the development and production databases simultaneously and automatically handles the migrations
68
- """
69
- project_api.deploy(uuid=uuid)
70
-
71
-
72
- @mcp.tool()
73
- def get_project_schema(uuid: str) -> str:
74
- """
75
- Get the schema for a GibsonAI project
76
- This includes any changes made to the schema since the last deployment
77
- """
78
- return project_api.schema(uuid=uuid)
79
-
80
-
81
- @mcp.tool()
82
- def get_deployed_schema(uuid: str) -> str:
83
- """
84
- Get the deployed schema for a GibsonAI project
85
- This is the schema that is currently live on the project's hosted databases
86
- """
87
- return project_api.database_schema(uuid=uuid)
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes