21 Commits

Author SHA1 Message Date
last2014 714edfa147 Merge pull request 'v1.1.3' (#15) from develop into main
Reviewed-on: #15
2026-01-25 03:26:27 +00:00
last2014 ab701005ec Merge branch 'main' into develop 2026-01-25 03:26:21 +00:00
last2014 72d7616c16 v1.1.3 2026-01-25 12:24:47 +09:00
last2014 0e3ce6a58a Merge pull request 'v1.1.2' (#14) from develop into main
Reviewed-on: #14
2026-01-24 04:08:32 +00:00
last2014 51a2acd8c3 Merge branch 'develop' of https://gitea.last2014.com/last2014/better-uwuzu-sdk into develop 2026-01-24 13:07:34 +09:00
last2014 fb218bcbe1 v1.1.2 2026-01-24 13:07:26 +09:00
last2014 4c508008b2 Merge pull request 'v1.1.1' (#13) from develop into main
Reviewed-on: #13
2026-01-24 03:50:37 +00:00
last2014 6371315b71 Merge branch 'main' into develop 2026-01-24 03:50:32 +00:00
last2014 9ba65ee60a Merge branch 'develop' of https://gitea.last2014.com/last2014/better-uwuzu-sdk into develop 2026-01-24 12:49:51 +09:00
last2014 d102adcebc v1.1.1 2026-01-24 12:49:08 +09:00
last2014 caa38f92e4 Merge pull request 'v1.1.0' (#12) from develop into main
Reviewed-on: #12
2026-01-24 02:30:32 +00:00
last2014 550018ed81 Merge branch 'main' into develop 2026-01-24 02:30:25 +00:00
last2014 e81dfba70a v1.1.0 2026-01-24 11:19:19 +09:00
last2014 845dad288e Merge pull request 'v1.0.3' (#11) from develop into main
Reviewed-on: #11
2026-01-22 22:32:03 +00:00
last2014 84e10c529b Merge branch 'main' into develop 2026-01-22 22:31:47 +00:00
last2014 85c8f8cc9f Merge branch 'develop' of https://gitea.last2014.com/last2014/better-uwuzu-sdk into develop 2026-01-23 07:28:57 +09:00
last2014 99387d1b3b ApiMapがanyになる問題を修正 / v1.0.3 2026-01-23 07:28:40 +09:00
last2014 8b2b1d2b13 Merge pull request 'v1.0.2' (#10) from develop into main
Reviewed-on: #10
2026-01-22 10:40:34 +00:00
last2014 59bfd58fba Merge branch 'main' into develop 2026-01-22 10:40:28 +00:00
last2014 8c4dfeaa77 v1.0.2 2026-01-22 19:39:01 +09:00
last2014 e4338c80e7 Content-Typeを削除 / ApiMapの不完全な部分を補完 2026-01-22 19:38:41 +09:00
8 changed files with 181 additions and 214 deletions
+9 -5
View File
@@ -5,13 +5,13 @@
## インストール
```bash
# npm
npm install git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.1
npm install git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.3
# yarn
yarn add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.1
yarn add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.3
# pnpm
pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.1
pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.3
```
> **NOTE**
> このSDKはnpmリポジトリがありません。Gitリポジトリを使用しています。
@@ -22,10 +22,12 @@ pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.1
## 初期化
```ts
import uwuzu from "better-uwuzu-sdk";
import type ApiMap from "better-uwuzu-sdk/1.6.11/map";
import type ApiMap from "better-uwuzu-sdk/1.6.8/map";
import Parser from "better-uwuzu-sdk/1.6.8/parser";
const client = new uwuzu<ApiMap>({
origin: "https://uwuzu.net",
parser: Parser,
});
try {
@@ -39,10 +41,12 @@ try {
## APIリクエスト
```ts
import uwuzu from "better-uwuzu-sdk";
import type ApiMap from "better-uwuzu-sdk/1.6.11/map";
import type ApiMap from "better-uwuzu-sdk/1.6.8/map";
import Parser from "better-uwuzu-sdk/1.6.8/parser";
const client = new uwuzu<ApiMap>({
origin: "https://uwuzu.net",
parser: Parser,
});
try {
+5 -5
View File
@@ -1,6 +1,6 @@
{
"name": "better-uwuzu-sdk",
"version": "1.0.1",
"version": "1.1.3",
"description": "A better uwuzu SDK.",
"main": "dist/index.js",
"types": "dist/types/index.d.ts",
@@ -33,19 +33,19 @@
"types": "./dist/types/*.d.ts"
},
"./*/*": {
"import": "./dist/types/*/*.js",
"import": "./dist/*/*.js",
"types": "./dist/types/*/*.d.ts"
},
"./*/*/*": {
"import": "./dist/types/*/*/*.js",
"import": "./dist/*/*/*.js",
"types": "./dist/types/*/*/*.d.ts"
},
"./*/*/*/*": {
"import": "./dist/types/*/*/*/*.js",
"import": "./dist/*/*/*/*.js",
"types": "./dist/types/*/*/*/*.d.ts"
},
"./*/*/*/*/*": {
"import": "./dist/types/*/*/*/*/*.js",
"import": "./dist/*/*/*/*/*.js",
"types": "./dist/types/*/*/*/*/*.d.ts"
}
},
+85
View File
@@ -0,0 +1,85 @@
import type { parserType } from "../index";
const mediaToObj = (ueuse: any) => {
const media = {
photo: [] as string[],
video: [] as string[],
};
if (ueuse.photo1 !== "" || ueuse.video1 !== "") {
if (ueuse.photo1 !== "") {
media.photo.push(ueuse.photo1);
delete ueuse.photo1;
}
if (ueuse.photo2 !== "") {
media.photo.push(ueuse.photo2);
delete ueuse.photo2;
}
if (ueuse.photo3 !== "") {
media.photo.push(ueuse.photo3);
delete ueuse.photo3;
}
if (ueuse.photo4 !== "") {
media.photo.push(ueuse.photo4);
delete ueuse.photo4;
}
if (ueuse.video1 !== "") {
media.video.push(ueuse.video1);
delete ueuse.video1;
}
}
ueuse.media = media;
return ueuse;
}
const Parser: parserType = (data, type, endpoint) => {
let result = data;
if (type === "request") {
if (result.media && result.text && endpoint === "ueuse/create") {
for (let i = 0; i < result.media.photo.length; i++) {
result[`photo${i + 1}`] = result.media.photo[i];
}
for (let i = 0; i < result.media.video.length; i++) {
result[`video${i + 1}`] = result.media.video[i];
}
}
return result;
} else {
if (result["0"] !== undefined && result.success === true) {
delete result.success;
const objData: any[] = Object.values(result);
for (let i = 0; i < objData.length; i++) {
if (endpoint.indexOf("ueuse") !== -1) {
objData[i] = mediaToObj(objData[i]);
}
}
return {
success: true,
data: objData,
};
}
if (result.favorite_list !== undefined && result.success === true) {
delete result.success;
const list = result.favorite_list.split(",");
return {
success: true,
favorite_list: list,
};
}
return result;
}
}
export default Parser;
+29 -1
View File
@@ -6,6 +6,20 @@ import MeNotification from "./me/notification";
import MeNotificationRead from "./me/notification/read";
import MeSettings from "./me/settings";
import Ueuse from "./ueuse";
import UeuseGet from "./ueuse/get";
import UeuseReplies from "./ueuse/replies";
import UeuseMentions from "./ueuse/mentions";
import UeuseSearch from "./ueuse/search";
import UeuseCreate from "./ueuse/create";
import UeuseDelete from "./ueuse/delete";
import UeuseBookmark from "./ueuse/bookmark";
import FavoriteChange from "./favorite/change";
import FavoriteGet from "./favorite/get";
import TokenGet from "./token/get";
import AdminUsers from "./admin/users";
import AdminUsersSanction from "./admin/users/sanction";
import AdminReports from "./admin/reports";
import AdminReportsResolve from "./admin/reports/resolve";
export type ApiMap =
& ServerInfo
@@ -15,4 +29,18 @@ export type ApiMap =
& MeSettings
& Users
& UsersFollow
& Ueuse;
& Ueuse
& UeuseGet
& UeuseReplies
& UeuseMentions
& UeuseSearch
& UeuseCreate
& UeuseDelete<string>
& UeuseBookmark
& FavoriteChange
& FavoriteGet
& TokenGet
& AdminUsers
& AdminUsersSanction<string>
& AdminReports
& AdminReportsResolve;
+1 -1
View File
@@ -2,7 +2,7 @@ import InputError from "../../modules/error/input";
import { UserDataNotFound } from "../../modules/error/critical";
export default interface TokenGet {
"ueuse/get": {
"token/get": {
body: {
/** api/authで使用したセッション */
session: string;
+3 -1
View File
@@ -3,10 +3,12 @@ import AuthError from "../../modules/error/auth";
import { Media } from "../../modules/ueuse";
export default interface UeuseCreate {
"ueuse/get": {
"ueuse/create": {
body: {
/** 本文 */
text: string;
/** メディア */
media: Media;
/** NSFWにするかどうか */
nsfw?: boolean;
/** 返信先ユーズのユニークID */
+36 -178
View File
@@ -1,111 +1,23 @@
type Abi = {
/**
* 追記
* 追記がない場合は空文字列です。
*/
abi: string;
/** 追記時刻 */
abidatetime: string;
} | {
/**
* 追記
* 追記が入力できないため常に空文字列です。
*/
abi: "";
/**
* 追記時刻
* 追記が入力できないため常に0000-00-00 00:00:00です。
*/
abidatetime: "0000-00-00 00:00:00";
}
export interface Media {
/** 画像URL */
photo: string[];
/** 動画URL */
video: string[];
};
export type Media =
| {
/**
* 画像1URL
* 画像1がないため常に空文字列です。
*/
photo1?: undefined;
/**
* 画像2URL
* 画像2がないため常に空文字列です。
* 画像2は画像1が入力されていることの内包条件です。
*/
photo2?: undefined;
/**
* 画像3URL
* 画像3がないため常に空文字列です。
* 画像3は画像2が入力されていることの内包条件です。
*/
photo3?: undefined;
/**
* 画像4URL
* 画像4がないため常に空文字列です。
* 画像4は画像3が入力されていることの内包条件です。
*/
photo4?: undefined;
/**
* 動画URL
* 動画がないため常に空文字列です。
*/
video1?: undefined;
} | {
/** 画像1URL */
photo1: string;
/**
* 画像2URL
* 画像2がない場合は空文字列です。
* 画像2は画像1が入力されていることの内包条件です。
*/
photo2?: string;
/**
* 画像3URL
* 画像3がない場合は空文字列です。
* 画像3は画像2が入力されていることの内包条件です。
*/
photo3?: string;
/**
* 画像4URL
* 画像4がない場合は空文字列です。
* 画像4は画像3が入力されていることの内包条件です。
*/
photo4?: string;
/**
* 動画URL
* 動画がないため常に空文字列です。
*/
video1?: undefined;
} | {
/** 動画URL */
video1: string;
/**
* 画像1URL
* 画像1がないため常に空文字列です。
*/
photo1?: undefined;
/**
* 画像2URL
* 画像2がないため常に空文字列です。
* 画像2は画像1が入力されていることの内包条件です。
*/
photo2?: undefined;
/**
* 画像3URL
* 画像3がないため常に空文字列です。
* 画像3は画像1が入力されていることの内包条件です。
*/
photo3?: undefined;
/**
* 画像4URL
* 画像4がないため常に空文字列です。
* 画像4は画像1が入力されていることの内包条件です。
*/
photo4?: undefined;
};
interface ueuseBase {
export default interface ueuseModule {
/** ユニークID */
uniqid: string;
/**
* 返信先ID
* 返信でない場合は空文字列です。
*/
replyid: string | "";
/**
* リユーズ/引用元ID
* リユーズ/引用でない場合は空文字列です。
*/
reuseid: string | "";
/** 送信者 */
account: {
/** ユーザー名 */
@@ -119,88 +31,34 @@ interface ueuseBase {
/** Botフラグ(自主設定)かどうか */
is_bot: boolean;
};
/** 本文 */
text: string;
/** いいねしたユーザーID */
favorite: string[];
/** メディア */
media: Media;
/** いいね数 */
favorite_cnt: number;
/** 返信数 */
reply_cnt: number;
/** リユーズ+引用数 */
reuse_cnt: number;
/** 送信時刻 */
/**
* 送信時刻
* YYYY-MM-DD HH:MM:SS形式です。
*/
datetime: string;
/**
* 追記
* 追記がない場合は空文字列です。
*/
abi: string | "";
/**
* 追記時刻
* 追記がない場合は0000-00-00 00:00:00です。
* YYYY-MM-DD HH:MM:SS形式です。
*/
abidatetime: string | "0000-00-00 00:00:00";
/** NSFW(自主設定)かどうか */
nsfw: boolean;
}
interface NormalUeuse extends ueuseBase {
/** 本文 */
text: string;
/**
* 返信先ID
* 返信でないため空文字列です。
*/
replyid: "";
/**
* リユーズ/引用元ID
* リユーズ/引用でないため空文字列です。
*/
reuseid: "";
}
interface ReplyUeuse extends ueuseBase {
/** 本文 */
text: string;
/** 返信先ID */
replyid: string;
/**
* リユーズ/引用元ID
* リユーズ/引用でないため空文字列です。
*/
reuseid: "";
}
interface Reuse extends ueuseBase {
/**
* 本文
* リユーズであるため常に空文字列です。
*/
text: "";
/**
* 返信先ID
* 返信でないため空文字列です。
*/
replyid: "";
/** リユーズ/引用元ID */
reuseid: string;
/**
* 追記
* リユーズであるため常に空文字列です。
*/
abi: "";
/**
* 追記時刻
* リユーズであるため常に0000-00-00 00:00:00です。
*/
abidatetime: "0000-00-00 00:00:00";
}
interface QuoteReuse extends ueuseBase {
/** 本文 */
text: string;
/**
* 返信先ID
* 返信でないため空文字列です。
*/
replyid: "";
/** 引用元ID */
reuseid: string;
}
type Ext = Abi & Media;
export type ueuseModule =
| (NormalUeuse & Ext)
| (ReplyUeuse & Ext)
| (QuoteReuse & Ext)
| Reuse;
+16 -26
View File
@@ -1,9 +1,19 @@
import uwuzuError from "./lib/error";
import uwuzuFetch from "./lib/fetch";
export type parserType = (
data: any,
type: "request" | "response",
endpoint: string,
) => any;
interface sdkOptions {
/** uwuzuサーバーのorigin */
origin: string;
/**
* リクエスト/レスポンスのパーサー
*/
parser: parserType;
/**
* 通信に失敗した際の再試行回数です。
* 全て失敗した場合はエラーを発生します。
@@ -29,15 +39,18 @@ export default class uwuzu<
M extends { [K in keyof M]: { body?: any; response: any } }
> {
readonly origin: string;
readonly parser: parserType;
readonly retry: number;
readonly waiting: number;
private _token: string | null = null;
constructor(options: sdkOptions) {
this.origin = options.origin;
this.parser = options.parser;
this.retry = options.retry ?? 5;
this.waiting = options.waiting ?? 500;
if (!this.parser) throw new uwuzuError("Invalid parser.");
if (this.retry < 1) throw new uwuzuError("Invalid retry count.");
if (this.waiting < 1) throw new uwuzuError("Invalid base waiting time.");
if (options.origin !== new URL(options.origin).origin)
@@ -73,6 +86,8 @@ export default class uwuzu<
let bodyParsed: any = args[0] ?? {};
if (typeof bodyParsed === "object") {
bodyParsed = this.parser(bodyParsed, "request", endpoint);
bodyParsed = {
...bodyParsed,
token: this._token,
@@ -88,37 +103,12 @@ export default class uwuzu<
endpoint as string,
{
method: "POST",
headers: {
"Content-Type": "application/json",
},
cache: "no-store",
body: bodyParsed,
}
);
let res = await req.json();
if (res["0"] !== undefined && res.success === true) {
res.success = undefined;
const data = Object.values(res).filter(Boolean);
return {
success: true,
data,
};
}
if (res.favorite_list !== undefined && res.success === true) {
res.success = undefined;
const list = res.favorite_list.split(",");
return {
success: true,
favorite_list: list,
};
}
const res = this.parser(await req.json(), "response", endpoint);
return res;
}