声明什么
得到什么
声明式 API 与 ORM,简洁高效
简单上手,产出高可读代码
自动完成请求解析校验
自动生成 OpenAPI 接口文档
python
from utilmeta.core import api, orm
from django.db import models
from .models import User, Article
class UserSchema(orm.Schema[User]):
username: str
articles_num: int = models.Count('articles')
class ArticleSchema(orm.Schema[Article]):
id: int
author: UserSchema
content: str
class ArticleAPI(api.API):
async def get(self, id: int) -> ArticleSchema:
return await ArticleSchema.ainit(id)
GET
/article?id=1 200
json
{
"id": 1,
"author": {
"username": "alice",
"articles_num": 3
},
"content": "hello world"
}
data:image/s3,"s3://crabby-images/8ad98/8ad98869e8a0ac1facd5f2dae602bb5839a8de13" alt=""
QUERY PARAMETERS
- id *
integer
RESPONSE application/json
- id
integer
- author
object
- username
string
- articles_num
integer
- content
string
Starlette
python
from utilmeta import UtilMeta
from utilmeta.core import api
from config import configure
import starlette
service = UtilMeta(
__name__,
name='blog',
backend=starlette,
)
configure(service)
from blog.api import ArticleAPI
@service.mount
class RootAPI(api.API):
article: ArticleAPI
app = service.application() # wsgi / asgi
if __name__ == '__main__':
service.run()
集成你最熟悉的框架
UtilMeta 可以使用主流的 Python 框架作为运行时实现,你也可以从现有项目渐进式地集成 UtilMeta 接口
data:image/s3,"s3://crabby-images/e2a4c/e2a4c826a42d7b6a229892020249470e3261a4e6" alt=""
data:image/s3,"s3://crabby-images/99650/99650ea2b4ea05960bd5a2f0da330fa8a6a16682" alt=""
data:image/s3,"s3://crabby-images/3cb0b/3cb0b11e3d5e13efefac3332dc312e36e5c0545f" alt=""
data:image/s3,"s3://crabby-images/aa1fc/aa1fce5cac8db13cb38b38214071577099503865" alt=""
data:image/s3,"s3://crabby-images/44728/44728884dc1153fcd9e100fcfc5f4932e5c63373" alt=""
data:image/s3,"s3://crabby-images/6f85e/6f85e05193def0c23e29508e4521677b8833d5fb" alt=""