napcat-sdk 0.5.1 → 0.6.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.
package/dist/index.d.mts CHANGED
@@ -6,7 +6,21 @@ declare const ABSTRACT_LOGGER: Logger;
6
6
  declare const CONSOLE_LOGGER: Logger;
7
7
  //#endregion
8
8
  //#region src/types.d.ts
9
- interface MiokiOptions {
9
+ interface Stat {
10
+ /** 启动时间,Unix 时间戳(毫秒) */
11
+ start_time: number;
12
+ /** 已接受消息数 */
13
+ recv: {
14
+ group: number;
15
+ private: number;
16
+ };
17
+ /** 已发送消息数 */
18
+ send: {
19
+ group: number;
20
+ private: number;
21
+ };
22
+ }
23
+ interface NapcatOptions {
10
24
  /** NapCat 访问令牌 */
11
25
  token: string;
12
26
  /** NapCat 服务器协议,默认为 ws */
@@ -39,7 +53,7 @@ interface EventMap extends OneBotEventMap {
39
53
  app_name: string;
40
54
  app_version: string;
41
55
  protocol_version: string;
42
- ts: number;
56
+ timestamp: number;
43
57
  };
44
58
  }
45
59
  /**
@@ -428,7 +442,7 @@ interface Group {
428
442
  /** NapCat 实例 */
429
443
  napcat: NapCat;
430
444
  /** 群签到 */
431
- doSign: () => Promise<string>;
445
+ sign: () => Promise<string>;
432
446
  /** 获取群信息 */
433
447
  getInfo: () => Promise<{
434
448
  group_all_shut: number;
@@ -439,21 +453,21 @@ interface Group {
439
453
  max_member_count: number;
440
454
  }>;
441
455
  /** 获取群成员列表 */
442
- getMemberList: () => Promise<any>;
456
+ getMemberList: () => Promise<GroupMemberInfo[]>;
443
457
  /** 获取群成员信息 */
444
- getMemberInfo: (user_id: number) => Promise<any>;
458
+ getMemberInfo: (user_id: number) => Promise<GroupMemberInfo>;
445
459
  /** 设置群头衔 */
446
- setTitle: (title: string) => Promise<any>;
460
+ setTitle: (user_id: number, title: string) => Promise<any>;
447
461
  /** 设置群名片 */
448
462
  setCard: (user_id: number, card: string) => Promise<any>;
449
- /** 添加群精华消息 */
450
- addEssence: (message_id: string) => Promise<any>;
451
- /** 删除群精华消息 */
452
- delEssence: (message_id: string) => Promise<any>;
463
+ /** 设置群精华消息 */
464
+ setEssence: (message_id: number) => Promise<any>;
465
+ /** 移除群精华消息 */
466
+ delEssence: (message_id: number) => Promise<any>;
453
467
  /** 撤回群消息 */
454
468
  recall: (message_id: number) => Promise<any>;
455
469
  /** 禁言群成员 */
456
- banMember: (user_id: number, duration: number) => Promise<any>;
470
+ ban: (user_id: number, duration: number) => Promise<any>;
457
471
  /** 发送群消息 */
458
472
  sendMsg: SendMsg;
459
473
  }
@@ -581,7 +595,7 @@ type MessageEventBase<T extends MessageType, U$1 extends object> = EventBase<"me
581
595
  raw_message: string;
582
596
  /** 消息段数组 */
583
597
  message: RecvElement[];
584
- /** 回复消息的方法 */
598
+ /** 回复消息 */
585
599
  reply: Reply;
586
600
  }>;
587
601
  /**
@@ -620,18 +634,20 @@ type GroupMessageEvent = MessageEventBase<"group", {
620
634
  user_id: number;
621
635
  /** 群消息子类型:normal-普通消息, notice-通知消息 */
622
636
  sub_type: "normal" | "notice";
623
- /** 撤回该消息的方法 */
637
+ /** 撤回该消息 */
624
638
  recall: Recall;
