克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

OpenTiny Logo

Tiny Engine Web Service是一个RESTful API,负责向前端提供数据服务、代码生成服务和代码发布服务。它不直接在数据库上操作,数据操作请求TinyEngine Data Center 数据中心的接口

English | 简体中文

目录规则

开发前需要了解项目整体目录结构,并按照如下规则去进行目录规则编写代码

├── README.md
├── app
│   ├── controller                      // controller
│   │   └── 业务控制器                    // 具体哪个业务建立自己的业务文件夹,如果是公用业务请把这个文件夹命名common
│   │       ├── api.js                  // api文件主要处理接口相关的逻辑
│   │       └── page.js                 // page文件主要处理页面的逻辑
│   ├── extend
│   │   └── helper.js                   // controller中的所有公共方法可以抽到helper里面通过 this.ctx.helper.xxx 引用
│   ├── middleware                      // 这部分中间件必须是公共逻辑(多语言处理之类的,记得要根据json还是html进行区分处理),业务逻辑不要放到中间件里面,各自业务公共方法可以在helper里面分自己业务空间定义通用的处理逻辑
│   ├── public                          // 静态文件目录,里面的资源本地开发阶段可以通过/public/方式访问到,但是发布线上记得要在网关层进行配置/public/目前的权限(这里建议静态资源放到cdn)。
│   │   └── 业务的静态资源                // 静态目录也要通过文件夹区分具体的业务类型,这里doc是文档中心的业务,知识库则建立zhishi文夹
│   │       ├── css
│   │       ├── images
│   │       └── js
│   ├── router                          // 路由根据业务进行划分,所有路由都必须要有自己业务前缀,除了common通用处理以外其他业务禁止使用/*这种全局路由,而采用/业务名称/*这种路由来处理各自业务下的逻辑
│   │   ├── common.js                   // common这个js主要处理根目录/*下路由等情况,其他业务逻辑禁止放到这里面
│   │   └── 业务的路由.js
│   ├── service                         // service跟controller同理,根据业务划分。
│   │   └── 业务相关的后端接口服务          // 业务中使用到跟后端对接相关接口,根据业务划分
│   │       └── 业务所依赖的具体服务的接口逻辑.js
│   └── view                            // view存放的是ejs模版,根据业务具体划分文件目录(业务下再根据语言目录划分不同模版),其common和error分别为公共布局以及错误处理。
│       ├── common                      // common存放公共布局文件(header/footer/sidecar等),各个业务可以在自己需要的时include进到自己业务中
│       │   ├── en-us                   // 公共英文的模版
│       │   │   └── index.tpl
│       │   └── zh-cn                   // 公共中文的模版
│       │       ├── footer.tpl
│       │       └── header.tpl
│       ├── 业务自己的模版                 // 文档中心的业务模版
│       │   ├── en-us
│       │   │   └── index.tpl
│       │   └── zh-cn
│       │       ├── 404.html
│       │       ├── content
│       │       │   ├── catalog.tpl
│       │       │   └── content.tpl
│       │       └── pages.tpl
│       └── error                        // error目录存放错误处理文件,如404 500这种错误可以放到这里面来,同时也会根据语言进行划分
│           ├── en-us
│           │   └── 404.tpl
│           └── zh-cn
│               └── 404.tpl
├── config                               // 项目配置 根据不同环境会加载不同配置
│   ├── config.default.js                // 这个文件主要是默认配置,是其他config文件定义之后根据环境不同会通过Object.assig(config.defalut.js,config.xxxx.js)方式合并。所以不同环境公共的配置全合并到这里,其他config做自己定制化处理即可。
│   ├── config.local.js                  // 只需要配置本地相关的一些差异化配置
│   ├── config.prod.js
│   └── plugin.js                       // 插件开关目录,根据实际需要去开关自己的插件
├── logs                                // 本地开发日志的输出目录
├── package.json
├── test                                // 测试用例,采用BDD方式进行测试用例编写
│   └── 业务测试用例                      // 业务相关测试用例
│        ├── controller.test.js         // 根据语言维度进行测试/根据接口是否200进行测试
│        └── service.test.js            // 根据服务返回接口是否正常,通过assert断言库进行测试
└── typings                             // egg使用typescript临时生成的一些定义文件,日常开发可以忽略。

接口返回规范

