Skip to content
On this page

[DEPRECATED] uni-app-deploy

该依赖已废弃,请迁移到功能一致的 @uni-helper/uni-deploy

License

npm

WIP

支持在脚本文件和 CI/CD 中调用以自动部署 uni-app 应用。

起步

安装依赖

安装依赖。

使用 npm

shell
npm install uni-app-deploy -D
1

使用 yarn

shell
yarn install uni-app-deploy -D
1

使用 pnpm

shell
pnpm install uni-app-deploy -D
1

使用 cnpm

shell
cnpm install uni-app-deploy -D
1

配置文件

支持以下配置:

  • uni-app-deploy.config.ts
  • uni-app-deploy.config.cts
  • uni-app-deploy.config.mts
  • uni-app-deploy.config.js
  • uni-app-deploy.config.cjs
  • uni-app-deploy.config.mjs
  • uni-app-deploy.config.json
  • package.json 中的 uni-app-deploy 字段内容

借助 joyconbundle-requirestrip-json-comments 的帮助,只要读取到以上任何配置文件,就会将其内容作为你提供的 uni-app-deploy 的配置。

以下是一个 uni-app-deploy.config.ts 的示例。

typescript
import { defineConfig } from 'uni-app-deploy';

export default defineConfig({
  /* 通用配置 */
  // 当前进程的工作目录,默认为执行目录
  cwd: process.cwd(),

  /* 应用平台 */
  platform: {
    // 微信小程序配置
    'mp-weixin': { ... },
  },

  /* 沟通工具 */
  im: {
    // 企业微信配置
    'wecom': { ... },
  },
})
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

配置

应用平台

如果不需要某个应用平台,传入 falsy 值即可。

微信小程序

类型定义如下。

typescript
import { ICreateProjectOptions } from 'miniprogram-ci/dist/@types/ci/project';
import { IInnerUploadOptions } from 'miniprogram-ci/dist/@types/ci/upload';

export interface MpWeixinConfig {
  /** miniprogram-ci ci.project */
  // {
  //   /**
  //    * 小程序 / 小游戏 appid
  //    * 如果没有填写,会尝试按以下顺序读取,如果读取失败将无法运行
  //    * ./src/manifest.json mp-weixin appid
  //    * ./**/manifest.json mp-weixin appid
  //    * ./dist/mp-weixin/project.config.json appid
  //    * ./dist/build/mp-weixin/project.config.json appid
  //    * ./dist/**\/mp-weixin/project.config.json appid
  //    */
  //   appid?: string;
  //   /**
  //    * 项目路径
  //    * 如果没有填写,会尝试按以下顺序寻找 project.config.json 并将其所在目录作为项目路径,如果寻找失败将无法运行
  //    * ./dist/mp-weixin/project.config.json
  //    * ./dist/build/mp-weixin/project.config.json
  //    * ./dist/**\/mp-weixin/project.config.json
  //    */
  //   path?: string;
  //   /**
  //    * 私钥内容
  //    */
  //   privateKey?: string;
  //   /**
  //    * 私钥路径
  //    * 如果没有填写,会尝试按以下顺序寻找 .key 文件并将其路径作为私钥路径,寻找失败不影响继续运行
  //    * ./**\/private.${appid}.key
  //    * ./**\/weixin.${appid}.key
  //    * ./**\/wechat.${appid}.key
  //    */
  //   privateKeyPath?: string;
  //   /**
  //    * 当前项目类型,默认为 miniprogram
  //    */
  //   type?: MiniProgramCI.ProjectType;
  // };
  project?: Partial<ICreateProjectOptions>;

  /** miniprogram-ci ci.upload */
  // {
  //   /**
  //    * 版本号
  //    * 如果没有填写,会尝试按以下顺序读取,如果读取失败将无法运行
  //    * ./package.json version
  //    * ./src/manifest.json versionName
  //    * ./**/manifest.json versionName
  //    */
  //   version?: string;
  //   /**
  //    * 编译设置
  //    * 如果没有填写,会尝试按以下顺序读取,如果读取失败将无法运行
  //    * ./src/manifest.json mp-weixin setting
  //    * ./**/manifest.json mp-weixin setting
  //    * ./dist/mp-weixin/project.config.json setting
  //    * ./dist/build/mp-weixin/project.config.json setting
  //    * ./dist/**\/mp-weixin/project.config.json setting
  //    */
  //   setting?: MiniProgramCI.ICompileSettings;
  //   /**
  //    * 备注,默认为 Uploaded by uni-app-deploy
  //    */
  //   desc?: string;
  // };
  upload?: Partial<Omit<IInnerUploadOptions, 'project'>>;

  /** miniprogram-ci ci.preview */
  // {
  //   /**
  //    * 版本号
  //    * 如果没有填写,会尝试按以下顺序读取,如果读取失败将无法运行
  //    * ./package.json version
  //    * ./src/manifest.json versionName
  //    * ./**/manifest.json versionName
  //    */
  //   version?: string;
  //   /**
  //    * 编译设置
  //    * 如果没有填写,会尝试按以下顺序读取,如果读取失败将无法运行
  //    * ./src/manifest.json mp-weixin setting
  //    * ./**/manifest.json mp-weixin setting
  //    * ./dist/mp-weixin/project.config.json setting
  //    * ./dist/build/mp-weixin/project.config.json setting
  //    * ./dist/**\/mp-weixin/project.config.json setting
  //    */
  //   setting?: MiniProgramCI.ICompileSettings;
  //   /**
  //    * 备注,默认为 Uploaded by uni-app-deploy
  //    */
  //   desc?: string;
  //   /**
  //    * 二维码格式,默认为 image
  //    */
  //   qrcodeFormat?: 'base64' | 'image' | 'terminal';
  //   /**
  //    * 二维码输出路径,默认为 qrcode.png
  //    */
  //   qrcodeOutputDest?: string;
  // };
  preview?: Partial<Omit<IInnerUploadOptions, 'project' | 'test'> & { test?: true }>;
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105

沟通工具

如果不需要某个沟通工具,传入 falsy 值即可。

钉钉

typescript
export interface DingtalkConfig {
  /**
   * 钉钉机器人 webhook
   * 如果不填写,无法发送请求
   */
  webhook?: string | string[];
}
1
2
3
4
5
6
7

企业微信

typescript
export interface WecomConfig {
  /**
   * 企业微信机器人 webhook
   * 如果不填写,无法发送请求
   */
  webhook?: string | string[];
}
1
2
3
4
5
6
7

CLI 调用

提供基于 ESM 的 CLI 调用。参考了 https://www.stefanjudis.com/snippets/how-to-create-a-module-based-node-js-executable/https://2ality.com/2022/07/nodejs-esm-shell-scripts.html

注册的命令是 uni-app-deployuad。你可以通过 uni-app-deploy -huad -h 查看命令提示。

目前提供三个命令。

uni-app-deploy validate

检查配置文件。

uni-app-deploy upload

上传。

uni-app-deploy preview

预览。

脚本调用

你可以从 uni-app-deploy 导入各种方法来组合使用。CLI 只是提供了更便捷的方式操作。

typescript
import {...} from 'uni-app-deploy';
1

Released under the MIT License.