mirror of
https://github.com/LLOneBot/LLOneBot.git
synced 2024-11-22 01:56:33 +00:00
Merge branch 'main' into dev
This commit is contained in:
commit
3303b30c4c
@ -47,7 +47,7 @@ export class NTQQFileApi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 上传文件到QQ的文件夹
|
// 上传文件到QQ的文件夹
|
||||||
static async uploadFile(filePath: string, elementType: ElementType = ElementType.PIC) {
|
static async uploadFile(filePath: string, elementType: ElementType = ElementType.PIC, elementSubType: number = 0) {
|
||||||
const md5 = await NTQQFileApi.getFileMd5(filePath);
|
const md5 = await NTQQFileApi.getFileMd5(filePath);
|
||||||
let ext = (await NTQQFileApi.getFileType(filePath))?.ext
|
let ext = (await NTQQFileApi.getFileType(filePath))?.ext
|
||||||
if (ext) {
|
if (ext) {
|
||||||
@ -66,7 +66,7 @@ export class NTQQFileApi {
|
|||||||
md5HexStr: md5,
|
md5HexStr: md5,
|
||||||
fileName: fileName,
|
fileName: fileName,
|
||||||
elementType: elementType,
|
elementType: elementType,
|
||||||
elementSubType: 0,
|
elementSubType,
|
||||||
thumbSize: 0,
|
thumbSize: 0,
|
||||||
needCreate: true,
|
needCreate: true,
|
||||||
downloadType: 1,
|
downloadType: 1,
|
||||||
@ -81,7 +81,8 @@ export class NTQQFileApi {
|
|||||||
md5,
|
md5,
|
||||||
fileName,
|
fileName,
|
||||||
path: mediaPath,
|
path: mediaPath,
|
||||||
fileSize
|
fileSize,
|
||||||
|
ext
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,32 +62,32 @@ export class SendMsgElementConstructor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static async pic(picPath: string, summary: string = ""): Promise<SendPicElement> {
|
static async pic(picPath: string, summary: string = "", subType: 0|1=0): Promise<SendPicElement> {
|
||||||
const {md5, fileName, path, fileSize} = await NTQQFileApi.uploadFile(picPath, ElementType.PIC);
|
const {md5, fileName, path, fileSize, ext} = await NTQQFileApi.uploadFile(picPath, ElementType.PIC, subType);
|
||||||
if (fileSize === 0) {
|
if (fileSize === 0) {
|
||||||
throw "文件异常,大小为0";
|
throw "文件异常,大小为0";
|
||||||
}
|
}
|
||||||
const imageSize = await NTQQFileApi.getImageSize(picPath);
|
const imageSize = await NTQQFileApi.getImageSize(picPath);
|
||||||
const picElement = {
|
const picElement = {
|
||||||
md5HexStr: md5,
|
md5HexStr: md5,
|
||||||
fileSize: fileSize,
|
fileSize: fileSize.toString(),
|
||||||
picWidth: imageSize.width,
|
picWidth: imageSize.width,
|
||||||
picHeight: imageSize.height,
|
picHeight: imageSize.height,
|
||||||
fileName: fileName,
|
fileName: md5 + ext,
|
||||||
sourcePath: path,
|
sourcePath: path,
|
||||||
original: true,
|
original: true,
|
||||||
picType: isGIF(picPath) ? PicType.gif : PicType.jpg,
|
picType: isGIF(picPath) ? PicType.gif : PicType.jpg,
|
||||||
picSubType: 0,
|
picSubType: subType,
|
||||||
fileUuid: "",
|
fileUuid: "",
|
||||||
fileSubId: "",
|
fileSubId: "",
|
||||||
thumbFileSize: 0,
|
thumbFileSize: 0,
|
||||||
summary,
|
summary
|
||||||
};
|
};
|
||||||
|
log("图片信息", picElement)
|
||||||
return {
|
return {
|
||||||
elementType: ElementType.PIC,
|
elementType: ElementType.PIC,
|
||||||
elementId: "",
|
elementId: "",
|
||||||
picElement
|
picElement,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ export class SendMsgElementConstructor {
|
|||||||
let thumb = path.replace(`${pathLib.sep}Ori${pathLib.sep}`, `${pathLib.sep}Thumb${pathLib.sep}`)
|
let thumb = path.replace(`${pathLib.sep}Ori${pathLib.sep}`, `${pathLib.sep}Thumb${pathLib.sep}`)
|
||||||
thumb = pathLib.dirname(thumb)
|
thumb = pathLib.dirname(thumb)
|
||||||
// log("thumb 目录", thumb)
|
// log("thumb 目录", thumb)
|
||||||
let videoInfo ={
|
let videoInfo = {
|
||||||
width: 1920, height: 1080,
|
width: 1920, height: 1080,
|
||||||
time: 15,
|
time: 15,
|
||||||
format: "mp4",
|
format: "mp4",
|
||||||
@ -128,7 +128,7 @@ export class SendMsgElementConstructor {
|
|||||||
try {
|
try {
|
||||||
videoInfo = await getVideoInfo(path);
|
videoInfo = await getVideoInfo(path);
|
||||||
log("视频信息", videoInfo)
|
log("视频信息", videoInfo)
|
||||||
}catch (e) {
|
} catch (e) {
|
||||||
log("获取视频信息失败", e)
|
log("获取视频信息失败", e)
|
||||||
}
|
}
|
||||||
const createThumb = new Promise<string>((resolve, reject) => {
|
const createThumb = new Promise<string>((resolve, reject) => {
|
||||||
|
@ -49,24 +49,29 @@ export enum PicType {
|
|||||||
jpg = 1000
|
jpg = 1000
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export enum PicSubType {
|
||||||
|
normal = 0, // 普通图片,大图
|
||||||
|
face = 1 // 表情包小图
|
||||||
|
}
|
||||||
|
|
||||||
export interface SendPicElement {
|
export interface SendPicElement {
|
||||||
elementType: ElementType.PIC,
|
elementType: ElementType.PIC,
|
||||||
elementId: "",
|
elementId: "",
|
||||||
picElement: {
|
picElement: {
|
||||||
md5HexStr: string,
|
md5HexStr: string,
|
||||||
fileSize: number,
|
fileSize: number | string,
|
||||||
picWidth: number,
|
picWidth: number,
|
||||||
picHeight: number,
|
picHeight: number,
|
||||||
fileName: string,
|
fileName: string,
|
||||||
sourcePath: string,
|
sourcePath: string,
|
||||||
original: boolean,
|
original: boolean,
|
||||||
picType: PicType,
|
picType: PicType,
|
||||||
picSubType: number,
|
picSubType: PicSubType,
|
||||||
fileUuid: string,
|
fileUuid: string,
|
||||||
fileSubId: string,
|
fileSubId: string,
|
||||||
thumbFileSize: number,
|
thumbFileSize: number,
|
||||||
summary: string,
|
summary: string,
|
||||||
}
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface SendReplyElement {
|
export interface SendReplyElement {
|
||||||
@ -200,7 +205,7 @@ export interface GrayTipElement {
|
|||||||
xmlElement: {
|
xmlElement: {
|
||||||
content: string;
|
content: string;
|
||||||
},
|
},
|
||||||
jsonGrayTipElement:{
|
jsonGrayTipElement: {
|
||||||
jsonStr: string;
|
jsonStr: string;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -248,6 +253,7 @@ export interface MarketFaceElement {
|
|||||||
],
|
],
|
||||||
"apngSupportSize": null
|
"apngSupportSize": null
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface VideoElement {
|
export interface VideoElement {
|
||||||
"filePath": string,
|
"filePath": string,
|
||||||
"fileName": string,
|
"fileName": string,
|
||||||
|
@ -2,7 +2,7 @@ import {
|
|||||||
AtType,
|
AtType,
|
||||||
ChatType,
|
ChatType,
|
||||||
ElementType,
|
ElementType,
|
||||||
Group,
|
Group, PicSubType,
|
||||||
RawMessage,
|
RawMessage,
|
||||||
SendArkElement,
|
SendArkElement,
|
||||||
SendMessageElement
|
SendMessageElement
|
||||||
@ -188,7 +188,7 @@ export async function createSendElements(messageData: OB11MessageData[], group:
|
|||||||
} else if (sendMsg.type === OB11MessageDataType.voice) {
|
} else if (sendMsg.type === OB11MessageDataType.voice) {
|
||||||
sendElements.push(await SendMsgElementConstructor.ptt(path));
|
sendElements.push(await SendMsgElementConstructor.ptt(path));
|
||||||
} else if (sendMsg.type === OB11MessageDataType.image) {
|
} else if (sendMsg.type === OB11MessageDataType.image) {
|
||||||
sendElements.push(await SendMsgElementConstructor.pic(path, sendMsg.data.summary || ""));
|
sendElements.push(await SendMsgElementConstructor.pic(path, sendMsg.data.summary || "", <PicSubType>parseInt(sendMsg.data?.subType?.toString()) || 0));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import {RawMessage} from "../ntqqapi/types";
|
import {PicSubType, RawMessage} from "../ntqqapi/types";
|
||||||
import {EventType} from "./event/OB11BaseEvent";
|
import {EventType} from "./event/OB11BaseEvent";
|
||||||
|
|
||||||
export interface OB11User {
|
export interface OB11User {
|
||||||
@ -134,11 +134,13 @@ interface OB11MessageFileBase {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export interface OB11MessageImage extends OB11MessageFileBase {
|
export interface OB11MessageImage extends OB11MessageFileBase {
|
||||||
type: OB11MessageDataType.image
|
type: OB11MessageDataType.image
|
||||||
data: OB11MessageFileBase['data'] & {
|
data: OB11MessageFileBase['data'] & {
|
||||||
summary ? : string; // 图片摘要
|
summary ? : string; // 图片摘要
|
||||||
}
|
subType?: PicSubType
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface OB11MessageRecord extends OB11MessageFileBase {
|
export interface OB11MessageRecord extends OB11MessageFileBase {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user