625
- /** 添加消息表态的方法 */
639
+ /** 添加消息表态 */
626
640
  addReaction: ReactionAction;
627
- /** 删除消息表态的方法 */
641
+ /** 删除消息表态 */
628
642
  delReaction: ReactionAction;
629
643
  /** 获取引用的消息 */
630
644
  getQuoteMessage: () => Promise<GroupMessageEvent | null>;
631
- /** 添加精华消息的方法 */
632
- addEssence: () => Promise<void>;
633
- /** 删除精华消息的方法 */
645
+ /** 设置精华消息 */
646
+ setEssence: () => Promise<void>;
647
+ /** 删除精华消息 */
634
648
  delEssence: () => Promise<void>;
649
+ /** 获取发送者作为群成员的相关信息,如群身份、群名片等 */
650
+ getSenderMemberInfo: () => Promise<any>;
635
651
  /** 群信息对象 */
636
652
  group: Group;
637
653
  /** 发送者信息 */
@@ -840,9 +856,9 @@ type RequestEventBase<T extends string, U$1 extends object> = EventBase<"request
840
856
  }>;
841
857
  /** 好友添加请求事件 */
842
858
  type FriendRequestEvent = RequestEventBase<"friend", {
843
- /** 同意添加好友请求的方法 */
859
+ /** 同意添加好友请求 */
844
860
  approve: () => Promise<void>;
845
- /** 拒绝添加好友请求的方法 */
861
+ /** 拒绝添加好友请求 */
846
862
  reject: (reason?: string) => Promise<void>;
847
863
  }>;
848
864
  /** 加群请求事件(他人申请加入群) */
@@ -851,9 +867,9 @@ type GroupAddRequestEvent = RequestEventBase<"group", {
851
867
  group_id: number;
852
868
  /** 请求子类型:add-主动加群 */
853
869
  sub_type: "add";
854
- /** 同意群请求的方法 */
870
+ /** 同意群请求 */
855
871
  approve: () => Promise<void>;
856
- /** 拒绝群请求的方法 */
872
+ /** 拒绝群请求 */
857
873
  reject: (reason?: string) => Promise<void>;
858
874
  }>;
859
875
  /** 邀请入群请求事件(他人邀请机器人入群) */
@@ -961,6 +977,26 @@ type OneBotAPI = "delete_friend" | "delete_msg" | "get_forward_msg" | "get_frien
961
977
  type NapCatExtendAPI = "_del_group_notice" | "_get_group_notice" | "_get_model_show" | "_mark_all_as_read" | "_send_group_notice" | "_set_model_show" | ".handle_quick_operation" | ".ocr_image" | "ArkShareGroup" | "ArkSharePeer" | "bot_exit" | "can_send_image" | "can_send_record" | "clean_cache" | "click_inline_keyboard_button" | "create_collection" | "create_group_file_folder" | "delete_essence_msg" | "delete_group_file" | "delete_group_folder" | "download_file" | "fetch_custom_face" | "fetch_emoji_like" | "forward_friend_single_msg" | "forward_group_single_msg" | "friend_poke" | "get_ai_characters" | "get_ai_record" | "get_clientkey" | "get_collection_list" | "get_cookies" | "get_credentials" | "get_csrf_token" | "get_doubt_friends_add_request" | "get_essence_msg_list" | "get_file" | "get_friend_msg_history" | "get_friends_with_category" | "get_group_at_all_remain" | "get_group_detail_info" | "get_group_file_system_info" | "get_group_file_url" | "get_group_files_by_folder" | "get_group_honor_info" | "get_group_ignored_notifies" | "get_group_info_ex" | "get_group_root_files" | "get_group_shut_list" | "get_group_system_msg" | "get_image" | "get_mini_app_ark" | "get_online_clients" | "get_private_file_url" | "get_profile_like" | "get_recent_contact" | "get_record" | "get_rkey_server" | "get_rkey" | "get_robot_uin_range" | "get_unidirectional_friend_list" | "get_version_info" | "group_poke" | "mark_group_msg_as_read" | "mark_msg_as_read" | "mark_private_msg_as_read" | "move_group_file" | "nc_get_packet_status" | "nc_get_rkey" | "nc_get_user_status" | "ocr_image" | "rename_group_file" | "send_forward_msg" | "send_group_ai_record" | "send_group_sign" | "send_like" | "send_packet" | "send_poke" | "set_diy_online_status" | "set_essence_msg" | "set_friend_remark" | "set_group_add_option" | "set_group_kick_members" | "set_group_remark" | "set_group_robot_add_option" | "set_group_search" | "set_group_sign" | "set_group_whole_ban" | "set_input_status" | "set_msg_emoji_like" | "set_online_status" | "set_qq_avatar" | "set_self_longnick" | "trans_group_file" | "translate_en2zh" | "upload_group_file" | "upload_private_file";
