@cloudbase/ai 2.24.6 → 2.24.8-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,14 +1,18 @@
1
- import type { ModelReq, ImageGenerateInput, HunyuanGenerateImageInput, HunyuanGenerateImageOutput } from '../type';
2
- type NoInfer<T> = [T][T extends any ? 0 : never];
3
- type GenerateImageInput<TProvider extends string, TInput = unknown> = unknown extends TInput ? TProvider extends 'hunyuan-image' ? HunyuanGenerateImageInput : ImageGenerateInput : TInput;
4
- type GenerateImageOutput<TProvider extends string, TOutput = unknown> = unknown extends TOutput ? TProvider extends 'hunyuan-image' ? HunyuanGenerateImageOutput : unknown : TOutput;
1
+ import type { ModelReq, HunyuanGenerateImageInput, HunyuanGenerateImageOutput, HunyuanARGenerateImageInput, HunyuanARGenerateImageOutput } from '../type';
2
+ interface HunyuanImageGenerateFn {
3
+ (input: HunyuanARGenerateImageInput): Promise<HunyuanARGenerateImageOutput>;
4
+ (input: HunyuanGenerateImageInput): Promise<HunyuanGenerateImageOutput>;
5
+ }
6
+ type GenerateImageFn<TProvider> = TProvider extends 'hunyuan-image' ? HunyuanImageGenerateFn : (input: unknown) => Promise<unknown>;
5
7
  export declare class DefaultImageModel<TProvider extends string> {
6
8
  private req;
7
9
  baseUrl: string;
8
10
  provider: TProvider;
9
- generateImageSubUrl: string;
11
+ defaultGenerateImageSubUrl: string;
12
+ generateImageSubUrlConfig: Record<string, Record<string, string>>;
13
+ generateImage: GenerateImageFn<TProvider>;
10
14
  constructor(req: ModelReq, baseUrl: string, provider: TProvider);
11
- generateImage<TInput = unknown, TOutput = unknown>(input: NoInfer<GenerateImageInput<TProvider, TInput>>): Promise<GenerateImageOutput<TProvider, TOutput>>;
15
+ private generateImageImpl;
12
16
  private getGenerateUrl;
13
17
  }
14
18
  export {};
