26 Commits

Author SHA1 Message Date
last2014 6a8ddae772 Del: debug 2026-04-05 14:10:57 +09:00
last2014 57da0ec0f3 Chg: debug 2026-04-05 13:15:04 +09:00
last2014 8017146b1a v1.1.7 2026-04-05 13:07:46 +09:00
last2014 5b048f18bf Fix: ueuse/create / Fix: parser 2026-04-05 13:07:28 +09:00
last2014 1d8a5d3937 Fix: parser 2026-04-05 13:01:01 +09:00
last2014 ed710dc45a Fix: parser 2026-04-05 12:54:14 +09:00
last2014 2efa5ec057 v1.1.5 2026-04-04 00:19:01 +09:00
last2014 6e8a1018b3 Fix: #17 2026-04-04 00:17:40 +09:00
last2014 e16ab5b22f Merge pull request 'v1.1.4' (#16) from develop into main
Reviewed-on: #16
2026-01-25 03:59:19 +00:00
last2014 f65b3d5e72 Merge branch 'main' into develop 2026-01-25 03:59:13 +00:00
last2014 fc325be4c7 v1.1.4 2026-01-25 12:56:27 +09:00
last2014 87a424a6b7 Merge branch 'develop' of https://gitea.last2014.com/last2014/better-uwuzu-sdk into develop 2026-01-25 12:52:05 +09:00
last2014 331cff0550 Fix: tokenなしのエンドポイントで通信できない問題 2026-01-25 12:51:56 +09:00
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
13 changed files with 170 additions and 218 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.3
npm install git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.7
# yarn
yarn add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.3
yarn add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.7
# pnpm
pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.3
pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.1.7
```
> **NOTE**
> このSDKはnpmリポジトリがありません。Gitリポジトリを使用しています。
@@ -22,10 +22,12 @@ pnpm add git+https://gitea.last2014.com/last2014/better-uwuzu-sdk.git#1.0.3
## 初期化
```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.3",
"version": "1.1.7",
"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"
}
},
+91
View File
@@ -0,0 +1,91 @@
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") {
if (result.media.photo) {
for (let i = 0; i < result.media.photo.length; i++) {
result[`image${i + 1}`] = result.media.photo[i];
}
}
/*if (result.media.video) {
for (let i = 0; i < result.media.video.length; i++) {
result[`video${i + 1}`] = result.media.video[i];
}
}*/
delete result.media;
}
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;
+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;
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../../modules/error/input";
import AuthError from "../../../modules/error/auth";
import { ueuseModule } from "../../../modules/ueuse";
import ueuseModule from "../../../modules/ueuse";
import ueuseError from "../../../modules/error/ueuse";
import Page from "../../../modules/page";
+4 -2
View File
@@ -3,17 +3,19 @@ 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 */
replyid?: string;
/** リユーズ/引用元ユーズのユニークID */
reuseid?: string;
} & Media;
};
response: {
/** 成功かどうか */
success: true;
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../modules/error/input";
import AuthError from "../../modules/error/auth";
import { ueuseModule } from "../../modules/ueuse";
import ueuseModule from "../../modules/ueuse";
import ueuseError from "../../modules/error/ueuse";
export default interface UeuseGet {
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../modules/error/input";
import AuthError from "../../modules/error/auth";
import { ueuseModule } from "../../modules/ueuse";
import ueuseModule from "../../modules/ueuse";
import ueuseError from "../../modules/error/ueuse";
import Page from "../../modules/page";
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../modules/error/input";
import AuthError from "../../modules/error/auth";
import { ueuseModule } from "../../modules/ueuse";
import ueuseModule from "../../modules/ueuse";
import ueuseError from "../../modules/error/ueuse";
import Page from "../../modules/page";
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../modules/error/input";
import AuthError from "../../modules/error/auth";
import { ueuseModule } from "../../modules/ueuse";
import ueuseModule from "../../modules/ueuse";
import ueuseError from "../../modules/error/ueuse";
import Page from "../../modules/page";
+1 -1
View File
@@ -1,6 +1,6 @@
import InputError from "../../modules/error/input";
import AuthError from "../../modules/error/auth";
import { ueuseModule } from "../../modules/ueuse";
import ueuseModule from "../../modules/ueuse";
import ueuseError from "../../modules/error/ueuse";
import Page from "../../modules/page";
+33 -175
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;
/** 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: "";
abi: string | "";
/**
* 追記時刻
* リユーズであるため常に0000-00-00 00:00:00です。
* 追記がない場合は0000-00-00 00:00:00です。
* YYYY-MM-DD HH:MM:SS形式です。
*/
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;
abidatetime: string | "0000-00-00 00:00:00";
/** NSFW(自主設定)かどうか */
nsfw: boolean;
}
+21 -24
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,10 +86,16 @@ export default class uwuzu<
let bodyParsed: any = args[0] ?? {};
if (typeof bodyParsed === "object") {
bodyParsed = this.parser(bodyParsed, "request", endpoint);
bodyParsed = {
...bodyParsed,
token: this._token,
token: this._token ?? "",
};
if (bodyParsed.token === "")
delete bodyParsed.token;
bodyParsed = JSON.stringify(bodyParsed);
}
@@ -93,29 +112,7 @@ export default class uwuzu<
}
);
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;
}