Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/insectkorea/swaggpt
SwagGPT is an experimental CLI tool designed to automatically generate and add Swagger annotation to Gin and Echo handler functions in Go projects.
https://github.com/insectkorea/swaggpt
gin golang gpt llm swagger
Last synced: 10 days ago
JSON representation
SwagGPT is an experimental CLI tool designed to automatically generate and add Swagger annotation to Gin and Echo handler functions in Go projects.
- Host: GitHub
- URL: https://github.com/insectkorea/swaggpt
- Owner: insectkorea
- License: mit
- Created: 2024-05-29T11:57:41.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-05-29T13:07:15.000Z (8 months ago)
- Last Synced: 2024-05-30T00:55:34.475Z (8 months ago)
- Topics: gin, golang, gpt, llm, swagger
- Language: Go
- Homepage:
- Size: 17.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SwagGPT
**SwagGPT** is an experimental CLI tool designed to automatically generate and add Swagger comments to Gin and Echo handler functions in Go projects. The tool uses OpenAI's GPT-4 model to analyze the handler functions and create comprehensive Swagger documentation, improving API documentation quality and consistency.
## Features
- **Automated Swagger Comment Creation**: Leverages OpenAI API to automatically produce Swagger comments from the content of handler functions.
- **Compatibility with Gin and Echo Frameworks**: Primarily designed for Gin, but can be extended to support other web frameworks such as Echo.
- **Dry Run Feature**: Allows users to preview the generated comments without altering the actual files.
- **Cost Prediction**: Provides an estimated cost prior to execution.
- **Concurrent Execution**: Enables simultaneous processing of multiple handler functions, improving the efficiency and speed of the documentation generation process.## Installation
To install the CLI tool, use the following command:
```sh
go install github.com/insectkorea/swagGPT/cmd/swaggpt@latest
```## Usage
### Set Up Environment
Make sure to set your OpenAI API key in the environment:
```sh
export OPENAI_API_KEY=your_openai_api_key
```### Run the CLI Tool
To add Swagger comments to handler functions in a specified directory:
```sh
swaggpt add-comments --dir /path/to/your/code --model gpt-4o
```If you have separate file that defines routes, you can add
```sh
swaggpt add-comments --dir /path/to/your/code --model gpt-4o --route-file /path/to/your/route-file
```Please make sure your files are under source version control, as swagGTP will overwrite contents.
You can use the `--dry-run` flag to preview the changes without writing them to files:
```sh
swaggpt add-comments --dir /path/to/your/code --model gpt-4o --dry-run
```Note that while dry-run does not write to your files, but it does make API requests to Open AI.
## Running Tests
To run the tests, use the following command:
```sh
go test ./...
```### Contributing Guidelines
1. Fork the repository.
2. Create a new branch (`git checkout -b feature-branch`).
3. Make your changes.
4. Commit your changes (`git commit -am 'Add new feature'`).
5. Push to the branch (`git push origin feature-branch`).
6. Create a new Pull Request.## License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.
## Disclaimer
This is an **experimental project**. The accuracy and reliability of the generated Swagger comments depend on the quality of the underlying AI model and the specific implementation details. Use this tool at your own risk, and always review the generated comments for correctness before deploying them in a production environment.
## Caution
This may cause unexpected amount of billing as the program needs to pass the whole handler code to correctly understand the context.