962
978
  /** 所有可用的 API 接口联合类型 */
963
979
  type API = OneBotAPI | NapCatExtendAPI;
980
+ interface GroupMemberInfo {
981
+ group_id: number;
982
+ user_id: number;
983
+ nickname: string;
984
+ card: string;
985
+ sex: string;
986
+ age: number;
987
+ area: string;
988
+ level: string;
989
+ qq_level: number;
990
+ join_time: number;
991
+ last_sent_time: number;
992
+ title_expire_time: number;
993
+ unfriendly: boolean;
994
+ card_changeable: boolean;
995
+ is_robot: boolean;
996
+ shut_up_timestamp: number;
997
+ role: "owner" | "admin" | "member" | (string & {});
998
+ title: string;
999
+ }
964
1000
  //#endregion
965
1001
  //#region src/segment.d.ts
966
1002
  /**
@@ -1013,7 +1049,9 @@ declare const version: string;
1013
1049
  declare class NapCat {
1014
1050
  #private;
1015
1051
  private readonly options;
1016
- constructor(options: MiokiOptions);
1052
+ constructor(options: NapcatOptions);
1053
+ /** 统计数据 */
1054
+ get stat(): Stat;
1017
1055
  /** WebSocket 实例 */
1018
1056
  get ws(): WebSocket;
1019
1057
  /** 日志记录器 */