1.返回格式
  • 正常数据
{
    "locale": "zh-cn",
    "data": {
      "app": {
        "count": 100
      }
    }
}
  • 错误数据
{
    "locale": "zh-cn",
    "data": {},
    "error": {
      "code": "CM002",
      "message": "name 不能为空",
    }
}
2.如何保证错误码和错误信息准确性
  • egg接口走通,除业务层返回403重登录外,http状态码均为200,异常原因体现在error;
  • 词条国际化:在config/locale 中持续补充对应错误码和词条内容
  • 不请求data-center的接口,直接调用helper.commonJson()返回数据
  • 请求data-center的接口:
    // 调用对应service方法,发起query请求,dataService会调用helper.getResponseData()
    // getResponseData会将data-center回传的错误信息进行规范化转换
    const createRes = await platforms.createPlatform(body);
    // 如果通用的错误提示不能体现出字段,可对已经获得数据再加工
    // formatResponse可进行逻辑扩展
    this.ctx.body = this.ctx.helper.formatResponse(createRes, 'name');
3.参数字段校验
  • 在egg服务层接口使用validate进行字段必要性和格式校验,避免这种错误在strapi抛出,对数据格式有特殊要求的可以在app/validate添加规则
4.错误处理中间件
  • 在中间件errorResponse.ts中补充错误拦截处理;服务端本身导致的异常会捕获并返回500,

使用手册

具体服务端使用文档请查看TinyEngine 官网-使用手册

开发

环境变量

变量名称 说明
GIT_USERNAME 应用发布时具备push代码权限的代码仓用户名
GIT_EMAIL 应用发布时具备push代码权限的代码仓的用户邮箱
GIT_USER_TOKEN 应用发布时具备push代码权限的代码仓token
GIT_REPO 应用发布时的代码仓地址
GIT_BRANCH 应用发布时默认提交代码的分支
DATA_CENTER_URL 数据中心地址,例如: https://www.mydatacenter.com
PROXY_SERVER 选择性设置,如果自己的服务器需要代理服务才能访问外部数据,需要配置代理服务的地址
OPENAI_API_KEY AI接口 openai的 API key
WENXIN_ACCESS_TOKEN AI接口 文心一言的access_token (30天一更新)
NPM_AUTH_TOKEN npmjs.com 的用户具备publish权限的authToken, 用户发布区块

以下为参考环境变量配置项:

obs 配置 此次开源代码提供了搭配华为云obs的使用示例:

变量名称 说明
OBS_AK obs AK 本示例代码使用华为云obs,如果使用其他云服务产品请搜索相关代码修改逻辑适配
OBS_SK obs SK 本示例代码使用华为云obs,如果使用其他云服务产品请搜索相关代码修改逻辑适配
OBS_ACCESS_URL obs的资源访问url,例如:https://tinyengine.obs.cn-north-4.myhuaweicloud.com/somepath/somefile.tar.gz
OBS_SERVICE_URL 使用obs sdk时传入的obs服务链接参数,例如:https://obs.cn-north-4.myhuaweicloud.com

RabbitMQ 配置 此次开源代码提供了连接RabbitMQ任务队列的使用示例(开源代码中RabbitMQ 插件处于关闭状态,如果需要请开启。 同时恢复项目根目录下app.ts中被注释的代码):

变量名称 说明
MQ_IP 任务队列服务ip地址
MQ_PORT 任务队列服务端口,例如 5671
MQ_USERNAME 任务队列服务用户名
MQ_PASSWORD 任务队列服务密码

如果涉及到自身服务的CI/CD 部署 或容器化部署请根据自身所属产品、工具的特点按照上面的清单配置环境变量;

本地运行时配置方式:

git-bash 或 bash

vi ~/.bashrc
export MQ_IP=192.168.0.11
export MQ_PORT=5671
# 等等环境变量

设置完后,重新打开命令行或在当前命令行执行

source ~/.bashrc

让设置的环境变量生效;(git bash中设置的环境变量无法适用于powershell 和cmd) 启动项目

nodejs版本选择: >= 16

进入到项目根目录下,一次执行:

yarn install --ignore-engines
npm run dev

里程碑

gantt dateFormat YYYY-MM-DD axisFormat %Y-%m-%d 1.0.0-beta.x version :active,2023-09-25, 2024-03-31 1.0.0-rc version : 2024-04-01, 2024-06-30 1.0.0 version : 2024-07-01, 2024-07-31

🤝 参与贡献

如果你对我们的开源项目感兴趣,欢迎加入我们!🎉

参与贡献之前请先阅读贡献指南

开源协议

MIT

MIT License Copyright (c) 2023 - present TinyEngine Authors. Copyright (c) 2023 - present Huawei Cloud Computing Technologies Co., Ltd. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

1234567890 展开 收起
JavaScript 等 3 种语言
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化