@@ -42,29 +42,44 @@ var DefaultImageModel = (function () {
42
42
  this.req = req;
43
43
  this.baseUrl = baseUrl;
44
44
  this.provider = provider;
45
- this.generateImageSubUrl = 'images/generations';
45
+ this.defaultGenerateImageSubUrl = 'images/generations';
46
+ this.generateImageSubUrlConfig = {
47
+ 'hunyuan-image': {
48
+ 'hunyuan-image-v3.0-v1.0.4': 'images/ar/generations',
49
+ 'hunyuan-image-v3.0-v1.0.1': 'images/ar/generations',
50
+ },
51
+ };
52
+ this.generateImage = this.generateImageImpl.bind(this);
46
53
  }
47
- DefaultImageModel.prototype.generateImage = function (input) {
54
+ DefaultImageModel.prototype.generateImageImpl = function (input) {
55
+ var _a;
48
56
  return __awaiter(this, void 0, void 0, function () {
49
- var res;
50
- return __generator(this, function (_a) {
51
- switch (_a.label) {
52
- case 0: return [4, this.req({
53
- url: this.getGenerateUrl(),
54
- data: input,
55
- stream: false,
56
- })];
57
+ var subUrl, newSubUrl, res;
58
+ return __generator(this, function (_b) {
59
+ switch (_b.label) {
60
+ case 0:
61
+ subUrl = this.defaultGenerateImageSubUrl;
62
+ if (typeof input === 'object' && input && 'model' in input && typeof input.model === 'string') {
63
+ newSubUrl = (_a = this.generateImageSubUrlConfig[this.provider]) === null || _a === void 0 ? void 0 : _a[input.model];
64
+ if (newSubUrl)
65
+ subUrl = newSubUrl;
66
+ }
67
+ return [4, this.req({
68
+ url: this.getGenerateUrl(subUrl),
69
+ data: input,
70
+ stream: false,
71
+ })];
57
72
  case 1:
58
- res = _a.sent();
73
+ res = (_b.sent());
59
74
  return [2, res];
60
75
  }
61
76
  });
62
77
  });
63
78
  };
64
- DefaultImageModel.prototype.getGenerateUrl = function () {
65
- return "".concat(this.baseUrl, "/").concat(this.provider, "/").concat(this.generateImageSubUrl);
79
+ DefaultImageModel.prototype.getGenerateUrl = function (subUrl) {
80
+ return "".concat(this.baseUrl, "/").concat(this.provider, "/").concat(subUrl);
66
81
  };
67
82
  return DefaultImageModel;
68
83
  }());
69
84
  exports.DefaultImageModel = DefaultImageModel;
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWxzL2ltYWdlLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXFDQTtJQUlFLDJCQUNVLEdBQWEsRUFDZCxPQUFlLEVBQ2YsUUFBbUI7UUFGbEIsUUFBRyxHQUFILEdBQUcsQ0FBVTtRQUNkLFlBQU8sR0FBUCxPQUFPLENBQVE7UUFDZixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBTnJCLHdCQUFtQixHQUFHLG9CQUFvQixDQUFBO0lBTzlDLENBQUM7SUFFUyx5Q0FBYSxHQUExQixVQUFnRSxLQUFxRDs7Ozs7NEJBQ3ZHLFdBQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQzs0QkFDekIsR0FBRyxFQUFFLElBQUksQ0FBQyxjQUFjLEVBQUU7NEJBQzFCLElBQUksRUFBRSxLQUFLOzRCQUNYLE1BQU0sRUFBRSxLQUFLO3lCQUNkLENBQUMsRUFBQTs7d0JBSkksR0FBRyxHQUFHLFNBSVY7d0JBRUYsV0FBTyxHQUE4QyxFQUFBOzs7O0tBQ3REO0lBV08sMENBQWMsR0FBdEI7UUFDRSxPQUFPLFVBQUcsSUFBSSxDQUFDLE9BQU8sY0FBSSxJQUFJLENBQUMsUUFBUSxjQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBRSxDQUFBO0lBQ3ZFLENBQUM7SUFLSCx3QkFBQztBQUFELENBQUMsQUFwQ0QsSUFvQ0M7QUFwQ1ksOENBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBNb2RlbFJlcSxcbiAgSW1hZ2VHZW5lcmF0ZUlucHV0LFxuICAvLyBJbWFnZUVkaXRJbnB1dCxcbiAgSHVueXVhbkdlbmVyYXRlSW1hZ2VJbnB1dCxcbiAgSHVueXVhbkdlbmVyYXRlSW1hZ2VPdXRwdXQsXG4gIC8vIEh1bnl1YW5FZGl0SW1hZ2VJbnB1dCxcbiAgLy8gSHVueXVhbkVkaXRJbWFnZU91dHB1dCxcbn0gZnJvbSAnLi4vdHlwZSdcblxuLy8gbW9jayBOb0luZmVyXG50eXBlIE5vSW5mZXI8VD4gPSBbVF1bVCBleHRlbmRzIGFueSA/IDAgOiBuZXZlcl1cblxudHlwZSBHZW5lcmF0ZUltYWdlSW5wdXQ8VFByb3ZpZGVyIGV4dGVuZHMgc3RyaW5nLCBUSW5wdXQgPSB1bmtub3duPiA9IHVua25vd24gZXh0ZW5kcyBUSW5wdXRcbiAgPyBUUHJvdmlkZXIgZXh0ZW5kcyAnaHVueXVhbi1pbWFnZSdcbiAgICA/IEh1bnl1YW5HZW5lcmF0ZUltYWdlSW5wdXRcbiAgICA6IEltYWdlR2VuZXJhdGVJbnB1dFxuICA6IFRJbnB1dFxuXG50eXBlIEdlbmVyYXRlSW1hZ2VPdXRwdXQ8VFByb3ZpZGVyIGV4dGVuZHMgc3RyaW5nLCBUT3V0cHV0ID0gdW5rbm93bj4gPSB1bmtub3duIGV4dGVuZHMgVE91dHB1dFxuICA/IFRQcm92aWRlciBleHRlbmRzICdodW55dWFuLWltYWdlJ1xuICAgID8gSHVueXVhbkdlbmVyYXRlSW1hZ2VPdXRwdXRcbiAgICA6IHVua25vd25cbiAgOiBUT3V0cHV0XG5cbi8vIHR5cGUgRWRpdEltYWdlSW5wdXQ8VCBleHRlbmRzIHN0cmluZywgVElucHV0ID0gdW5rbm93bj4gPSB1bmtub3duIGV4dGVuZHMgVElucHV0XG4vLyAgID8gVCBleHRlbmRzICdodW55dWFuLWltYWdlJ1xuLy8gICAgID8gSHVueXVhbkVkaXRJbWFnZUlucHV0XG4vLyAgICAgOiBJbWFnZUVkaXRJbnB1dFxuLy8gICA6IFRJbnB1dFxuXG4vLyB0eXBlIEVkaXRJbWFnZU91dHB1dDxUIGV4dGVuZHMgc3RyaW5nLCBUT3V0cHV0ID0gdW5rbm93bj4gPSB1bmtub3duIGV4dGVuZHMgVE91dHB1dFxuLy8gICA/IFQgZXh0ZW5kcyAnaHVueXVhbi1pbWFnZSdcbi8vICAgICA/IEh1bnl1YW5FZGl0SW1hZ2VPdXRwdXRcbi8vICAgICA6IHVua25vd25cbi8vICAgOiBUT3V0cHV0XG5cbmV4cG9ydCBjbGFzcyBEZWZhdWx0SW1hZ2VNb2RlbDxUUHJvdmlkZXIgZXh0ZW5kcyBzdHJpbmc+IHtcbiAgcHVibGljIGdlbmVyYXRlSW1hZ2VTdWJVcmwgPSAnaW1hZ2VzL2dlbmVyYXRpb25zJ1xuICAvLyBwdWJsaWMgZWRpdEltYWdlU3ViVXJsID0gJ2ltYWdlcy9lZGl0cydcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlcTogTW9kZWxSZXEsXG4gICAgcHVibGljIGJhc2VVcmw6IHN0cmluZyxcbiAgICBwdWJsaWMgcHJvdmlkZXI6IFRQcm92aWRlcixcbiAgKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZW5lcmF0ZUltYWdlPFRJbnB1dCA9IHVua25vd24sIFRPdXRwdXQgPSB1bmtub3duPihpbnB1dDogTm9JbmZlcjxHZW5lcmF0ZUltYWdlSW5wdXQ8VFByb3ZpZGVyLCBUSW5wdXQ+PiwpOiBQcm9taXNlPEdlbmVyYXRlSW1hZ2VPdXRwdXQ8VFByb3ZpZGVyLCBUT3V0cHV0Pj4ge1xuICAgIGNvbnN0IHJlcyA9IGF3YWl0IHRoaXMucmVxKHtcbiAgICAgIHVybDogdGhpcy5nZXRHZW5lcmF0ZVVybCgpLFxuICAgICAgZGF0YTogaW5wdXQsXG4gICAgICBzdHJlYW06IGZhbHNlLFxuICAgIH0pXG5cbiAgICByZXR1cm4gcmVzIGFzIEdlbmVyYXRlSW1hZ2VPdXRwdXQ8VFByb3ZpZGVyLCBUT3V0cHV0PlxuICB9XG5cbiAgLy8gcHVibGljIGFzeW5jIGVkaXRJbWFnZTxUSW5wdXQgPSB1bmtub3duLCBUT3V0cHV0ID0gdW5rbm93bj4oaW5wdXQ6IE5vSW5mZXI8RWRpdEltYWdlSW5wdXQ8VFByb3ZpZGVyLCBUSW5wdXQ+PiwpOiBQcm9taXNlPEVkaXRJbWFnZU91dHB1dDxUUHJvdmlkZXIsIFRPdXRwdXQ+PiB7XG4gIC8vICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5yZXEoe1xuICAvLyAgICAgdXJsOiB0aGlzLmdldEVkaXRVcmwoKSxcbiAgLy8gICAgIGRhdGE6IGlucHV0LFxuICAvLyAgICAgc3RyZWFtOiBmYWxzZSxcbiAgLy8gICB9KVxuICAvLyAgIHJldHVybiByZXMgYXMgRWRpdEltYWdlT3V0cHV0PFRQcm92aWRlciwgVE91dHB1dD5cbiAgLy8gfVxuXG4gIHByaXZhdGUgZ2V0R2VuZXJhdGVVcmwoKSB7XG4gICAgcmV0dXJuIGAke3RoaXMuYmFzZVVybH0vJHt0aGlzLnByb3ZpZGVyfS8ke3RoaXMuZ2VuZXJhdGVJbWFnZVN1YlVybH1gXG4gIH1cblxuICAvLyBwcml2YXRlIGdldEVkaXRVcmwoKSB7XG4gIC8vICAgcmV0dXJuIGAke3RoaXMuYmFzZVVybH0vJHt0aGlzLnByb3ZpZGVyfS8ke3RoaXMuZWRpdEltYWdlU3ViVXJsfWBcbiAgLy8gfVxufVxuIl19
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWxzL2ltYWdlLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW9CQTtJQWFFLDJCQUFvQixHQUFhLEVBQVMsT0FBZSxFQUFTLFFBQW1CO1FBQWpFLFFBQUcsR0FBSCxHQUFHLENBQVU7UUFBUyxZQUFPLEdBQVAsT0FBTyxDQUFRO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQVo5RSwrQkFBMEIsR0FBRyxvQkFBb0IsQ0FBQTtRQUVqRCw4QkFBeUIsR0FBMkM7WUFDekUsZUFBZSxFQUFFO2dCQUNmLDJCQUEyQixFQUFFLHVCQUF1QjtnQkFDcEQsMkJBQTJCLEVBQUUsdUJBQXVCO2FBQ3JEO1NBQ0YsQ0FBQTtRQU1DLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQStCLENBQUE7SUFDdEYsQ0FBQztJQUdhLDZDQUFpQixHQUEvQixVQUFnQyxLQUE4RDs7Ozs7Ozt3QkFDeEYsTUFBTSxHQUFHLElBQUksQ0FBQywwQkFBMEIsQ0FBQTt3QkFFNUMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksS0FBSyxJQUFJLE9BQU8sSUFBSSxLQUFLLElBQUksT0FBTyxLQUFLLENBQUMsS0FBSyxLQUFLLFFBQVEsRUFBRTs0QkFDdkYsU0FBUyxHQUFHLE1BQUEsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsMENBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBOzRCQUM5RSxJQUFJLFNBQVM7Z0NBQUUsTUFBTSxHQUFHLFNBQVMsQ0FBQTt5QkFDbEM7d0JBRVksV0FBTSxJQUFJLENBQUMsR0FBRyxDQUFDO2dDQUMxQixHQUFHLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUM7Z0NBQ2hDLElBQUksRUFBRSxLQUFLO2dDQUNYLE1BQU0sRUFBRSxLQUFLOzZCQUNkLENBQUMsRUFBQTs7d0JBSkksR0FBRyxHQUFHLENBQUMsU0FJWCxDQUE4RDt3QkFFaEUsV0FBTyxHQUFHLEVBQUE7Ozs7S0FDWDtJQUVPLDBDQUFjLEdBQXRCLFVBQXVCLE1BQWM7UUFDbkMsT0FBTyxVQUFHLElBQUksQ0FBQyxPQUFPLGNBQUksSUFBSSxDQUFDLFFBQVEsY0FBSSxNQUFNLENBQUUsQ0FBQTtJQUNyRCxDQUFDO0lBQ0gsd0JBQUM7QUFBRCxDQUFDLEFBdENELElBc0NDO0FBdENZLDhDQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgTW9kZWxSZXEsXG4gIC8vIEltYWdlRWRpdElucHV0LFxuICBIdW55dWFuR2VuZXJhdGVJbWFnZUlucHV0LFxuICBIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dCxcbiAgSHVueXVhbkFSR2VuZXJhdGVJbWFnZUlucHV0LFxuICBIdW55dWFuQVJHZW5lcmF0ZUltYWdlT3V0cHV0LFxuICAvLyBIdW55dWFuRWRpdEltYWdlSW5wdXQsXG4gIC8vIEh1bnl1YW5FZGl0SW1hZ2VPdXRwdXQsXG59IGZyb20gJy4uL3R5cGUnXG5cbmludGVyZmFjZSBIdW55dWFuSW1hZ2VHZW5lcmF0ZUZuIHtcbiAgKGlucHV0OiBIdW55dWFuQVJHZW5lcmF0ZUltYWdlSW5wdXQpOiBQcm9taXNlPEh1bnl1YW5BUkdlbmVyYXRlSW1hZ2VPdXRwdXQ+XG4gIChpbnB1dDogSHVueXVhbkdlbmVyYXRlSW1hZ2VJbnB1dCk6IFByb21pc2U8SHVueXVhbkdlbmVyYXRlSW1hZ2VPdXRwdXQ+XG59XG5cbnR5cGUgR2VuZXJhdGVJbWFnZUZuPFRQcm92aWRlcj4gPSBUUHJvdmlkZXIgZXh0ZW5kcyAnaHVueXVhbi1pbWFnZSdcbiAgPyBIdW55dWFuSW1hZ2VHZW5lcmF0ZUZuXG4gIDogKGlucHV0OiB1bmtub3duKSA9PiBQcm9taXNlPHVua25vd24+XG5cbmV4cG9ydCBjbGFzcyBEZWZhdWx0SW1hZ2VNb2RlbDxUUHJvdmlkZXIgZXh0ZW5kcyBzdHJpbmc+IHtcbiAgcHVibGljIGRlZmF1bHRHZW5lcmF0ZUltYWdlU3ViVXJsID0gJ2ltYWdlcy9nZW5lcmF0aW9ucydcblxuICBwdWJsaWMgZ2VuZXJhdGVJbWFnZVN1YlVybENvbmZpZzogUmVjb3JkPHN0cmluZywgUmVjb3JkPHN0cmluZywgc3RyaW5nPj4gPSB7XG4gICAgJ2h1bnl1YW4taW1hZ2UnOiB7XG4gICAgICAnaHVueXVhbi1pbWFnZS12My4wLXYxLjAuNCc6ICdpbWFnZXMvYXIvZ2VuZXJhdGlvbnMnLFxuICAgICAgJ2h1bnl1YW4taW1hZ2UtdjMuMC12MS4wLjEnOiAnaW1hZ2VzL2FyL2dlbmVyYXRpb25zJyxcbiAgICB9LFxuICB9XG5cbiAgLyoqIOeUn+aIkOWbvueJhyAqL1xuICBwdWJsaWMgZ2VuZXJhdGVJbWFnZTogR2VuZXJhdGVJbWFnZUZuPFRQcm92aWRlcj5cblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlcTogTW9kZWxSZXEsIHB1YmxpYyBiYXNlVXJsOiBzdHJpbmcsIHB1YmxpYyBwcm92aWRlcjogVFByb3ZpZGVyKSB7XG4gICAgdGhpcy5nZW5lcmF0ZUltYWdlID0gdGhpcy5nZW5lcmF0ZUltYWdlSW1wbC5iaW5kKHRoaXMpIGFzIEdlbmVyYXRlSW1hZ2VGbjxUUHJvdmlkZXI+XG4gIH1cblxuICAvKiogZ2VuZXJhdGVJbWFnZSDnmoTlrp7pmYXlrp7njrAgKi9cbiAgcHJpdmF0ZSBhc3luYyBnZW5lcmF0ZUltYWdlSW1wbChpbnB1dDogSHVueXVhbkFSR2VuZXJhdGVJbWFnZUlucHV0IHwgSHVueXVhbkdlbmVyYXRlSW1hZ2VJbnB1dCwpOiBQcm9taXNlPEh1bnl1YW5BUkdlbmVyYXRlSW1hZ2VPdXRwdXQgfCBIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dD4ge1xuICAgIGxldCBzdWJVcmwgPSB0aGlzLmRlZmF1bHRHZW5lcmF0ZUltYWdlU3ViVXJsXG5cbiAgICBpZiAodHlwZW9mIGlucHV0ID09PSAnb2JqZWN0JyAmJiBpbnB1dCAmJiAnbW9kZWwnIGluIGlucHV0ICYmIHR5cGVvZiBpbnB1dC5tb2RlbCA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGNvbnN0IG5ld1N1YlVybCA9IHRoaXMuZ2VuZXJhdGVJbWFnZVN1YlVybENvbmZpZ1t0aGlzLnByb3ZpZGVyXT8uW2lucHV0Lm1vZGVsXVxuICAgICAgaWYgKG5ld1N1YlVybCkgc3ViVXJsID0gbmV3U3ViVXJsXG4gICAgfVxuXG4gICAgY29uc3QgcmVzID0gKGF3YWl0IHRoaXMucmVxKHtcbiAgICAgIHVybDogdGhpcy5nZXRHZW5lcmF0ZVVybChzdWJVcmwpLFxuICAgICAgZGF0YTogaW5wdXQsXG4gICAgICBzdHJlYW06IGZhbHNlLFxuICAgIH0pKSBhcyBIdW55dWFuQVJHZW5lcmF0ZUltYWdlT3V0cHV0IHwgSHVueXVhbkdlbmVyYXRlSW1hZ2VPdXRwdXRcblxuICAgIHJldHVybiByZXNcbiAgfVxuXG4gIHByaXZhdGUgZ2V0R2VuZXJhdGVVcmwoc3ViVXJsOiBzdHJpbmcpIHtcbiAgICByZXR1cm4gYCR7dGhpcy5iYXNlVXJsfS8ke3RoaXMucHJvdmlkZXJ9LyR7c3ViVXJsfWBcbiAgfVxufVxuIl19
@@ -123,7 +123,7 @@ export interface ImageEditInput {
123
123
  [key: string]: unknown;
124
124
  }
125
125
  export interface HunyuanGenerateImageInput {
126
- model: 'hunyuan-image' | (string & {});
126
+ model: 'hunyuan-image';
127
127
  prompt: string;
128
128
  version?: 'v1.8.1' | 'v1.9' | (string & {});
129
129
  size?: string;
@@ -134,6 +134,27 @@ export interface HunyuanGenerateImageInput {
134
134
  footnote?: string;
135
135
  seed?: number;
136
136
  }
137
+ export interface HunyuanARGenerateImageInput {
138
+ model: 'hunyuan-image-v3.0-v1.0.4' | 'hunyuan-image-v3.0-v1.0.1';
139
+ prompt: string;
140
+ size?: string;
141
+ seed?: number;
142
+ footnote?: string;
143
+ revise?: {
144
+ value: boolean;
145
+ };
146
+ enable_thinking?: {
147
+ value: boolean;
148
+ };
149
+ }
150
+ export interface HunyuanARGenerateImageOutput {
151
+ id: string;
152
+ created: number;
153
+ data: Array<{
154
+ url: string;
155
+ revised_prompt?: string;
156
+ }>;
157
+ }
137
158
  export type HunyuanEditImageInput = {
138
159
  model: 'hunyuan-image' | (string & {});
139
160
  prompt: string;
package/dist/cjs/type.js CHANGED
@@ -7,4 +7,4 @@ var SimpleChatModel = (function () {
7
7
  return SimpleChatModel;
8
8
  }());
9
9
  exports.SimpleChatModel = SimpleChatModel;
10
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type.js","sourceRoot":"","sources":["../../src/type.ts"],"names":[],"mappings":";;;AAAA;IAAA;IAIA,CAAC;IAAD,sBAAC;AAAD,CAAC,AAJD,IAIC;AAJqB,0CAAe","sourcesContent":["export abstract class SimpleChatModel {\n  public abstract doGenerate(data: BaseChatModelInput, options?: ReqOptions): Promise<DoGenerateOutput>\n\n  public abstract doStream(data: BaseChatModelInput, options?: ReqOptions): Promise<DoStreamOutput>\n}\n\ntype RawResponse = { rawResponse?: any }\n\nexport type DoGenerateOutput = BaseDoGenerateOutput & RawResponse\n\nexport type DoStreamOutput = AsyncIterableReadableStream<BaseDoStreamOutputChunk & RawResponse>\n\nexport type ChatModelConstructor = typeof SimpleChatModel\n\nexport type AsyncIterableReadableStream<T> = ReadableStream<T> & {\n  [Symbol.asyncIterator]: () => { next(): Promise<IteratorResult<T>> }\n}\n\nexport interface IModelReqInput {\n  url: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport type ModelReq = <T extends IModelReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport interface IBotReqInput {\n  url: string\n  method: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport interface ReqOptions {\n  timeout?: number\n}\n\nexport type BotReq = <T extends IBotReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport type UserMessage = {\n  role: 'user'\n  content: string\n}\n\nexport type SystemMessage = {\n  role: 'system'\n  content: string\n}\n\nexport type AssistantMessage = PlainAssistantMessage | ToolCallAssistantMessage\n\nexport type PlainAssistantMessage = {\n  role: 'assistant'\n  content: string\n}\n\nexport type ToolCallAssistantMessage = {\n  role: 'assistant'\n  tool_calls: Array<ToolCall>\n  content?: string\n}\n\nexport type ToolMessage = {\n  role: 'tool'\n  tool_call_id: string\n  content: string\n}\n\nexport type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage\n\nexport type FunctionTool = {\n  name: string\n  description: string\n  fn: CallableFunction\n  parameters: object\n}\n\n// #region 大模型标准输入类型\nexport interface BaseChatModelInput {\n  model: string\n  messages: Array<ChatModelMessage>\n  temperature?: number\n  top_p?: number\n  tools?: Array<ModelTool>\n  tool_choice?: 'none' | 'auto' | 'custom'\n}\n\n/**\n * 给 LLM 发请求时要传的工具\n */\nexport type ModelTool = {\n  type: string\n  function: ModelToolFunction\n}\n\n/**\n * 给 LLM 发请求时要传的工具函数\n */\nexport type ModelToolFunction = {\n  name: string\n  description: string\n  /**\n   * 描述函数参数的 JSON Schema\n   */\n  parameters: object\n}\n// #endregion\n\n// #region 大模型标准响应类型\nexport type ToolCall = {\n  id: string\n  type: string\n  function: { name: string; arguments: string }\n}\n\ntype FinishReason = 'tool_calls' | (string & {})\n\nexport type Usage = {\n  completion_tokens: number\n  prompt_tokens: number\n  total_tokens: number\n}\n\nexport interface BaseDoGenerateOutput {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    message?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n\nexport interface BaseDoStreamOutputChunk {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    delta?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n// #endregion\n\n// #region Image Model Types\n/**\n * 图片生成输入参数\n */\nexport interface ImageGenerateInput {\n  model: string // 模型名称，例如 'hunyuan-image'、'dall-e-3'\n  prompt: string // 用于描述要生成的图片内容\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 图片编辑输入参数\n */\nexport interface ImageEditInput {\n  model: string\n  prompt: string\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 混元图片生成输入参数\n * 接口文档：POST /openapi/v1/images/generations\n */\nexport interface HunyuanGenerateImageInput {\n  /** 模型名称，默认为 hunyuan-image */\n  model: 'hunyuan-image' | (string & {})\n  /** 用来生成图像的文本描述 */\n  prompt: string\n  /**\n   * 模型版本，支持 v1.8.1 和 v1.9，默认版本 v1.8.1\n   * - v1.8.1: 采用二阶段模型支持文生图任务，针对图像细节、稳定性等要求高的任务较为合适\n   * - v1.9: 采用模型矩阵能力支持文生图任务，后端由人像、游戏、通用模型，以及各类功能插件组成，灵活适配多种文生图任务\n   */\n  version?: 'v1.8.1' | 'v1.9' | (string & {})\n  /**\n   * 图片尺寸，默认 \"1024x1024\"\n   * v1.9 仅支持以下几个尺寸：\n   * - 1024x1024\n   * - 1024x768, 1152x864\n   * - 768x1024, 864x1152\n   * - 1280x768 (16:9)\n   * - 768x1280 (9:16)\n   * - 1280x720 (16:9)\n   * - 720x1280 (9:16)\n   *\n   * 支持用户自定义尺寸，但输入尺寸只支持 768-1280 之间且为 64 的倍数的数字\n   */\n  size?: string\n  /**\n   * 仅 v1.9 支持，负向词\n   * 如果不传则使用各个模型内部的默认负向词\n   */\n  negative_prompt?: string\n  /**\n   * 仅 v1.9 支持，可指定风格：\n   * - 古风二次元风格\n   * - 都市二次元风格\n   * - 悬疑风格\n   * - 校园风格\n   * - 都市异能风格\n   */\n  style?: '古风二次元风格' | '都市二次元风格' | '悬疑风格' | '校园风格' | '都市异能风格' | (string & {})\n  /**\n   * 为 true 时对 prompt 进行改写，实际生成的图片会使用改写后的 prompt 进行生成\n   * 多数场景可提升生成的图片效果，默认为 true\n   */\n  revise?: boolean\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * 业务自定义水印内容\n   * 限制 16 个字符长度（不区分中英文），生成在图片右下角\n   */\n  footnote?: string\n  /**\n   * 生成种子，仅当生成图片数为 1 时生效\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n}\n\n/**\n * 混元图片编辑输入参数\n * 接口文档：POST /openapi/v1/images/edits\n */\nexport type HunyuanEditImageInput = {\n  /** 模型名称，本期为 hunyuan-image，即为商品图编辑场景 */\n  model: 'hunyuan-image' | (string & {})\n  /** 编辑的文本描述 */\n  prompt: string\n  /** 模型版本 */\n  version?: string\n  /**\n   * 图片尺寸，默认 \"800x800\"\n   * 支持用户自定义尺寸，但输入尺寸只支持 512-1280 之间\n   * 目前只支持 1:1、16:9、9:16 三个尺寸\n   */\n  size?: string\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * beta 参数，随机种子\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n  /**\n   * 业务自定义角标内容\n   * 限制 16 个字符长度（不区分中英文）\n   */\n  footnote?: string\n  /**\n   * 图 base64 编码，大小不超过 6M\n   * 支持 jpg/jpeg 格式，和 image_url 二选一\n   * 长短边比例要求 2:1 内\n   */\n  image?: string\n  /**\n   * 图片 url\n   * 长短边比例要求 2:1 内，和 image 二选一\n   */\n  image_url?: string\n} & (\n  | {\n    mask: string\n    mask_url?: never\n  }\n  | {\n    mask?: never\n    mask_url: string\n  }\n)\n\n/**\n * 混元图片生成输出\n */\nexport interface HunyuanGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n    /** 原 prompt 改写后的文本。若 revise 为 false，则为原 prompt */\n    revised_prompt?: string\n  }>\n}\n\n/**\n * 混元图片编辑输出\n */\nexport interface HunyuanEditImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n  }>\n}\n\n// #endregion\n"]}
10
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type.js","sourceRoot":"","sources":["../../src/type.ts"],"names":[],"mappings":";;;AAAA;IAAA;IAIA,CAAC;IAAD,sBAAC;AAAD,CAAC,AAJD,IAIC;AAJqB,0CAAe","sourcesContent":["export abstract class SimpleChatModel {\n  public abstract doGenerate(data: BaseChatModelInput, options?: ReqOptions): Promise<DoGenerateOutput>\n\n  public abstract doStream(data: BaseChatModelInput, options?: ReqOptions): Promise<DoStreamOutput>\n}\n\ntype RawResponse = { rawResponse?: any }\n\nexport type DoGenerateOutput = BaseDoGenerateOutput & RawResponse\n\nexport type DoStreamOutput = AsyncIterableReadableStream<BaseDoStreamOutputChunk & RawResponse>\n\nexport type ChatModelConstructor = typeof SimpleChatModel\n\nexport type AsyncIterableReadableStream<T> = ReadableStream<T> & {\n  [Symbol.asyncIterator]: () => { next(): Promise<IteratorResult<T>> }\n}\n\nexport interface IModelReqInput {\n  url: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport type ModelReq = <T extends IModelReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport interface IBotReqInput {\n  url: string\n  method: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport interface ReqOptions {\n  timeout?: number\n}\n\nexport type BotReq = <T extends IBotReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport type UserMessage = {\n  role: 'user'\n  content: string\n}\n\nexport type SystemMessage = {\n  role: 'system'\n  content: string\n}\n\nexport type AssistantMessage = PlainAssistantMessage | ToolCallAssistantMessage\n\nexport type PlainAssistantMessage = {\n  role: 'assistant'\n  content: string\n}\n\nexport type ToolCallAssistantMessage = {\n  role: 'assistant'\n  tool_calls: Array<ToolCall>\n  content?: string\n}\n\nexport type ToolMessage = {\n  role: 'tool'\n  tool_call_id: string\n  content: string\n}\n\nexport type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage\n\nexport type FunctionTool = {\n  name: string\n  description: string\n  fn: CallableFunction\n  parameters: object\n}\n\n// #region 大模型标准输入类型\nexport interface BaseChatModelInput {\n  model: string\n  messages: Array<ChatModelMessage>\n  temperature?: number\n  top_p?: number\n  tools?: Array<ModelTool>\n  tool_choice?: 'none' | 'auto' | 'custom'\n}\n\n/**\n * 给 LLM 发请求时要传的工具\n */\nexport type ModelTool = {\n  type: string\n  function: ModelToolFunction\n}\n\n/**\n * 给 LLM 发请求时要传的工具函数\n */\nexport type ModelToolFunction = {\n  name: string\n  description: string\n  /**\n   * 描述函数参数的 JSON Schema\n   */\n  parameters: object\n}\n// #endregion\n\n// #region 大模型标准响应类型\nexport type ToolCall = {\n  id: string\n  type: string\n  function: { name: string; arguments: string }\n}\n\ntype FinishReason = 'tool_calls' | (string & {})\n\nexport type Usage = {\n  completion_tokens: number\n  prompt_tokens: number\n  total_tokens: number\n}\n\nexport interface BaseDoGenerateOutput {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    message?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n\nexport interface BaseDoStreamOutputChunk {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    delta?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n// #endregion\n\n// #region Image Model Types\n/**\n * 图片生成输入参数\n */\nexport interface ImageGenerateInput {\n  model: string // 模型名称，例如 'hunyuan-image'、'dall-e-3'\n  prompt: string // 用于描述要生成的图片内容\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 图片编辑输入参数\n */\nexport interface ImageEditInput {\n  model: string\n  prompt: string\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\nexport interface HunyuanGenerateImageInput {\n  model: 'hunyuan-image'\n  /** 用来生成图像的文本描述 */\n  prompt: string\n  /**\n   * 模型版本，支持 v1.8.1 和 v1.9，默认版本 v1.8.1\n   * - v1.8.1: 采用二阶段模型支持文生图任务，针对图像细节、稳定性等要求高的任务较为合适\n   * - v1.9: 采用模型矩阵能力支持文生图任务，后端由人像、游戏、通用模型，以及各类功能插件组成，灵活适配多种文生图任务\n   */\n  version?: 'v1.8.1' | 'v1.9' | (string & {})\n  /**\n   * 图片尺寸，默认 \"1024x1024\"\n   * v1.9 仅支持以下几个尺寸：\n   * - 1024x1024\n   * - 1024x768, 1152x864\n   * - 768x1024, 864x1152\n   * - 1280x768 (16:9)\n   * - 768x1280 (9:16)\n   * - 1280x720 (16:9)\n   * - 720x1280 (9:16)\n   *\n   * 支持用户自定义尺寸，但输入尺寸只支持 768-1280 之间且为 64 的倍数的数字\n   */\n  size?: string\n  /**\n   * 仅 v1.9 支持，负向词\n   * 如果不传则使用各个模型内部的默认负向词\n   */\n  negative_prompt?: string\n  /**\n   * 仅 v1.9 支持，可指定风格：\n   * - 古风二次元风格\n   * - 都市二次元风格\n   * - 悬疑风格\n   * - 校园风格\n   * - 都市异能风格\n   */\n  style?: '古风二次元风格' | '都市二次元风格' | '悬疑风格' | '校园风格' | '都市异能风格' | (string & {})\n  /**\n   * 为 true 时对 prompt 进行改写，实际生成的图片会使用改写后的 prompt 进行生成\n   * 多数场景可提升生成的图片效果，默认为 true\n   */\n  revise?: boolean\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * 业务自定义水印内容\n   * 限制 16 个字符长度（不区分中英文），生成在图片右下角\n   */\n  footnote?: string\n  /**\n   * 生成种子，仅当生成图片数为 1 时生效\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n}\n\nexport interface HunyuanARGenerateImageInput {\n  /** 模型名称：hunyuan-image-v3.0-v1.0.4（推荐）或 hunyuan-image-v3.0-v1.0.1 */\n  model: 'hunyuan-image-v3.0-v1.0.4' | 'hunyuan-image-v3.0-v1.0.1'\n  /** 生成图片使用的文本，不超过 8192 字符 */\n  prompt: string\n  /**\n   * 图片尺寸，格式 \"${宽}x${高}\"，默认 \"1024x1024\"\n   * hunyuan-image-v3.0-v1.0.4：宽高 [512, 2048]，面积不超过 1024x1024\n   * hunyuan-image-v3.0-v1.0.1：支持固定尺寸列表\n   */\n  size?: string\n  /** 生成种子，仅当生成图片数为 1 时生效，范围 [1, 4294967295] */\n  seed?: number\n  /** 业务自定义水印内容，限制 16 字符，生成在图片右下角 */\n  footnote?: string\n  /** 是否对 prompt 改写，默认开启。改写会增加约 30s 耗时 */\n  revise?: { value: boolean }\n  /** 改写是否开启 thinking 模式，默认开启。开启后效果提升但耗时增加（最大 60s） */\n  enable_thinking?: { value: boolean }\n}\n\nexport interface HunyuanARGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期 24 小时 */\n    url: string\n    /** 改写后的 prompt */\n    revised_prompt?: string\n  }>\n}\n\nexport type HunyuanEditImageInput = {\n  /** 模型名称，本期为 hunyuan-image，即为商品图编辑场景 */\n  model: 'hunyuan-image' | (string & {})\n  /** 编辑的文本描述 */\n  prompt: string\n  /** 模型版本 */\n  version?: string\n  /**\n   * 图片尺寸，默认 \"800x800\"\n   * 支持用户自定义尺寸，但输入尺寸只支持 512-1280 之间\n   * 目前只支持 1:1、16:9、9:16 三个尺寸\n   */\n  size?: string\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * beta 参数，随机种子\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n  /**\n   * 业务自定义角标内容\n   * 限制 16 个字符长度（不区分中英文）\n   */\n  footnote?: string\n  /**\n   * 图 base64 编码，大小不超过 6M\n   * 支持 jpg/jpeg 格式，和 image_url 二选一\n   * 长短边比例要求 2:1 内\n   */\n  image?: string\n  /**\n   * 图片 url\n   * 长短边比例要求 2:1 内，和 image 二选一\n   */\n  image_url?: string\n} & (\n  | {\n    mask: string\n    mask_url?: never\n  }\n  | {\n    mask?: never\n    mask_url: string\n  }\n)\n\n/**\n * 混元图片生成输出\n */\nexport interface HunyuanGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n    /** 原 prompt 改写后的文本。若 revise 为 false，则为原 prompt */\n    revised_prompt?: string\n  }>\n}\n\n/**\n * 混元图片编辑输出\n */\nexport interface HunyuanEditImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n  }>\n}\n\n// #endregion\n"]}
@@ -1,14 +1,18 @@
1
- import type { ModelReq, ImageGenerateInput, HunyuanGenerateImageInput, HunyuanGenerateImageOutput } from '../type';
2
- type NoInfer<T> = [T][T extends any ? 0 : never];
3
- type GenerateImageInput<TProvider extends string, TInput = unknown> = unknown extends TInput ? TProvider extends 'hunyuan-image' ? HunyuanGenerateImageInput : ImageGenerateInput : TInput;
4
- type GenerateImageOutput<TProvider extends string, TOutput = unknown> = unknown extends TOutput ? TProvider extends 'hunyuan-image' ? HunyuanGenerateImageOutput : unknown : TOutput;
1
+ import type { ModelReq, HunyuanGenerateImageInput, HunyuanGenerateImageOutput, HunyuanARGenerateImageInput, HunyuanARGenerateImageOutput } from '../type';
2
+ interface HunyuanImageGenerateFn {
3
+ (input: HunyuanARGenerateImageInput): Promise<HunyuanARGenerateImageOutput>;
4
+ (input: HunyuanGenerateImageInput): Promise<HunyuanGenerateImageOutput>;
5
+ }
6
+ type GenerateImageFn<TProvider> = TProvider extends 'hunyuan-image' ? HunyuanImageGenerateFn : (input: unknown) => Promise<unknown>;
5
7
  export declare class DefaultImageModel<TProvider extends string> {
6
8
  private req;
7
9
  baseUrl: string;
8
10
  provider: TProvider;
9
- generateImageSubUrl: string;
11
+ defaultGenerateImageSubUrl: string;
12
+ generateImageSubUrlConfig: Record<string, Record<string, string>>;
13
+ generateImage: GenerateImageFn<TProvider>;
10
14
  constructor(req: ModelReq, baseUrl: string, provider: TProvider);
11
- generateImage<TInput = unknown, TOutput = unknown>(input: NoInfer<GenerateImageInput<TProvider, TInput>>): Promise<GenerateImageOutput<TProvider, TOutput>>;
15
+ private generateImageImpl;
12
16
  private getGenerateUrl;
13
17
  }
14
18
  export {};
@@ -39,29 +39,44 @@ var DefaultImageModel = (function () {
39
39
  this.req = req;
40
40
  this.baseUrl = baseUrl;
41
41
  this.provider = provider;
42
- this.generateImageSubUrl = 'images/generations';
42
+ this.defaultGenerateImageSubUrl = 'images/generations';
43
+ this.generateImageSubUrlConfig = {
44
+ 'hunyuan-image': {
45
+ 'hunyuan-image-v3.0-v1.0.4': 'images/ar/generations',
46
+ 'hunyuan-image-v3.0-v1.0.1': 'images/ar/generations',
47
+ },
48
+ };
49
+ this.generateImage = this.generateImageImpl.bind(this);
43
50
  }
44
- DefaultImageModel.prototype.generateImage = function (input) {
51
+ DefaultImageModel.prototype.generateImageImpl = function (input) {
52
+ var _a;
45
53
  return __awaiter(this, void 0, void 0, function () {
46
- var res;
47
- return __generator(this, function (_a) {
48
- switch (_a.label) {
49
- case 0: return [4, this.req({
50
- url: this.getGenerateUrl(),
51
- data: input,
52
- stream: false,
53
- })];
54
+ var subUrl, newSubUrl, res;
55
+ return __generator(this, function (_b) {
56
+ switch (_b.label) {
57
+ case 0:
58
+ subUrl = this.defaultGenerateImageSubUrl;
59
+ if (typeof input === 'object' && input && 'model' in input && typeof input.model === 'string') {
60
+ newSubUrl = (_a = this.generateImageSubUrlConfig[this.provider]) === null || _a === void 0 ? void 0 : _a[input.model];
61
+ if (newSubUrl)
62
+ subUrl = newSubUrl;
63
+ }
64
+ return [4, this.req({
65
+ url: this.getGenerateUrl(subUrl),
66
+ data: input,
67
+ stream: false,
68
+ })];
54
69
  case 1:
55
- res = _a.sent();
70
+ res = (_b.sent());
56
71
  return [2, res];
57
72
  }
58
73
  });
59
74
  });
60
75
  };
61
- DefaultImageModel.prototype.getGenerateUrl = function () {
62
- return "".concat(this.baseUrl, "/").concat(this.provider, "/").concat(this.generateImageSubUrl);
76
+ DefaultImageModel.prototype.getGenerateUrl = function (subUrl) {
77
+ return "".concat(this.baseUrl, "/").concat(this.provider, "/").concat(subUrl);
63
78
  };
64
79
  return DefaultImageModel;
65
80
  }());
66
81
  export { DefaultImageModel };
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWxzL2ltYWdlLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQXFDQTtJQUlFLDJCQUNVLEdBQWEsRUFDZCxPQUFlLEVBQ2YsUUFBbUI7UUFGbEIsUUFBRyxHQUFILEdBQUcsQ0FBVTtRQUNkLFlBQU8sR0FBUCxPQUFPLENBQVE7UUFDZixhQUFRLEdBQVIsUUFBUSxDQUFXO1FBTnJCLHdCQUFtQixHQUFHLG9CQUFvQixDQUFBO0lBTzlDLENBQUM7SUFFUyx5Q0FBYSxHQUExQixVQUFnRSxLQUFxRDs7Ozs7NEJBQ3ZHLFdBQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQzs0QkFDekIsR0FBRyxFQUFFLElBQUksQ0FBQyxjQUFjLEVBQUU7NEJBQzFCLElBQUksRUFBRSxLQUFLOzRCQUNYLE1BQU0sRUFBRSxLQUFLO3lCQUNkLENBQUMsRUFBQTs7d0JBSkksR0FBRyxHQUFHLFNBSVY7d0JBRUYsV0FBTyxHQUE4QyxFQUFBOzs7O0tBQ3REO0lBV08sMENBQWMsR0FBdEI7UUFDRSxPQUFPLFVBQUcsSUFBSSxDQUFDLE9BQU8sY0FBSSxJQUFJLENBQUMsUUFBUSxjQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBRSxDQUFBO0lBQ3ZFLENBQUM7SUFLSCx3QkFBQztBQUFELENBQUMsQUFwQ0QsSUFvQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIE1vZGVsUmVxLFxuICBJbWFnZUdlbmVyYXRlSW5wdXQsXG4gIC8vIEltYWdlRWRpdElucHV0LFxuICBIdW55dWFuR2VuZXJhdGVJbWFnZUlucHV0LFxuICBIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dCxcbiAgLy8gSHVueXVhbkVkaXRJbWFnZUlucHV0LFxuICAvLyBIdW55dWFuRWRpdEltYWdlT3V0cHV0LFxufSBmcm9tICcuLi90eXBlJ1xuXG4vLyBtb2NrIE5vSW5mZXJcbnR5cGUgTm9JbmZlcjxUPiA9IFtUXVtUIGV4dGVuZHMgYW55ID8gMCA6IG5ldmVyXVxuXG50eXBlIEdlbmVyYXRlSW1hZ2VJbnB1dDxUUHJvdmlkZXIgZXh0ZW5kcyBzdHJpbmcsIFRJbnB1dCA9IHVua25vd24+ID0gdW5rbm93biBleHRlbmRzIFRJbnB1dFxuICA/IFRQcm92aWRlciBleHRlbmRzICdodW55dWFuLWltYWdlJ1xuICAgID8gSHVueXVhbkdlbmVyYXRlSW1hZ2VJbnB1dFxuICAgIDogSW1hZ2VHZW5lcmF0ZUlucHV0XG4gIDogVElucHV0XG5cbnR5cGUgR2VuZXJhdGVJbWFnZU91dHB1dDxUUHJvdmlkZXIgZXh0ZW5kcyBzdHJpbmcsIFRPdXRwdXQgPSB1bmtub3duPiA9IHVua25vd24gZXh0ZW5kcyBUT3V0cHV0XG4gID8gVFByb3ZpZGVyIGV4dGVuZHMgJ2h1bnl1YW4taW1hZ2UnXG4gICAgPyBIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dFxuICAgIDogdW5rbm93blxuICA6IFRPdXRwdXRcblxuLy8gdHlwZSBFZGl0SW1hZ2VJbnB1dDxUIGV4dGVuZHMgc3RyaW5nLCBUSW5wdXQgPSB1bmtub3duPiA9IHVua25vd24gZXh0ZW5kcyBUSW5wdXRcbi8vICAgPyBUIGV4dGVuZHMgJ2h1bnl1YW4taW1hZ2UnXG4vLyAgICAgPyBIdW55dWFuRWRpdEltYWdlSW5wdXRcbi8vICAgICA6IEltYWdlRWRpdElucHV0XG4vLyAgIDogVElucHV0XG5cbi8vIHR5cGUgRWRpdEltYWdlT3V0cHV0PFQgZXh0ZW5kcyBzdHJpbmcsIFRPdXRwdXQgPSB1bmtub3duPiA9IHVua25vd24gZXh0ZW5kcyBUT3V0cHV0XG4vLyAgID8gVCBleHRlbmRzICdodW55dWFuLWltYWdlJ1xuLy8gICAgID8gSHVueXVhbkVkaXRJbWFnZU91dHB1dFxuLy8gICAgIDogdW5rbm93blxuLy8gICA6IFRPdXRwdXRcblxuZXhwb3J0IGNsYXNzIERlZmF1bHRJbWFnZU1vZGVsPFRQcm92aWRlciBleHRlbmRzIHN0cmluZz4ge1xuICBwdWJsaWMgZ2VuZXJhdGVJbWFnZVN1YlVybCA9ICdpbWFnZXMvZ2VuZXJhdGlvbnMnXG4gIC8vIHB1YmxpYyBlZGl0SW1hZ2VTdWJVcmwgPSAnaW1hZ2VzL2VkaXRzJ1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgcmVxOiBNb2RlbFJlcSxcbiAgICBwdWJsaWMgYmFzZVVybDogc3RyaW5nLFxuICAgIHB1YmxpYyBwcm92aWRlcjogVFByb3ZpZGVyLFxuICApIHt9XG5cbiAgcHVibGljIGFzeW5jIGdlbmVyYXRlSW1hZ2U8VElucHV0ID0gdW5rbm93biwgVE91dHB1dCA9IHVua25vd24+KGlucHV0OiBOb0luZmVyPEdlbmVyYXRlSW1hZ2VJbnB1dDxUUHJvdmlkZXIsIFRJbnB1dD4+LCk6IFByb21pc2U8R2VuZXJhdGVJbWFnZU91dHB1dDxUUHJvdmlkZXIsIFRPdXRwdXQ+PiB7XG4gICAgY29uc3QgcmVzID0gYXdhaXQgdGhpcy5yZXEoe1xuICAgICAgdXJsOiB0aGlzLmdldEdlbmVyYXRlVXJsKCksXG4gICAgICBkYXRhOiBpbnB1dCxcbiAgICAgIHN0cmVhbTogZmFsc2UsXG4gICAgfSlcblxuICAgIHJldHVybiByZXMgYXMgR2VuZXJhdGVJbWFnZU91dHB1dDxUUHJvdmlkZXIsIFRPdXRwdXQ+XG4gIH1cblxuICAvLyBwdWJsaWMgYXN5bmMgZWRpdEltYWdlPFRJbnB1dCA9IHVua25vd24sIFRPdXRwdXQgPSB1bmtub3duPihpbnB1dDogTm9JbmZlcjxFZGl0SW1hZ2VJbnB1dDxUUHJvdmlkZXIsIFRJbnB1dD4+LCk6IFByb21pc2U8RWRpdEltYWdlT3V0cHV0PFRQcm92aWRlciwgVE91dHB1dD4+IHtcbiAgLy8gICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLnJlcSh7XG4gIC8vICAgICB1cmw6IHRoaXMuZ2V0RWRpdFVybCgpLFxuICAvLyAgICAgZGF0YTogaW5wdXQsXG4gIC8vICAgICBzdHJlYW06IGZhbHNlLFxuICAvLyAgIH0pXG4gIC8vICAgcmV0dXJuIHJlcyBhcyBFZGl0SW1hZ2VPdXRwdXQ8VFByb3ZpZGVyLCBUT3V0cHV0PlxuICAvLyB9XG5cbiAgcHJpdmF0ZSBnZXRHZW5lcmF0ZVVybCgpIHtcbiAgICByZXR1cm4gYCR7dGhpcy5iYXNlVXJsfS8ke3RoaXMucHJvdmlkZXJ9LyR7dGhpcy5nZW5lcmF0ZUltYWdlU3ViVXJsfWBcbiAgfVxuXG4gIC8vIHByaXZhdGUgZ2V0RWRpdFVybCgpIHtcbiAgLy8gICByZXR1cm4gYCR7dGhpcy5iYXNlVXJsfS8ke3RoaXMucHJvdmlkZXJ9LyR7dGhpcy5lZGl0SW1hZ2VTdWJVcmx9YFxuICAvLyB9XG59XG4iXX0=
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtbW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kZWxzL2ltYWdlLW1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQW9CQTtJQWFFLDJCQUFvQixHQUFhLEVBQVMsT0FBZSxFQUFTLFFBQW1CO1FBQWpFLFFBQUcsR0FBSCxHQUFHLENBQVU7UUFBUyxZQUFPLEdBQVAsT0FBTyxDQUFRO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQVo5RSwrQkFBMEIsR0FBRyxvQkFBb0IsQ0FBQTtRQUVqRCw4QkFBeUIsR0FBMkM7WUFDekUsZUFBZSxFQUFFO2dCQUNmLDJCQUEyQixFQUFFLHVCQUF1QjtnQkFDcEQsMkJBQTJCLEVBQUUsdUJBQXVCO2FBQ3JEO1NBQ0YsQ0FBQTtRQU1DLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQStCLENBQUE7SUFDdEYsQ0FBQztJQUdhLDZDQUFpQixHQUEvQixVQUFnQyxLQUE4RDs7Ozs7Ozt3QkFDeEYsTUFBTSxHQUFHLElBQUksQ0FBQywwQkFBMEIsQ0FBQTt3QkFFNUMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksS0FBSyxJQUFJLE9BQU8sSUFBSSxLQUFLLElBQUksT0FBTyxLQUFLLENBQUMsS0FBSyxLQUFLLFFBQVEsRUFBRTs0QkFDdkYsU0FBUyxHQUFHLE1BQUEsSUFBSSxDQUFDLHlCQUF5QixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsMENBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBOzRCQUM5RSxJQUFJLFNBQVM7Z0NBQUUsTUFBTSxHQUFHLFNBQVMsQ0FBQTt5QkFDbEM7d0JBRVksV0FBTSxJQUFJLENBQUMsR0FBRyxDQUFDO2dDQUMxQixHQUFHLEVBQUUsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUM7Z0NBQ2hDLElBQUksRUFBRSxLQUFLO2dDQUNYLE1BQU0sRUFBRSxLQUFLOzZCQUNkLENBQUMsRUFBQTs7d0JBSkksR0FBRyxHQUFHLENBQUMsU0FJWCxDQUE4RDt3QkFFaEUsV0FBTyxHQUFHLEVBQUE7Ozs7S0FDWDtJQUVPLDBDQUFjLEdBQXRCLFVBQXVCLE1BQWM7UUFDbkMsT0FBTyxVQUFHLElBQUksQ0FBQyxPQUFPLGNBQUksSUFBSSxDQUFDLFFBQVEsY0FBSSxNQUFNLENBQUUsQ0FBQTtJQUNyRCxDQUFDO0lBQ0gsd0JBQUM7QUFBRCxDQUFDLEFBdENELElBc0NDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBNb2RlbFJlcSxcbiAgLy8gSW1hZ2VFZGl0SW5wdXQsXG4gIEh1bnl1YW5HZW5lcmF0ZUltYWdlSW5wdXQsXG4gIEh1bnl1YW5HZW5lcmF0ZUltYWdlT3V0cHV0LFxuICBIdW55dWFuQVJHZW5lcmF0ZUltYWdlSW5wdXQsXG4gIEh1bnl1YW5BUkdlbmVyYXRlSW1hZ2VPdXRwdXQsXG4gIC8vIEh1bnl1YW5FZGl0SW1hZ2VJbnB1dCxcbiAgLy8gSHVueXVhbkVkaXRJbWFnZU91dHB1dCxcbn0gZnJvbSAnLi4vdHlwZSdcblxuaW50ZXJmYWNlIEh1bnl1YW5JbWFnZUdlbmVyYXRlRm4ge1xuICAoaW5wdXQ6IEh1bnl1YW5BUkdlbmVyYXRlSW1hZ2VJbnB1dCk6IFByb21pc2U8SHVueXVhbkFSR2VuZXJhdGVJbWFnZU91dHB1dD5cbiAgKGlucHV0OiBIdW55dWFuR2VuZXJhdGVJbWFnZUlucHV0KTogUHJvbWlzZTxIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dD5cbn1cblxudHlwZSBHZW5lcmF0ZUltYWdlRm48VFByb3ZpZGVyPiA9IFRQcm92aWRlciBleHRlbmRzICdodW55dWFuLWltYWdlJ1xuICA/IEh1bnl1YW5JbWFnZUdlbmVyYXRlRm5cbiAgOiAoaW5wdXQ6IHVua25vd24pID0+IFByb21pc2U8dW5rbm93bj5cblxuZXhwb3J0IGNsYXNzIERlZmF1bHRJbWFnZU1vZGVsPFRQcm92aWRlciBleHRlbmRzIHN0cmluZz4ge1xuICBwdWJsaWMgZGVmYXVsdEdlbmVyYXRlSW1hZ2VTdWJVcmwgPSAnaW1hZ2VzL2dlbmVyYXRpb25zJ1xuXG4gIHB1YmxpYyBnZW5lcmF0ZUltYWdlU3ViVXJsQ29uZmlnOiBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+PiA9IHtcbiAgICAnaHVueXVhbi1pbWFnZSc6IHtcbiAgICAgICdodW55dWFuLWltYWdlLXYzLjAtdjEuMC40JzogJ2ltYWdlcy9hci9nZW5lcmF0aW9ucycsXG4gICAgICAnaHVueXVhbi1pbWFnZS12My4wLXYxLjAuMSc6ICdpbWFnZXMvYXIvZ2VuZXJhdGlvbnMnLFxuICAgIH0sXG4gIH1cblxuICAvKiog55Sf5oiQ5Zu+54mHICovXG4gIHB1YmxpYyBnZW5lcmF0ZUltYWdlOiBHZW5lcmF0ZUltYWdlRm48VFByb3ZpZGVyPlxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVxOiBNb2RlbFJlcSwgcHVibGljIGJhc2VVcmw6IHN0cmluZywgcHVibGljIHByb3ZpZGVyOiBUUHJvdmlkZXIpIHtcbiAgICB0aGlzLmdlbmVyYXRlSW1hZ2UgPSB0aGlzLmdlbmVyYXRlSW1hZ2VJbXBsLmJpbmQodGhpcykgYXMgR2VuZXJhdGVJbWFnZUZuPFRQcm92aWRlcj5cbiAgfVxuXG4gIC8qKiBnZW5lcmF0ZUltYWdlIOeahOWunumZheWunueOsCAqL1xuICBwcml2YXRlIGFzeW5jIGdlbmVyYXRlSW1hZ2VJbXBsKGlucHV0OiBIdW55dWFuQVJHZW5lcmF0ZUltYWdlSW5wdXQgfCBIdW55dWFuR2VuZXJhdGVJbWFnZUlucHV0LCk6IFByb21pc2U8SHVueXVhbkFSR2VuZXJhdGVJbWFnZU91dHB1dCB8IEh1bnl1YW5HZW5lcmF0ZUltYWdlT3V0cHV0PiB7XG4gICAgbGV0IHN1YlVybCA9IHRoaXMuZGVmYXVsdEdlbmVyYXRlSW1hZ2VTdWJVcmxcblxuICAgIGlmICh0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnICYmIGlucHV0ICYmICdtb2RlbCcgaW4gaW5wdXQgJiYgdHlwZW9mIGlucHV0Lm1vZGVsID09PSAnc3RyaW5nJykge1xuICAgICAgY29uc3QgbmV3U3ViVXJsID0gdGhpcy5nZW5lcmF0ZUltYWdlU3ViVXJsQ29uZmlnW3RoaXMucHJvdmlkZXJdPy5baW5wdXQubW9kZWxdXG4gICAgICBpZiAobmV3U3ViVXJsKSBzdWJVcmwgPSBuZXdTdWJVcmxcbiAgICB9XG5cbiAgICBjb25zdCByZXMgPSAoYXdhaXQgdGhpcy5yZXEoe1xuICAgICAgdXJsOiB0aGlzLmdldEdlbmVyYXRlVXJsKHN1YlVybCksXG4gICAgICBkYXRhOiBpbnB1dCxcbiAgICAgIHN0cmVhbTogZmFsc2UsXG4gICAgfSkpIGFzIEh1bnl1YW5BUkdlbmVyYXRlSW1hZ2VPdXRwdXQgfCBIdW55dWFuR2VuZXJhdGVJbWFnZU91dHB1dFxuXG4gICAgcmV0dXJuIHJlc1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRHZW5lcmF0ZVVybChzdWJVcmw6IHN0cmluZykge1xuICAgIHJldHVybiBgJHt0aGlzLmJhc2VVcmx9LyR7dGhpcy5wcm92aWRlcn0vJHtzdWJVcmx9YFxuICB9XG59XG4iXX0=
@@ -123,7 +123,7 @@ export interface ImageEditInput {
123
123
  [key: string]: unknown;
124
124
  }
125
125
  export interface HunyuanGenerateImageInput {
126
- model: 'hunyuan-image' | (string & {});
126
+ model: 'hunyuan-image';
127
127
  prompt: string;
128
128
  version?: 'v1.8.1' | 'v1.9' | (string & {});
129
129
  size?: string;
@@ -134,6 +134,27 @@ export interface HunyuanGenerateImageInput {
134
134
  footnote?: string;
135
135
  seed?: number;
136
136
  }
137
+ export interface HunyuanARGenerateImageInput {
138
+ model: 'hunyuan-image-v3.0-v1.0.4' | 'hunyuan-image-v3.0-v1.0.1';
139
+ prompt: string;
140
+ size?: string;
141
+ seed?: number;
142
+ footnote?: string;
143
+ revise?: {
144
+ value: boolean;
145
+ };
146
+ enable_thinking?: {
147
+ value: boolean;
148
+ };
149
+ }
150
+ export interface HunyuanARGenerateImageOutput {
151
+ id: string;
152
+ created: number;
153
+ data: Array<{
154
+ url: string;
155
+ revised_prompt?: string;
156
+ }>;
157
+ }
137
158
  export type HunyuanEditImageInput = {
138
159
  model: 'hunyuan-image' | (string & {});
139
160
  prompt: string;
package/dist/esm/type.js CHANGED
@@ -4,4 +4,4 @@ var SimpleChatModel = (function () {
4
4
  return SimpleChatModel;
5
5
  }());
6
6
  export { SimpleChatModel };
7
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type.js","sourceRoot":"","sources":["../../src/type.ts"],"names":[],"mappings":"AAAA;IAAA;IAIA,CAAC;IAAD,sBAAC;AAAD,CAAC,AAJD,IAIC","sourcesContent":["export abstract class SimpleChatModel {\n  public abstract doGenerate(data: BaseChatModelInput, options?: ReqOptions): Promise<DoGenerateOutput>\n\n  public abstract doStream(data: BaseChatModelInput, options?: ReqOptions): Promise<DoStreamOutput>\n}\n\ntype RawResponse = { rawResponse?: any }\n\nexport type DoGenerateOutput = BaseDoGenerateOutput & RawResponse\n\nexport type DoStreamOutput = AsyncIterableReadableStream<BaseDoStreamOutputChunk & RawResponse>\n\nexport type ChatModelConstructor = typeof SimpleChatModel\n\nexport type AsyncIterableReadableStream<T> = ReadableStream<T> & {\n  [Symbol.asyncIterator]: () => { next(): Promise<IteratorResult<T>> }\n}\n\nexport interface IModelReqInput {\n  url: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport type ModelReq = <T extends IModelReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport interface IBotReqInput {\n  url: string\n  method: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport interface ReqOptions {\n  timeout?: number\n}\n\nexport type BotReq = <T extends IBotReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport type UserMessage = {\n  role: 'user'\n  content: string\n}\n\nexport type SystemMessage = {\n  role: 'system'\n  content: string\n}\n\nexport type AssistantMessage = PlainAssistantMessage | ToolCallAssistantMessage\n\nexport type PlainAssistantMessage = {\n  role: 'assistant'\n  content: string\n}\n\nexport type ToolCallAssistantMessage = {\n  role: 'assistant'\n  tool_calls: Array<ToolCall>\n  content?: string\n}\n\nexport type ToolMessage = {\n  role: 'tool'\n  tool_call_id: string\n  content: string\n}\n\nexport type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage\n\nexport type FunctionTool = {\n  name: string\n  description: string\n  fn: CallableFunction\n  parameters: object\n}\n\n// #region 大模型标准输入类型\nexport interface BaseChatModelInput {\n  model: string\n  messages: Array<ChatModelMessage>\n  temperature?: number\n  top_p?: number\n  tools?: Array<ModelTool>\n  tool_choice?: 'none' | 'auto' | 'custom'\n}\n\n/**\n * 给 LLM 发请求时要传的工具\n */\nexport type ModelTool = {\n  type: string\n  function: ModelToolFunction\n}\n\n/**\n * 给 LLM 发请求时要传的工具函数\n */\nexport type ModelToolFunction = {\n  name: string\n  description: string\n  /**\n   * 描述函数参数的 JSON Schema\n   */\n  parameters: object\n}\n// #endregion\n\n// #region 大模型标准响应类型\nexport type ToolCall = {\n  id: string\n  type: string\n  function: { name: string; arguments: string }\n}\n\ntype FinishReason = 'tool_calls' | (string & {})\n\nexport type Usage = {\n  completion_tokens: number\n  prompt_tokens: number\n  total_tokens: number\n}\n\nexport interface BaseDoGenerateOutput {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    message?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n\nexport interface BaseDoStreamOutputChunk {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    delta?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n// #endregion\n\n// #region Image Model Types\n/**\n * 图片生成输入参数\n */\nexport interface ImageGenerateInput {\n  model: string // 模型名称，例如 'hunyuan-image'、'dall-e-3'\n  prompt: string // 用于描述要生成的图片内容\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 图片编辑输入参数\n */\nexport interface ImageEditInput {\n  model: string\n  prompt: string\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 混元图片生成输入参数\n * 接口文档：POST /openapi/v1/images/generations\n */\nexport interface HunyuanGenerateImageInput {\n  /** 模型名称，默认为 hunyuan-image */\n  model: 'hunyuan-image' | (string & {})\n  /** 用来生成图像的文本描述 */\n  prompt: string\n  /**\n   * 模型版本，支持 v1.8.1 和 v1.9，默认版本 v1.8.1\n   * - v1.8.1: 采用二阶段模型支持文生图任务，针对图像细节、稳定性等要求高的任务较为合适\n   * - v1.9: 采用模型矩阵能力支持文生图任务，后端由人像、游戏、通用模型，以及各类功能插件组成，灵活适配多种文生图任务\n   */\n  version?: 'v1.8.1' | 'v1.9' | (string & {})\n  /**\n   * 图片尺寸，默认 \"1024x1024\"\n   * v1.9 仅支持以下几个尺寸：\n   * - 1024x1024\n   * - 1024x768, 1152x864\n   * - 768x1024, 864x1152\n   * - 1280x768 (16:9)\n   * - 768x1280 (9:16)\n   * - 1280x720 (16:9)\n   * - 720x1280 (9:16)\n   *\n   * 支持用户自定义尺寸，但输入尺寸只支持 768-1280 之间且为 64 的倍数的数字\n   */\n  size?: string\n  /**\n   * 仅 v1.9 支持，负向词\n   * 如果不传则使用各个模型内部的默认负向词\n   */\n  negative_prompt?: string\n  /**\n   * 仅 v1.9 支持，可指定风格：\n   * - 古风二次元风格\n   * - 都市二次元风格\n   * - 悬疑风格\n   * - 校园风格\n   * - 都市异能风格\n   */\n  style?: '古风二次元风格' | '都市二次元风格' | '悬疑风格' | '校园风格' | '都市异能风格' | (string & {})\n  /**\n   * 为 true 时对 prompt 进行改写，实际生成的图片会使用改写后的 prompt 进行生成\n   * 多数场景可提升生成的图片效果，默认为 true\n   */\n  revise?: boolean\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * 业务自定义水印内容\n   * 限制 16 个字符长度（不区分中英文），生成在图片右下角\n   */\n  footnote?: string\n  /**\n   * 生成种子，仅当生成图片数为 1 时生效\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n}\n\n/**\n * 混元图片编辑输入参数\n * 接口文档：POST /openapi/v1/images/edits\n */\nexport type HunyuanEditImageInput = {\n  /** 模型名称，本期为 hunyuan-image，即为商品图编辑场景 */\n  model: 'hunyuan-image' | (string & {})\n  /** 编辑的文本描述 */\n  prompt: string\n  /** 模型版本 */\n  version?: string\n  /**\n   * 图片尺寸，默认 \"800x800\"\n   * 支持用户自定义尺寸，但输入尺寸只支持 512-1280 之间\n   * 目前只支持 1:1、16:9、9:16 三个尺寸\n   */\n  size?: string\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * beta 参数，随机种子\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n  /**\n   * 业务自定义角标内容\n   * 限制 16 个字符长度（不区分中英文）\n   */\n  footnote?: string\n  /**\n   * 图 base64 编码，大小不超过 6M\n   * 支持 jpg/jpeg 格式，和 image_url 二选一\n   * 长短边比例要求 2:1 内\n   */\n  image?: string\n  /**\n   * 图片 url\n   * 长短边比例要求 2:1 内，和 image 二选一\n   */\n  image_url?: string\n} & (\n  | {\n    mask: string\n    mask_url?: never\n  }\n  | {\n    mask?: never\n    mask_url: string\n  }\n)\n\n/**\n * 混元图片生成输出\n */\nexport interface HunyuanGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n    /** 原 prompt 改写后的文本。若 revise 为 false，则为原 prompt */\n    revised_prompt?: string\n  }>\n}\n\n/**\n * 混元图片编辑输出\n */\nexport interface HunyuanEditImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n  }>\n}\n\n// #endregion\n"]}
7
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"type.js","sourceRoot":"","sources":["../../src/type.ts"],"names":[],"mappings":"AAAA;IAAA;IAIA,CAAC;IAAD,sBAAC;AAAD,CAAC,AAJD,IAIC","sourcesContent":["export abstract class SimpleChatModel {\n  public abstract doGenerate(data: BaseChatModelInput, options?: ReqOptions): Promise<DoGenerateOutput>\n\n  public abstract doStream(data: BaseChatModelInput, options?: ReqOptions): Promise<DoStreamOutput>\n}\n\ntype RawResponse = { rawResponse?: any }\n\nexport type DoGenerateOutput = BaseDoGenerateOutput & RawResponse\n\nexport type DoStreamOutput = AsyncIterableReadableStream<BaseDoStreamOutputChunk & RawResponse>\n\nexport type ChatModelConstructor = typeof SimpleChatModel\n\nexport type AsyncIterableReadableStream<T> = ReadableStream<T> & {\n  [Symbol.asyncIterator]: () => { next(): Promise<IteratorResult<T>> }\n}\n\nexport interface IModelReqInput {\n  url: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport type ModelReq = <T extends IModelReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport interface IBotReqInput {\n  url: string\n  method: string\n  headers?: Record<string, string>\n  data?: Object\n  stream?: boolean\n  timeout?: number\n}\n\nexport interface ReqOptions {\n  timeout?: number\n}\n\nexport type BotReq = <T extends IBotReqInput>(\n  props: T,\n) => T['stream'] extends true ? Promise<ReadableStream<Uint8Array>> : Promise<Object>\n\nexport type UserMessage = {\n  role: 'user'\n  content: string\n}\n\nexport type SystemMessage = {\n  role: 'system'\n  content: string\n}\n\nexport type AssistantMessage = PlainAssistantMessage | ToolCallAssistantMessage\n\nexport type PlainAssistantMessage = {\n  role: 'assistant'\n  content: string\n}\n\nexport type ToolCallAssistantMessage = {\n  role: 'assistant'\n  tool_calls: Array<ToolCall>\n  content?: string\n}\n\nexport type ToolMessage = {\n  role: 'tool'\n  tool_call_id: string\n  content: string\n}\n\nexport type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage\n\nexport type FunctionTool = {\n  name: string\n  description: string\n  fn: CallableFunction\n  parameters: object\n}\n\n// #region 大模型标准输入类型\nexport interface BaseChatModelInput {\n  model: string\n  messages: Array<ChatModelMessage>\n  temperature?: number\n  top_p?: number\n  tools?: Array<ModelTool>\n  tool_choice?: 'none' | 'auto' | 'custom'\n}\n\n/**\n * 给 LLM 发请求时要传的工具\n */\nexport type ModelTool = {\n  type: string\n  function: ModelToolFunction\n}\n\n/**\n * 给 LLM 发请求时要传的工具函数\n */\nexport type ModelToolFunction = {\n  name: string\n  description: string\n  /**\n   * 描述函数参数的 JSON Schema\n   */\n  parameters: object\n}\n// #endregion\n\n// #region 大模型标准响应类型\nexport type ToolCall = {\n  id: string\n  type: string\n  function: { name: string; arguments: string }\n}\n\ntype FinishReason = 'tool_calls' | (string & {})\n\nexport type Usage = {\n  completion_tokens: number\n  prompt_tokens: number\n  total_tokens: number\n}\n\nexport interface BaseDoGenerateOutput {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    message?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n\nexport interface BaseDoStreamOutputChunk {\n  choices?: Array<{\n    finish_reason?: FinishReason\n    delta?: ChatModelMessage\n  }>\n  usage?: Usage\n}\n// #endregion\n\n// #region Image Model Types\n/**\n * 图片生成输入参数\n */\nexport interface ImageGenerateInput {\n  model: string // 模型名称，例如 'hunyuan-image'、'dall-e-3'\n  prompt: string // 用于描述要生成的图片内容\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\n/**\n * 图片编辑输入参数\n */\nexport interface ImageEditInput {\n  model: string\n  prompt: string\n  size?: string // 尺寸\n  n?: number // 张数\n  [key: string]: unknown // 允许额外的厂商特定参数\n}\n\nexport interface HunyuanGenerateImageInput {\n  model: 'hunyuan-image'\n  /** 用来生成图像的文本描述 */\n  prompt: string\n  /**\n   * 模型版本，支持 v1.8.1 和 v1.9，默认版本 v1.8.1\n   * - v1.8.1: 采用二阶段模型支持文生图任务，针对图像细节、稳定性等要求高的任务较为合适\n   * - v1.9: 采用模型矩阵能力支持文生图任务，后端由人像、游戏、通用模型，以及各类功能插件组成，灵活适配多种文生图任务\n   */\n  version?: 'v1.8.1' | 'v1.9' | (string & {})\n  /**\n   * 图片尺寸，默认 \"1024x1024\"\n   * v1.9 仅支持以下几个尺寸：\n   * - 1024x1024\n   * - 1024x768, 1152x864\n   * - 768x1024, 864x1152\n   * - 1280x768 (16:9)\n   * - 768x1280 (9:16)\n   * - 1280x720 (16:9)\n   * - 720x1280 (9:16)\n   *\n   * 支持用户自定义尺寸，但输入尺寸只支持 768-1280 之间且为 64 的倍数的数字\n   */\n  size?: string\n  /**\n   * 仅 v1.9 支持，负向词\n   * 如果不传则使用各个模型内部的默认负向词\n   */\n  negative_prompt?: string\n  /**\n   * 仅 v1.9 支持，可指定风格：\n   * - 古风二次元风格\n   * - 都市二次元风格\n   * - 悬疑风格\n   * - 校园风格\n   * - 都市异能风格\n   */\n  style?: '古风二次元风格' | '都市二次元风格' | '悬疑风格' | '校园风格' | '都市异能风格' | (string & {})\n  /**\n   * 为 true 时对 prompt 进行改写，实际生成的图片会使用改写后的 prompt 进行生成\n   * 多数场景可提升生成的图片效果，默认为 true\n   */\n  revise?: boolean\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * 业务自定义水印内容\n   * 限制 16 个字符长度（不区分中英文），生成在图片右下角\n   */\n  footnote?: string\n  /**\n   * 生成种子，仅当生成图片数为 1 时生效\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n}\n\nexport interface HunyuanARGenerateImageInput {\n  /** 模型名称：hunyuan-image-v3.0-v1.0.4（推荐）或 hunyuan-image-v3.0-v1.0.1 */\n  model: 'hunyuan-image-v3.0-v1.0.4' | 'hunyuan-image-v3.0-v1.0.1'\n  /** 生成图片使用的文本，不超过 8192 字符 */\n  prompt: string\n  /**\n   * 图片尺寸，格式 \"${宽}x${高}\"，默认 \"1024x1024\"\n   * hunyuan-image-v3.0-v1.0.4：宽高 [512, 2048]，面积不超过 1024x1024\n   * hunyuan-image-v3.0-v1.0.1：支持固定尺寸列表\n   */\n  size?: string\n  /** 生成种子，仅当生成图片数为 1 时生效，范围 [1, 4294967295] */\n  seed?: number\n  /** 业务自定义水印内容，限制 16 字符，生成在图片右下角 */\n  footnote?: string\n  /** 是否对 prompt 改写，默认开启。改写会增加约 30s 耗时 */\n  revise?: { value: boolean }\n  /** 改写是否开启 thinking 模式，默认开启。开启后效果提升但耗时增加（最大 60s） */\n  enable_thinking?: { value: boolean }\n}\n\nexport interface HunyuanARGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期 24 小时 */\n    url: string\n    /** 改写后的 prompt */\n    revised_prompt?: string\n  }>\n}\n\nexport type HunyuanEditImageInput = {\n  /** 模型名称，本期为 hunyuan-image，即为商品图编辑场景 */\n  model: 'hunyuan-image' | (string & {})\n  /** 编辑的文本描述 */\n  prompt: string\n  /** 模型版本 */\n  version?: string\n  /**\n   * 图片尺寸，默认 \"800x800\"\n   * 支持用户自定义尺寸，但输入尺寸只支持 512-1280 之间\n   * 目前只支持 1:1、16:9、9:16 三个尺寸\n   */\n  size?: string\n  /**\n   * 生成图片个数，默认为 1\n   * 目前只支持生成一张，固定为 1，传其他的值会报错\n   */\n  n?: number\n  /**\n   * beta 参数，随机种子\n   * 范围 [1, 4294967295]，不传时默认随机\n   */\n  seed?: number\n  /**\n   * 业务自定义角标内容\n   * 限制 16 个字符长度（不区分中英文）\n   */\n  footnote?: string\n  /**\n   * 图 base64 编码，大小不超过 6M\n   * 支持 jpg/jpeg 格式，和 image_url 二选一\n   * 长短边比例要求 2:1 内\n   */\n  image?: string\n  /**\n   * 图片 url\n   * 长短边比例要求 2:1 内，和 image 二选一\n   */\n  image_url?: string\n} & (\n  | {\n    mask: string\n    mask_url?: never\n  }\n  | {\n    mask?: never\n    mask_url: string\n  }\n)\n\n/**\n * 混元图片生成输出\n */\nexport interface HunyuanGenerateImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n    /** 原 prompt 改写后的文本。若 revise 为 false，则为原 prompt */\n    revised_prompt?: string\n  }>\n}\n\n/**\n * 混元图片编辑输出\n */\nexport interface HunyuanEditImageOutput {\n  /** 此次请求的 id */\n  id: string\n  /** unix 时间戳 */\n  created: number\n  /** 返回的图片生成内容 */\n  data: Array<{\n    /** 生成的图片 url，有效期为 24 小时 */\n    url: string\n  }>\n}\n\n// #endregion\n"]}