@@ -1022,6 +1060,8 @@ declare class NapCat {
1022
1060
  get segment(): typeof segment;
1023
1061
  /**
1024
1062
  * 机器人 QQ 号
1063
+ *
1064
+ * @deprecated 建议使用 `uin` 属性
1025
1065
  */
1026
1066
  get user_id(): number;
1027
1067
  /**
@@ -1032,6 +1072,8 @@ declare class NapCat {
1032
1072
  * 机器人昵称
1033
1073
  */
1034
1074
  get nickname(): string;
1075
+ /** 标准化可发送消息元素 */
1076
+ normalizeSendable(msg: Sendable | Sendable[]): NormalizedElementToSend[];
1035
1077
  stringifyMessage(message: RecvElement[]): string;
1036
1078
  /** 获取一个群的信息,可以用于发送群消息等操作 */
1037
1079
  pickGroup(group_id: number): Promise<GroupWithInfo | null>;
@@ -1058,6 +1100,42 @@ declare class NapCat {
1058
1100
  */
1059
1101
  api<T extends any>(action: API | (string & {}), params?: Record<string, any>): Promise<T>;
1060
1102
  /**
1103
+ * 获取好友列表
1104
+ */
1105
+ getFriendList(): Promise<(Friend & Record<string, any>)[]>;
1106
+ /**
1107
+ * 获取群列表
1108
+ */
1109
+ getGroupList(): Promise<(Group & Record<string, any>)[]>;
1110
+ /**
1111
+ * 添加消息回应
1112
+ */
1113
+ addReaction(message_id: number, id: string): Promise<void>;
1114
+ /**
1115
+ * 删除消息回应
1116
+ */
1117
+ delReaction(message_id: number, id: string): Promise<void>;
1118
+ /**
1119
+ * 获取消息
1120
+ */
1121
+ getMsg(message_id?: number | string | null): Promise<GroupMessageEvent | PrivateMessageEvent | null>;
1122
+ /**
1123
+ * 删除好友
1124
+ */
1125
+ deleteFriend(user_id: number, block?: boolean, both?: boolean): Promise<void>;
1126
+ /**
1127
+ * 设置群成员禁言
1128
+ */
1129
+ setGroupBan(group_id: number, user_id: number, duration: number): Promise<void>;
1130
+ /**
1131
+ * 撤回消息
1132
+ */
1133
+ recallMsg(message_id: number): Promise<void>;
1134
+ /**
1135
+ * 获取陌生人信息
1136
+ */
1137
+ getStrangerInfo(user_id: number): Promise<any>;
1138
+ /**
1061
1139
  * 发送私聊消息
1062
1140
  */
1063
1141
  sendPrivateMsg(user_id: number, sendable: Sendable | Sendable[]): Promise<{
@@ -1070,6 +1148,38 @@ declare class NapCat {
1070
1148
  message_id: number;
1071
1149
  }>;
1072
1150
  /**
1151
+ * 获取群信息
1152
+ */
1153
+ getGroupInfo(group_id: number): Promise<any>;
1154
+ /**
1155
+ * 群签到
1156
+ */
1157
+ setGroupSign(group_id: number): Promise<any>;
1158
+ /**
1159
+ * 设置群精华消息
1160
+ */
1161
+ setEssenceMsg(message_id: number): Promise<void>;
1162
+ /**
1163
+ * 删除群精华消息
1164
+ */
1165
+ deleteEssenceMsg(message_id: number): Promise<void>;
1166
+ /**
1167
+ * 设置群成员名片
1168
+ */
1169
+ setGroupCard(group_id: number, user_id: number, card: string): Promise<void>;
1170
+ /**
1171
+ * 设置群成员专属头衔
1172
+ */
1173
+ setGroupSpecialTitle(group_id: number, user_id: number, title: string): Promise<void>;
1174
+ /**
1175
+ * 获取群成员列表
1176
+ */
1177
+ getGroupMemberList(group_id: number): Promise<GroupMemberInfo[]>;
1178
+ /**
1179
+ * 获取群成员信息
1180
+ */
1181
+ getGroupMemberInfo(group_id: number, user_id: number): Promise<GroupMemberInfo>;
1182
+ /**
1073
1183
  * 机器人是否在线
1074
1184
  */
1075
1185
  isOnline(): boolean;
@@ -1125,5 +1235,5 @@ declare class NapCat {
1125
1235
  close(): void;
1126
1236
  }
1127
1237
  //#endregion
1128
- export { ABSTRACT_LOGGER, API, CONSOLE_LOGGER, EventBase, EventMap, ExtractByType, FlattenData, Friend, FriendDecreaseNoticeEvent, FriendIncreaseNoticeEvent, FriendInputNoticeEvent, FriendLikeNoticeEvent, FriendNoticeEvent, FriendNoticeEventBase, FriendPokeNoticeEvent, FriendRecallNoticeEvent, FriendRequestEvent, FriendWithInfo, Group, GroupAddRequestEvent, GroupAdminNoticeEvent, GroupBanNoticeEvent, GroupCardNoticeEvent, GroupDecreaseNoticeEvent, GroupEssenceNoticeEvent, GroupIncreaseNoticeEvent, GroupInviteRequestEvent, GroupMessageEvent, GroupNoticeEvent, GroupNoticeEventBase, GroupPokeNoticeEvent, GroupReactionNoticeEvent, GroupRecallNoticeEvent, GroupRequestEvent, GroupTitleNoticeEvent, GroupUploadNoticeEvent, GroupWithInfo, HeartbeatMetaEvent, LifecycleMetaEvent, LogLevel, Logger, MediaProps, MessageEvent, MessageEventBase, MessageType, MetaEvent, MetaEventBase, MetaEventType, MiokiOptions, NapCat, NapCatExtendAPI, NormalizedElementToSend, NoticeEvent, NoticeEventBase, NoticeSubType, NoticeType, OneBotAPI, OneBotEventMap, OptionalKeys, OptionalProps, PostType, PrivateMessageEvent, RecvAtElement, RecvDiceElement, RecvElement, RecvFaceElement, RecvFileElement, RecvForwardElement, RecvImageElement, RecvJsonElement, RecvLightAppElement, RecvLocationElement, RecvMarkdownElement, RecvPokeElement, RecvRecordElement, RecvReplyElement, RecvRpsElement, RecvShakeElement, RecvShareElement, RecvTextElement, RecvVideoElement, RequestEvent, RequestEventBase, SendAtElement, SendBfaceElement, SendContactElement, SendCustomMusicElement, SendElement, SendFaceElement, SendFileElement, SendForwardElement, SendImageElement, SendJsonElement, SendLightAppElement, SendMarkdownElement, SendMfaceElement, SendMusicElement, SendNodeContentElement, SendNodeElement, SendNodeRefElement, SendPlatformMusicElement, SendPokeElement, SendRecordElement, SendReplyElement, SendTextElement, SendVideoElement, Sendable, WrapData, name, noop, segment, version };
1238
+ export { ABSTRACT_LOGGER, API, CONSOLE_LOGGER, EventBase, EventMap, ExtractByType, FlattenData, Friend, FriendDecreaseNoticeEvent, FriendIncreaseNoticeEvent, FriendInputNoticeEvent, FriendLikeNoticeEvent, FriendNoticeEvent, FriendNoticeEventBase, FriendPokeNoticeEvent, FriendRecallNoticeEvent, FriendRequestEvent, FriendWithInfo, Group, GroupAddRequestEvent, GroupAdminNoticeEvent, GroupBanNoticeEvent, GroupCardNoticeEvent, GroupDecreaseNoticeEvent, GroupEssenceNoticeEvent, GroupIncreaseNoticeEvent, GroupInviteRequestEvent, GroupMemberInfo, GroupMessageEvent, GroupNoticeEvent, GroupNoticeEventBase, GroupPokeNoticeEvent, GroupReactionNoticeEvent, GroupRecallNoticeEvent, GroupRequestEvent, GroupTitleNoticeEvent, GroupUploadNoticeEvent, GroupWithInfo, HeartbeatMetaEvent, LifecycleMetaEvent, LogLevel, Logger, MediaProps, MessageEvent, MessageEventBase, MessageType, MetaEvent, MetaEventBase, MetaEventType, NapCat, NapCatExtendAPI, NapcatOptions, NormalizedElementToSend, NoticeEvent, NoticeEventBase, NoticeSubType, NoticeType, OneBotAPI, OneBotEventMap, OptionalKeys, OptionalProps, PostType, PrivateMessageEvent, RecvAtElement, RecvDiceElement, RecvElement, RecvFaceElement, RecvFileElement, RecvForwardElement, RecvImageElement, RecvJsonElement, RecvLightAppElement, RecvLocationElement, RecvMarkdownElement, RecvPokeElement, RecvRecordElement, RecvReplyElement, RecvRpsElement, RecvShakeElement, RecvShareElement, RecvTextElement, RecvVideoElement, RequestEvent, RequestEventBase, SendAtElement, SendBfaceElement, SendContactElement, SendCustomMusicElement, SendElement, SendFaceElement, SendFileElement, SendForwardElement, SendImageElement, SendJsonElement, SendLightAppElement, SendMarkdownElement, SendMfaceElement, SendMusicElement, SendNodeContentElement, SendNodeElement, SendNodeRefElement, SendPlatformMusicElement, SendPokeElement, SendRecordElement, SendReplyElement, SendTextElement, SendVideoElement, Sendable, Stat, WrapData, name, noop, segment, version };
1129
1239
  //# sourceMappingURL=index.d.mts.map