api/README.md

52 lines
1.9 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# @go/api
`@go/api` 是一个极致精简、接口驱动、AI 友好的 API 调用引擎。它旨在消除对接第三方服务如腾讯云、阿里云、OpenAI 等)时的繁琐 SDK 依赖和硬编码摩擦。
## 🎯 设计哲学
* **数据驱动 (Data-Driven)**:一切皆数据,通过强类型 Action 结构体描述请求。
* **无状态 (Stateless)**:核心库不绑定任何具体的云服务实现,仅提供标准协议支持。
* **AI 友好 (AI-First)**:极其简单的结构体定义,消除了幻觉,让 AI 能够精准生成调用代码。
* **非破坏性注入**:支持从配置自动回填缺失参数(如 AppId, SecretId但不覆盖显式设置的值。
## 📦 安装
```bash
go get apigo.cc/go/api
```
## 💡 核心流程
1. **定义 Action**:实现 `Action` 接口(及可选的 `SignerAction`, `ConfigurableAction` 等)。
2. **配置授权**:在 `api.yml` 或环境变量中配置密钥。
3. **发起调用**:使用 `api.Call[Response](&action)`
## 🛠 接口说明
* `Action`:核心标识接口,定义动作名称(如 `tencent.sms.smsPackagesStatistics`)。
* `SignerAction`:指定签名算法名称(如 `tc3`)。
* `ConfigurableAction`:提供硬编码的默认参数或元数据。
* `URLAction` / `MethodAction`:动态指定 Endpoint 和 HTTP 方法。
* `ValidatableAction`:业务参数自校验。
## 🔒 安全性
* **内置解密**:支持自动识别并解密配置中的 AES 加密内容。
* **并发安全**:配置树操作受 `sync.RWMutex` 保护。
## 🧪 示例
```go
type MySmsAction struct {
Limit int
AppId string // 自动从配置注入
}
func (MySmsAction) ActionName() string { return "tencent.sms.smsPackagesStatistics" }
func (MySmsAction) SignerName() string { return "tc3" }
resp, err := api.Call[MyResponse](&MySmsAction{Limit: 10})
```
---
更多详情请参阅 [TEST.md](./TEST.md) 和 [CHANGELOG.md](./CHANGELOG.md)。