narou 1.2.0 → 2.0.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/LICENSE +21 -0
- package/README.md +73 -37
- package/dist/index.browser.cjs +87 -1359
- package/dist/index.browser.cjs.map +1 -1
- package/dist/index.browser.d.cts +11 -19
- package/dist/index.browser.d.mts +47 -0
- package/dist/index.browser.mjs +66 -0
- package/dist/index.browser.mjs.map +1 -0
- package/dist/index.cjs +147 -1410
- package/dist/index.cjs.map +1 -1
- package/dist/index.common-8lS2K_1Y.mjs +1166 -0
- package/dist/index.common-8lS2K_1Y.mjs.map +1 -0
- package/dist/index.common-CYj0n0aU.cjs +1346 -0
- package/dist/index.common-CYj0n0aU.cjs.map +1 -0
- package/dist/index.d.cts +28 -21
- package/dist/index.d.mts +63 -0
- package/dist/index.mjs +128 -0
- package/dist/index.mjs.map +1 -0
- package/dist/user-search-BY6FdEe7.d.cts +1394 -0
- package/dist/user-search-Besgk-Hx.d.mts +1394 -0
- package/package.json +28 -37
- package/pnpm-lock.yaml +1325 -1100
- package/src/index.ts +5 -1
- package/src/narou-fetch.ts +4 -3
- package/src/narou-jsonp.ts +4 -2
- package/src/narou.ts +50 -13
- package/src/params.ts +1 -1
- package/src/ranking.ts +20 -11
- package/src/search-builder-r18.ts +6 -2
- package/src/search-builder.ts +7 -3
- package/src/user-search.ts +9 -2
- package/dist/chunk-3A5MHPWL.js +0 -37
- package/dist/chunk-3A5MHPWL.js.map +0 -1
- package/dist/chunk-4ZP5YNWI.js +0 -1
- package/dist/chunk-4ZP5YNWI.js.map +0 -1
- package/dist/chunk-5UDKQCPJ.js +0 -407
- package/dist/chunk-5UDKQCPJ.js.map +0 -1
- package/dist/chunk-6BZWV4ZC.js +0 -75
- package/dist/chunk-6BZWV4ZC.js.map +0 -1
- package/dist/chunk-BQLSW236.js +0 -117
- package/dist/chunk-BQLSW236.js.map +0 -1
- package/dist/chunk-DEQICAN3.js +0 -94
- package/dist/chunk-DEQICAN3.js.map +0 -1
- package/dist/chunk-E2H3AJSQ.js +0 -57
- package/dist/chunk-E2H3AJSQ.js.map +0 -1
- package/dist/chunk-HOBLKBZ6.js +0 -452
- package/dist/chunk-HOBLKBZ6.js.map +0 -1
- package/dist/chunk-IPDEGCWU.js +0 -39
- package/dist/chunk-IPDEGCWU.js.map +0 -1
- package/dist/chunk-LQLNWSWV.js +0 -26
- package/dist/chunk-LQLNWSWV.js.map +0 -1
- package/dist/chunk-PLEM2AOH.js +0 -44
- package/dist/chunk-PLEM2AOH.js.map +0 -1
- package/dist/chunk-RNHRR56W.js +0 -25
- package/dist/chunk-RNHRR56W.js.map +0 -1
- package/dist/chunk-VUZIISP2.js +0 -23
- package/dist/chunk-VUZIISP2.js.map +0 -1
- package/dist/chunk-VZVUANDN.js +0 -17
- package/dist/chunk-VZVUANDN.js.map +0 -1
- package/dist/index.browser.d.ts +0 -55
- package/dist/index.browser.js +0 -126
- package/dist/index.browser.js.map +0 -1
- package/dist/index.common.cjs +0 -1187
- package/dist/index.common.cjs.map +0 -1
- package/dist/index.common.d.cts +0 -6
- package/dist/index.common.d.ts +0 -6
- package/dist/index.common.js +0 -76
- package/dist/index.common.js.map +0 -1
- package/dist/index.d.ts +0 -56
- package/dist/index.js +0 -131
- package/dist/index.js.map +0 -1
- package/dist/narou-DBa12V_l.d.ts +0 -404
- package/dist/narou-DCp4aGfA.d.cts +0 -404
- package/dist/narou-fetch.cjs +0 -164
- package/dist/narou-fetch.cjs.map +0 -1
- package/dist/narou-fetch.d.cts +0 -20
- package/dist/narou-fetch.d.ts +0 -20
- package/dist/narou-fetch.js +0 -10
- package/dist/narou-fetch.js.map +0 -1
- package/dist/narou-jsonp.cjs +0 -162
- package/dist/narou-jsonp.cjs.map +0 -1
- package/dist/narou-jsonp.d.cts +0 -13
- package/dist/narou-jsonp.d.ts +0 -13
- package/dist/narou-jsonp.js +0 -10
- package/dist/narou-jsonp.js.map +0 -1
- package/dist/narou-ranking-results.cjs +0 -19
- package/dist/narou-ranking-results.cjs.map +0 -1
- package/dist/narou-ranking-results.d.cts +0 -4
- package/dist/narou-ranking-results.d.ts +0 -4
- package/dist/narou-ranking-results.js +0 -1
- package/dist/narou-ranking-results.js.map +0 -1
- package/dist/narou-search-results-C21hWrnL.d.cts +0 -727
- package/dist/narou-search-results-DT0YdaBn.d.ts +0 -727
- package/dist/narou-search-results.cjs +0 -62
- package/dist/narou-search-results.cjs.map +0 -1
- package/dist/narou-search-results.d.cts +0 -2
- package/dist/narou-search-results.d.ts +0 -2
- package/dist/narou-search-results.js +0 -11
- package/dist/narou-search-results.js.map +0 -1
- package/dist/narou.cjs +0 -112
- package/dist/narou.cjs.map +0 -1
- package/dist/narou.d.cts +0 -4
- package/dist/narou.d.ts +0 -4
- package/dist/narou.js +0 -8
- package/dist/narou.js.map +0 -1
- package/dist/params.cjs +0 -448
- package/dist/params.cjs.map +0 -1
- package/dist/params.d.cts +0 -2
- package/dist/params.d.ts +0 -2
- package/dist/params.js +0 -41
- package/dist/params.js.map +0 -1
- package/dist/ranking-history.cjs +0 -47
- package/dist/ranking-history.cjs.map +0 -1
- package/dist/ranking-history.d.cts +0 -28
- package/dist/ranking-history.d.ts +0 -28
- package/dist/ranking-history.js +0 -8
- package/dist/ranking-history.js.map +0 -1
- package/dist/ranking.cjs +0 -783
- package/dist/ranking.cjs.map +0 -1
- package/dist/ranking.d.cts +0 -108
- package/dist/ranking.d.ts +0 -108
- package/dist/ranking.js +0 -10
- package/dist/ranking.js.map +0 -1
- package/dist/search-builder-r18.cjs +0 -547
- package/dist/search-builder-r18.cjs.map +0 -1
- package/dist/search-builder-r18.d.cts +0 -45
- package/dist/search-builder-r18.d.ts +0 -45
- package/dist/search-builder-r18.js +0 -9
- package/dist/search-builder-r18.js.map +0 -1
- package/dist/search-builder.cjs +0 -591
- package/dist/search-builder.cjs.map +0 -1
- package/dist/search-builder.d.cts +0 -4
- package/dist/search-builder.d.ts +0 -4
- package/dist/search-builder.js +0 -12
- package/dist/search-builder.js.map +0 -1
- package/dist/user-search.cjs +0 -325
- package/dist/user-search.cjs.map +0 -1
- package/dist/user-search.d.cts +0 -66
- package/dist/user-search.d.ts +0 -66
- package/dist/user-search.js +0 -9
- package/dist/user-search.js.map +0 -1
- package/dist/util/date.cjs +0 -51
- package/dist/util/date.cjs.map +0 -1
- package/dist/util/date.d.cts +0 -21
- package/dist/util/date.d.ts +0 -21
- package/dist/util/date.js +0 -11
- package/dist/util/date.js.map +0 -1
- package/dist/util/jsonp.cjs +0 -63
- package/dist/util/jsonp.cjs.map +0 -1
- package/dist/util/jsonp.d.cts +0 -49
- package/dist/util/jsonp.d.ts +0 -49
- package/dist/util/jsonp.js +0 -7
- package/dist/util/jsonp.js.map +0 -1
- package/dist/util/type.cjs +0 -19
- package/dist/util/type.cjs.map +0 -1
- package/dist/util/type.d.cts +0 -27
- package/dist/util/type.d.ts +0 -27
- package/dist/util/type.js +0 -1
- package/dist/util/type.js.map +0 -1
- package/dist/util/unzipp.cjs +0 -47
- package/dist/util/unzipp.cjs.map +0 -1
- package/dist/util/unzipp.d.cts +0 -12
- package/dist/util/unzipp.d.ts +0 -12
- package/dist/util/unzipp.js +0 -7
- package/dist/util/unzipp.js.map +0 -1
|
@@ -1,404 +0,0 @@
|
|
|
1
|
-
import { r as NarouSearchResult, d as SearchResultFieldNames, a as ParamsBaseWithOrder, q as GzipLevel, S as SearchParams, g as Order, o as NovelTypeParam, m as BuntaiParam, D as DateParam, N as NarouSearchResults, j as BigGenre, G as Genre, F as Fields, u as SearchResultFields, O as OptionalFields, v as SearchResultOptionalFields, y as PickedNarouSearchResult, b as RankingParams, c as RankingHistoryParams, U as UserSearchParams, s as UserSearchResult } from './narou-search-results-C21hWrnL.cjs';
|
|
2
|
-
import { RankingHistoryRawResult } from './ranking-history.cjs';
|
|
3
|
-
import { Join } from './util/type.cjs';
|
|
4
|
-
|
|
5
|
-
type DefaultSearchResultFields = keyof Omit<NarouSearchResult, "weekly_unique" | "noveltype" | "nocgenre" | "xid">;
|
|
6
|
-
declare abstract class SearchBuilderBase<TParams extends ParamsBaseWithOrder<TOrder>, TOrder extends string> {
|
|
7
|
-
protected params: TParams;
|
|
8
|
-
protected api: NarouNovel;
|
|
9
|
-
/**
|
|
10
|
-
* constructor
|
|
11
|
-
* @private
|
|
12
|
-
* @param params クエリパラメータ
|
|
13
|
-
* @param api NarouNovel インスタンス
|
|
14
|
-
*/
|
|
15
|
-
constructor(params: TParams | undefined, api: NarouNovel);
|
|
16
|
-
/**
|
|
17
|
-
* 配列から重複を除去する
|
|
18
|
-
* @protected
|
|
19
|
-
* @static
|
|
20
|
-
* @param array 配列
|
|
21
|
-
* @returns 重複を除去した配列
|
|
22
|
-
*/
|
|
23
|
-
protected static distinct<T>(array: readonly T[]): T[];
|
|
24
|
-
/**
|
|
25
|
-
* 配列をハイフン区切りの文字列に変換する
|
|
26
|
-
* @protected
|
|
27
|
-
* @static
|
|
28
|
-
* @param n 文字列または数値の配列、あるいは単一の文字列または数値
|
|
29
|
-
* @returns ハイフン区切りの文字列
|
|
30
|
-
*/
|
|
31
|
-
protected static array2string<T extends string | number>(n: T | readonly T[]): Join<T>;
|
|
32
|
-
/**
|
|
33
|
-
* 取得件数を指定する (lim)
|
|
34
|
-
* @param num 取得件数 (1-500)
|
|
35
|
-
* @return {this}
|
|
36
|
-
*/
|
|
37
|
-
limit(num: number): this;
|
|
38
|
-
/**
|
|
39
|
-
* 取得開始位置を指定する (st)
|
|
40
|
-
* @param num 取得開始位置 (1-)
|
|
41
|
-
* @return {this}
|
|
42
|
-
*/
|
|
43
|
-
start(num: number): this;
|
|
44
|
-
/**
|
|
45
|
-
* ページ番号と1ページあたりの件数で取得範囲を指定する
|
|
46
|
-
* @param no ページ番号 (0-)
|
|
47
|
-
* @param count 1ページあたりの件数 (デフォルト: 20)
|
|
48
|
-
* @return {this}
|
|
49
|
-
*/
|
|
50
|
-
page(no: number, count?: number): this;
|
|
51
|
-
/**
|
|
52
|
-
* 出力順序を指定する (order)
|
|
53
|
-
* 指定しない場合は新着順となります。
|
|
54
|
-
* @param {TOrder} order 出力順序
|
|
55
|
-
* @return {this}
|
|
56
|
-
*/
|
|
57
|
-
order(order: TOrder): this;
|
|
58
|
-
/**
|
|
59
|
-
* gzip圧縮レベルを指定する (gzip)
|
|
60
|
-
*
|
|
61
|
-
* 転送量上限を減らすためにも推奨
|
|
62
|
-
* @param {GzipLevel} level gzip圧縮レベル(1~5)
|
|
63
|
-
* @return {this}
|
|
64
|
-
*/
|
|
65
|
-
gzip(level: GzipLevel): this;
|
|
66
|
-
/**
|
|
67
|
-
* クエリパラメータをセットする
|
|
68
|
-
* @protected
|
|
69
|
-
* @param obj セットするパラメータ
|
|
70
|
-
* @return {this}
|
|
71
|
-
*/
|
|
72
|
-
protected set(obj: TParams): this;
|
|
73
|
-
/**
|
|
74
|
-
* クエリパラメータを削除する
|
|
75
|
-
* @protected
|
|
76
|
-
* @param key 削除するパラメータのキー
|
|
77
|
-
* @returns {this}
|
|
78
|
-
*/
|
|
79
|
-
protected unset(key: keyof TParams): this;
|
|
80
|
-
}
|
|
81
|
-
declare abstract class NovelSearchBuilderBase<T extends SearchResultFieldNames> extends SearchBuilderBase<SearchParams, Order> {
|
|
82
|
-
/**
|
|
83
|
-
* 検索語を指定します (word)。
|
|
84
|
-
* 半角または全角スペースで区切るとAND抽出になります。部分一致でHITします。
|
|
85
|
-
* @param word 検索語
|
|
86
|
-
* @return {this}
|
|
87
|
-
*/
|
|
88
|
-
word(word: string): this;
|
|
89
|
-
/**
|
|
90
|
-
* 除外したい単語を指定します (notword)。
|
|
91
|
-
* スペースで区切ることにより除外する単語を増やせます。部分一致で除外されます。
|
|
92
|
-
* @param word 除外語
|
|
93
|
-
* @return {this}
|
|
94
|
-
*/
|
|
95
|
-
notWord(word: string): this;
|
|
96
|
-
/**
|
|
97
|
-
* 検索対象を作品名に限定するかどうかを指定します (title)。
|
|
98
|
-
* @param bool trueの場合、作品名を検索対象とする (デフォルト: true)
|
|
99
|
-
* @return {this}
|
|
100
|
-
*/
|
|
101
|
-
byTitle(bool?: boolean): this;
|
|
102
|
-
/**
|
|
103
|
-
* 検索対象をあらすじに限定するかどうかを指定します (ex)。
|
|
104
|
-
* @param bool trueの場合、あらすじを検索対象とする (デフォルト: true)
|
|
105
|
-
* @return {this}
|
|
106
|
-
*/
|
|
107
|
-
byOutline(bool?: boolean): this;
|
|
108
|
-
/**
|
|
109
|
-
* 検索対象をキーワードに限定するかどうかを指定します (keyword)。
|
|
110
|
-
* @param bool trueの場合、キーワードを検索対象とする (デフォルト: true)
|
|
111
|
-
* @return {this}
|
|
112
|
-
*/
|
|
113
|
-
byKeyword(bool?: boolean): this;
|
|
114
|
-
/**
|
|
115
|
-
* 検索対象を作者名に限定するかどうかを指定します (wname)。
|
|
116
|
-
* @param bool trueの場合、作者名を検索対象とする (デフォルト: true)
|
|
117
|
-
* @return {this}
|
|
118
|
-
*/
|
|
119
|
-
byAuthor(bool?: boolean): this;
|
|
120
|
-
/**
|
|
121
|
-
* ボーイズラブ作品を抽出または除外します (isbl/notbl)。
|
|
122
|
-
* @param bool trueの場合、ボーイズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
123
|
-
* @return {this}
|
|
124
|
-
*/
|
|
125
|
-
isBL(bool?: boolean): this;
|
|
126
|
-
/**
|
|
127
|
-
* ガールズラブ作品を抽出または除外します (isgl/notgl)。
|
|
128
|
-
* @param bool trueの場合、ガールズラブ作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
129
|
-
* @return {this}
|
|
130
|
-
*/
|
|
131
|
-
isGL(bool?: boolean): this;
|
|
132
|
-
/**
|
|
133
|
-
* 残酷な描写あり作品を抽出または除外します (iszankoku/notzankoku)。
|
|
134
|
-
* @param bool trueの場合、残酷な描写あり作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
135
|
-
* @return {this}
|
|
136
|
-
*/
|
|
137
|
-
isZankoku(bool?: boolean): this;
|
|
138
|
-
/**
|
|
139
|
-
* 異世界転生作品を抽出または除外します (istensei/nottensei)。
|
|
140
|
-
* @param bool trueの場合、異世界転生作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
141
|
-
* @return {this}
|
|
142
|
-
*/
|
|
143
|
-
isTensei(bool?: boolean): this;
|
|
144
|
-
/**
|
|
145
|
-
* 異世界転移作品を抽出または除外します (istenni/nottenni)。
|
|
146
|
-
* @param bool trueの場合、異世界転移作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
147
|
-
* @return {this}
|
|
148
|
-
*/
|
|
149
|
-
isTenni(bool?: boolean): this;
|
|
150
|
-
/**
|
|
151
|
-
* 異世界転生または異世界転移作品を抽出します (istt)。
|
|
152
|
-
* @return {this}
|
|
153
|
-
*/
|
|
154
|
-
isTT(): this;
|
|
155
|
-
/**
|
|
156
|
-
* 抽出する作品の文字数を指定します (length)。
|
|
157
|
-
* 範囲指定する場合は、最小文字数と最大文字数をハイフン(-)記号で区切ってください。
|
|
158
|
-
* @param length 文字数、または[最小文字数, 最大文字数]
|
|
159
|
-
* @return {this}
|
|
160
|
-
*/
|
|
161
|
-
length(length: number | readonly number[]): this;
|
|
162
|
-
/**
|
|
163
|
-
* 抽出する作品の会話率を%単位で指定します (kaiwaritu)。
|
|
164
|
-
* @param num 会話率(%)
|
|
165
|
-
* @return {this}
|
|
166
|
-
*/
|
|
167
|
-
kaiwaritu(num: number): this;
|
|
168
|
-
/**
|
|
169
|
-
* 抽出する作品の会話率を%単位で範囲指定します (kaiwaritu)。
|
|
170
|
-
* @param min 最低会話率(%)
|
|
171
|
-
* @param max 最高会話率(%)
|
|
172
|
-
* @return {this}
|
|
173
|
-
*/
|
|
174
|
-
kaiwaritu(min: number, max: number): this;
|
|
175
|
-
/**
|
|
176
|
-
* 抽出する作品の挿絵数を指定します (sasie)。
|
|
177
|
-
* @param num 挿絵数、または[最小挿絵数, 最大挿絵数]
|
|
178
|
-
* @return {this}
|
|
179
|
-
*/
|
|
180
|
-
sasie(num: number | readonly number[]): this;
|
|
181
|
-
/**
|
|
182
|
-
* 抽出する作品の予想読了時間を分単位で指定します (time)。
|
|
183
|
-
* @param num 読了時間(分)、または[最小読了時間, 最大読了時間]
|
|
184
|
-
* @return {this}
|
|
185
|
-
*/
|
|
186
|
-
time(num: number | readonly number[]): this;
|
|
187
|
-
/**
|
|
188
|
-
* Nコードを指定して取得します (ncode)。
|
|
189
|
-
* @param ncodes Nコード、またはNコードの配列
|
|
190
|
-
* @return {this}
|
|
191
|
-
*/
|
|
192
|
-
ncode(ncodes: string | readonly string[]): this;
|
|
193
|
-
/**
|
|
194
|
-
* 抽出する小説タイプを指定します (type)。
|
|
195
|
-
* @param type 小説タイプ (t: 短編, r: 連載中, er: 完結済連載小説, ter: 短編と完結済連載小説, re: 連載中と完結済連載小説)
|
|
196
|
-
* @return {this}
|
|
197
|
-
*/
|
|
198
|
-
type(type: NovelTypeParam): this;
|
|
199
|
-
/**
|
|
200
|
-
* 抽出する作品の文体を指定します (buntai)。
|
|
201
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
202
|
-
* @param buntai 文体コード、または文体コードの配列
|
|
203
|
-
* @return {this}
|
|
204
|
-
*/
|
|
205
|
-
buntai(buntai: BuntaiParam | readonly BuntaiParam[]): this;
|
|
206
|
-
/**
|
|
207
|
-
* 連載停止中作品に関する指定をします (stop)。
|
|
208
|
-
* @param bool trueの場合、長期連載停止中のみ取得する (デフォルト: true)。falseの場合、長期連載停止中を除外する。
|
|
209
|
-
* @return {this}
|
|
210
|
-
*/
|
|
211
|
-
isStop(bool?: boolean): this;
|
|
212
|
-
/**
|
|
213
|
-
* ピックアップ作品のみを取得します (ispickup)。
|
|
214
|
-
* @return {this}
|
|
215
|
-
*/
|
|
216
|
-
isPickup(): this;
|
|
217
|
-
/**
|
|
218
|
-
* 最終更新日時を指定します (lastup)。
|
|
219
|
-
* @param date 最終更新日時 (YYYYMMDDhhmmss形式またはUNIXタイムスタンプ)
|
|
220
|
-
* @return {this}
|
|
221
|
-
*/
|
|
222
|
-
lastUpdate(date: DateParam): this;
|
|
223
|
-
/**
|
|
224
|
-
* 最終更新日時の範囲を指定します (lastup)。
|
|
225
|
-
* @param from 開始日時 (UNIXタイムスタンプ)
|
|
226
|
-
* @param to 終了日時 (UNIXタイムスタンプ)
|
|
227
|
-
* @return {this}
|
|
228
|
-
*/
|
|
229
|
-
lastUpdate(from: number, to: number): this;
|
|
230
|
-
/**
|
|
231
|
-
* 最終更新日時の範囲を指定します (lastup)。
|
|
232
|
-
* @param from 開始日時 (Dateオブジェクト)
|
|
233
|
-
* @param to 終了日時 (Dateオブジェクト)
|
|
234
|
-
* @return {this}
|
|
235
|
-
*/
|
|
236
|
-
lastUpdate(from: Date, to: Date): this;
|
|
237
|
-
/**
|
|
238
|
-
* 作品の更新日時を指定します (lastupdate)。
|
|
239
|
-
* @param date 作品の更新日時 (YYYYMMDDhhmmss形式またはUNIXタイムスタンプ)
|
|
240
|
-
* @return {this}
|
|
241
|
-
*/
|
|
242
|
-
lastNovelUpdate(date: DateParam): this;
|
|
243
|
-
/**
|
|
244
|
-
* 作品の更新日時の範囲を指定します (lastupdate)。
|
|
245
|
-
* @param from 開始日時 (UNIXタイムスタンプ)
|
|
246
|
-
* @param to 終了日時 (UNIXタイムスタンプ)
|
|
247
|
-
* @return {this}
|
|
248
|
-
*/
|
|
249
|
-
lastNovelUpdate(from: number, to: number): this;
|
|
250
|
-
/**
|
|
251
|
-
* 作品の更新日時の範囲を指定します (lastupdate)。
|
|
252
|
-
* @param from 開始日時 (Dateオブジェクト)
|
|
253
|
-
* @param to 終了日時 (Dateオブジェクト)
|
|
254
|
-
* @return {this}
|
|
255
|
-
*/
|
|
256
|
-
lastNovelUpdate(from: Date, to: Date): this;
|
|
257
|
-
/**
|
|
258
|
-
* なろう小説APIへの検索リクエストを実行する
|
|
259
|
-
* @returns {Promise<NarouSearchResults>} 検索結果
|
|
260
|
-
*/
|
|
261
|
-
execute(): Promise<NarouSearchResults<NarouSearchResult, T>>;
|
|
262
|
-
}
|
|
263
|
-
/**
|
|
264
|
-
* 検索ヘルパー
|
|
265
|
-
* @class SearchBuilder
|
|
266
|
-
*/
|
|
267
|
-
declare class SearchBuilder<T extends keyof NarouSearchResult = DefaultSearchResultFields, TOpt extends keyof NarouSearchResult = never> extends NovelSearchBuilderBase<T | TOpt> {
|
|
268
|
-
/**
|
|
269
|
-
* 大ジャンルを指定して取得します (biggenre)。
|
|
270
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
271
|
-
* @param genre 大ジャンルコード、または大ジャンルコードの配列
|
|
272
|
-
* @return {this}
|
|
273
|
-
*/
|
|
274
|
-
bigGenre(genre: BigGenre | readonly BigGenre[]): this;
|
|
275
|
-
/**
|
|
276
|
-
* 除外したい大ジャンルを指定します (notbiggenre)。
|
|
277
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
278
|
-
* @param genre 除外する大ジャンルコード、または大ジャンルコードの配列
|
|
279
|
-
* @return {this}
|
|
280
|
-
*/
|
|
281
|
-
notBigGenre(genre: BigGenre | readonly BigGenre[]): this;
|
|
282
|
-
/**
|
|
283
|
-
* ジャンルを指定して取得します (genre)。
|
|
284
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
285
|
-
* @param genre ジャンルコード、またはジャンルコードの配列
|
|
286
|
-
* @return {this}
|
|
287
|
-
*/
|
|
288
|
-
genre(genre: Genre | readonly Genre[]): this;
|
|
289
|
-
/**
|
|
290
|
-
* 除外したいジャンルを指定します (notgenre)。
|
|
291
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
292
|
-
* @param genre 除外するジャンルコード、またはジャンルコードの配列
|
|
293
|
-
* @return {this}
|
|
294
|
-
*/
|
|
295
|
-
notGenre(genre: Genre | readonly Genre[]): this;
|
|
296
|
-
/**
|
|
297
|
-
* ユーザIDを指定して取得します (userid)。
|
|
298
|
-
* 複数指定する場合はハイフン(-)で区切ってください。
|
|
299
|
-
* @param ids ユーザID、またはユーザIDの配列
|
|
300
|
-
* @return {this}
|
|
301
|
-
*/
|
|
302
|
-
userId(ids: number | readonly number[]): this;
|
|
303
|
-
/**
|
|
304
|
-
* R15作品を抽出または除外します (isr15/notr15)。
|
|
305
|
-
* @param bool trueの場合、R15作品を抽出する (デフォルト: true)。falseの場合、除外する。
|
|
306
|
-
* @return {this}
|
|
307
|
-
*/
|
|
308
|
-
isR15(bool?: boolean): this;
|
|
309
|
-
/**
|
|
310
|
-
* 出力する項目を個別に指定します (of)。
|
|
311
|
-
* 未指定時は全項目出力されます。転送量軽減のため、このパラメータの使用が推奨されます。
|
|
312
|
-
* 複数項目を出力する場合はハイフン(-)記号で区切ってください。
|
|
313
|
-
* @param fields 出力するフィールド名、またはフィールド名の配列
|
|
314
|
-
* @return {SearchBuilder<SearchResultFields<TFields>, TOpt>} 型が更新されたビルダー
|
|
315
|
-
*/
|
|
316
|
-
fields<TFields extends Fields>(fields: TFields | readonly TFields[]): SearchBuilder<SearchResultFields<TFields>, TOpt>;
|
|
317
|
-
/**
|
|
318
|
-
* 出力オプション項目を指定します (opt)。
|
|
319
|
-
* 複数項目を出力する場合はハイフン(-)記号で区切ってください。
|
|
320
|
-
* @param option 出力するオプションフィールド名、またはオプションフィールド名の配列
|
|
321
|
-
* @return {SearchBuilder<T, SearchResultOptionalFields<TFields>>} 型が更新されたビルダー
|
|
322
|
-
*/
|
|
323
|
-
opt<TFields extends OptionalFields>(option: TFields | readonly TFields[]): SearchBuilder<T, SearchResultOptionalFields<TFields>>;
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
/**
|
|
327
|
-
* ランキングAPIの結果
|
|
328
|
-
* @see https://dev.syosetu.com/man/rankapi/#output
|
|
329
|
-
*/
|
|
330
|
-
interface NarouRankingResult {
|
|
331
|
-
/** Nコード */
|
|
332
|
-
ncode: string;
|
|
333
|
-
/** 順位 */
|
|
334
|
-
rank: number;
|
|
335
|
-
/** ポイント */
|
|
336
|
-
pt: number;
|
|
337
|
-
}
|
|
338
|
-
/**
|
|
339
|
-
* ランキングと小説情報をマージした結果
|
|
340
|
-
*/
|
|
341
|
-
type RankingResult<T extends SearchResultFieldNames = DefaultSearchResultFields> = Partial<PickedNarouSearchResult<T>> & NarouRankingResult;
|
|
342
|
-
|
|
343
|
-
/**
|
|
344
|
-
* なろう小説APIへのリクエストパラメータ
|
|
345
|
-
*/
|
|
346
|
-
type NarouParams = SearchParams | RankingParams | RankingHistoryParams | UserSearchParams;
|
|
347
|
-
/**
|
|
348
|
-
* なろう小説APIへのリクエストを実行する
|
|
349
|
-
* @class NarouNovel
|
|
350
|
-
* @private
|
|
351
|
-
*/
|
|
352
|
-
declare abstract class NarouNovel {
|
|
353
|
-
/**
|
|
354
|
-
* なろうAPIへのAPIリクエストを実行する
|
|
355
|
-
* @param params クエリパラメータ
|
|
356
|
-
* @param endpoint APIエンドポイント
|
|
357
|
-
* @returns 実行結果
|
|
358
|
-
*/
|
|
359
|
-
protected abstract execute<T>(params: NarouParams, endpoint: string): Promise<T>;
|
|
360
|
-
/**
|
|
361
|
-
* APIへの検索リクエストを実行する
|
|
362
|
-
* @param params クエリパラメータ
|
|
363
|
-
* @param endpoint APIエンドポイント
|
|
364
|
-
* @returns 検索結果
|
|
365
|
-
*/
|
|
366
|
-
protected executeSearch<T extends keyof NarouSearchResult>(params: SearchParams, endpoint?: string): Promise<NarouSearchResults<NarouSearchResult, T>>;
|
|
367
|
-
/**
|
|
368
|
-
* 小説APIへの検索リクエストを実行する
|
|
369
|
-
* @param params クエリパラメータ
|
|
370
|
-
* @returns 検索結果
|
|
371
|
-
* @see https://dev.syosetu.com/man/api/
|
|
372
|
-
*/
|
|
373
|
-
executeNovel<T extends keyof NarouSearchResult>(params: SearchParams): Promise<NarouSearchResults<NarouSearchResult, T>>;
|
|
374
|
-
/**
|
|
375
|
-
* R18小説APIへの検索リクエストを実行する
|
|
376
|
-
* @param params クエリパラメータ
|
|
377
|
-
* @returns 検索結果
|
|
378
|
-
* @see https://dev.syosetu.com/xman/api/
|
|
379
|
-
*/
|
|
380
|
-
executeNovel18<T extends keyof NarouSearchResult>(params: SearchParams): Promise<NarouSearchResults<NarouSearchResult, T>>;
|
|
381
|
-
/**
|
|
382
|
-
* ランキングAPIへのリクエストを実行する
|
|
383
|
-
* @param params クエリパラメータ
|
|
384
|
-
* @returns ランキング結果
|
|
385
|
-
* @see https://dev.syosetu.com/man/rankapi/
|
|
386
|
-
*/
|
|
387
|
-
executeRanking(params: RankingParams): Promise<NarouRankingResult[]>;
|
|
388
|
-
/**
|
|
389
|
-
* 殿堂入りAPiへのリクエストを実行する
|
|
390
|
-
* @param params クエリパラメータ
|
|
391
|
-
* @returns ランキング履歴結果
|
|
392
|
-
* @see https://dev.syosetu.com/man/rankinapi/
|
|
393
|
-
*/
|
|
394
|
-
executeRankingHistory(params: RankingHistoryParams): Promise<RankingHistoryRawResult[]>;
|
|
395
|
-
/**
|
|
396
|
-
* ユーザー検索APIへのリクエストを実行する
|
|
397
|
-
* @param params クエリパラメータ
|
|
398
|
-
* @returns 検索結果
|
|
399
|
-
* @see https://dev.syosetu.com/man/userapi/
|
|
400
|
-
*/
|
|
401
|
-
executeUserSearch<T extends keyof UserSearchResult>(params: UserSearchParams): Promise<NarouSearchResults<UserSearchResult, T>>;
|
|
402
|
-
}
|
|
403
|
-
|
|
404
|
-
export { type DefaultSearchResultFields as D, NarouNovel as N, type RankingResult as R, SearchBuilder as S, type NarouParams as a, type NarouRankingResult as b, SearchBuilderBase as c, NovelSearchBuilderBase as d };
|
package/dist/narou-fetch.cjs
DELETED
|
@@ -1,164 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/narou-fetch.ts
|
|
21
|
-
var narou_fetch_exports = {};
|
|
22
|
-
__export(narou_fetch_exports, {
|
|
23
|
-
default: () => NarouNovelFetch
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(narou_fetch_exports);
|
|
26
|
-
|
|
27
|
-
// src/util/unzipp.ts
|
|
28
|
-
var import_zlib = require("zlib");
|
|
29
|
-
var import_util = require("util");
|
|
30
|
-
var gunzipAsync = (0, import_util.promisify)(import_zlib.gunzip);
|
|
31
|
-
var decoder = new TextDecoder();
|
|
32
|
-
async function unzipp(data) {
|
|
33
|
-
try {
|
|
34
|
-
const buffer = await gunzipAsync(data);
|
|
35
|
-
try {
|
|
36
|
-
return JSON.parse(decoder.decode(buffer));
|
|
37
|
-
} catch {
|
|
38
|
-
throw decoder.decode(buffer);
|
|
39
|
-
}
|
|
40
|
-
} catch (e) {
|
|
41
|
-
if (typeof e === "string") throw e;
|
|
42
|
-
throw decoder.decode(data);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// src/narou-search-results.ts
|
|
47
|
-
var NarouSearchResults = class {
|
|
48
|
-
/**
|
|
49
|
-
* @constractor
|
|
50
|
-
* @private
|
|
51
|
-
*/
|
|
52
|
-
constructor([header, ...result], params) {
|
|
53
|
-
const count = header.allcount;
|
|
54
|
-
const limit = params.lim ?? 20;
|
|
55
|
-
const start = params.st ?? 0;
|
|
56
|
-
this.allcount = count;
|
|
57
|
-
this.limit = limit;
|
|
58
|
-
this.start = start;
|
|
59
|
-
this.page = start / limit;
|
|
60
|
-
this.length = result.length;
|
|
61
|
-
this.values = result;
|
|
62
|
-
}
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
// src/narou.ts
|
|
66
|
-
var NarouNovel = class {
|
|
67
|
-
/**
|
|
68
|
-
* APIへの検索リクエストを実行する
|
|
69
|
-
* @param params クエリパラメータ
|
|
70
|
-
* @param endpoint APIエンドポイント
|
|
71
|
-
* @returns 検索結果
|
|
72
|
-
*/
|
|
73
|
-
async executeSearch(params, endpoint = "https://api.syosetu.com/novelapi/api/") {
|
|
74
|
-
return new NarouSearchResults(await this.execute(params, endpoint), params);
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* 小説APIへの検索リクエストを実行する
|
|
78
|
-
* @param params クエリパラメータ
|
|
79
|
-
* @returns 検索結果
|
|
80
|
-
* @see https://dev.syosetu.com/man/api/
|
|
81
|
-
*/
|
|
82
|
-
async executeNovel(params) {
|
|
83
|
-
return await this.executeSearch(
|
|
84
|
-
params,
|
|
85
|
-
"https://api.syosetu.com/novelapi/api/"
|
|
86
|
-
);
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* R18小説APIへの検索リクエストを実行する
|
|
90
|
-
* @param params クエリパラメータ
|
|
91
|
-
* @returns 検索結果
|
|
92
|
-
* @see https://dev.syosetu.com/xman/api/
|
|
93
|
-
*/
|
|
94
|
-
async executeNovel18(params) {
|
|
95
|
-
return await this.executeSearch(
|
|
96
|
-
params,
|
|
97
|
-
"https://api.syosetu.com/novel18api/api/"
|
|
98
|
-
);
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* ランキングAPIへのリクエストを実行する
|
|
102
|
-
* @param params クエリパラメータ
|
|
103
|
-
* @returns ランキング結果
|
|
104
|
-
* @see https://dev.syosetu.com/man/rankapi/
|
|
105
|
-
*/
|
|
106
|
-
async executeRanking(params) {
|
|
107
|
-
return await this.execute(params, "https://api.syosetu.com/rank/rankget/");
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* 殿堂入りAPiへのリクエストを実行する
|
|
111
|
-
* @param params クエリパラメータ
|
|
112
|
-
* @returns ランキング履歴結果
|
|
113
|
-
* @see https://dev.syosetu.com/man/rankinapi/
|
|
114
|
-
*/
|
|
115
|
-
async executeRankingHistory(params) {
|
|
116
|
-
return await this.execute(params, "https://api.syosetu.com/rank/rankin/");
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* ユーザー検索APIへのリクエストを実行する
|
|
120
|
-
* @param params クエリパラメータ
|
|
121
|
-
* @returns 検索結果
|
|
122
|
-
* @see https://dev.syosetu.com/man/userapi/
|
|
123
|
-
*/
|
|
124
|
-
async executeUserSearch(params) {
|
|
125
|
-
return new NarouSearchResults(
|
|
126
|
-
await this.execute(params, "https://api.syosetu.com/userapi/api/"),
|
|
127
|
-
params
|
|
128
|
-
);
|
|
129
|
-
}
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
// src/narou-fetch.ts
|
|
133
|
-
var NarouNovelFetch = class extends NarouNovel {
|
|
134
|
-
/**
|
|
135
|
-
* コンストラクタ
|
|
136
|
-
* @param fetch fetch関数(デフォルトはネイティブのfetch)
|
|
137
|
-
*/
|
|
138
|
-
constructor(fetch2) {
|
|
139
|
-
super();
|
|
140
|
-
this.fetch = fetch2;
|
|
141
|
-
}
|
|
142
|
-
async execute(params, endpoint) {
|
|
143
|
-
const query = { ...params, out: "json" };
|
|
144
|
-
if (query.gzip === void 0) {
|
|
145
|
-
query.gzip = 5;
|
|
146
|
-
}
|
|
147
|
-
if (query.gzip === 0) {
|
|
148
|
-
delete query.gzip;
|
|
149
|
-
}
|
|
150
|
-
const url = new URL(endpoint);
|
|
151
|
-
Object.entries(query).forEach(([key, value]) => {
|
|
152
|
-
if (value !== void 0) {
|
|
153
|
-
url.searchParams.append(key, value.toString());
|
|
154
|
-
}
|
|
155
|
-
});
|
|
156
|
-
const res = await (this.fetch ?? fetch)(url);
|
|
157
|
-
if (!query.gzip) {
|
|
158
|
-
return await res.json();
|
|
159
|
-
}
|
|
160
|
-
const buffer = await res.arrayBuffer();
|
|
161
|
-
return await unzipp(buffer);
|
|
162
|
-
}
|
|
163
|
-
};
|
|
164
|
-
//# sourceMappingURL=narou-fetch.cjs.map
|
package/dist/narou-fetch.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/narou-fetch.ts","../src/util/unzipp.ts","../src/narou-search-results.ts","../src/narou.ts"],"sourcesContent":["import { unzipp } from \"./util/unzipp.js\";\nimport NarouNovel from \"./narou.js\";\nimport type { NarouParams } from \"./narou.js\";\n\ntype Fetch = typeof fetch;\n\n/**\n * なろう小説APIへのリクエストを実行する\n */\nexport default class NarouNovelFetch extends NarouNovel {\n /**\n * コンストラクタ\n * @param fetch fetch関数(デフォルトはネイティブのfetch)\n */\n constructor(private fetch?: Fetch) {\n super();\n }\n\n protected async execute<T>(\n params: NarouParams,\n endpoint: string\n ): Promise<T> {\n const query = { ...params, out: \"json\" };\n\n if (query.gzip === undefined) {\n query.gzip = 5;\n }\n if (query.gzip === 0) {\n delete query.gzip;\n }\n const url = new URL(endpoint);\n\n Object.entries(query).forEach(([key, value]) => {\n if (value !== undefined) {\n url.searchParams.append(key, value.toString());\n }\n });\n\n const res = await (this.fetch ?? fetch)(url);\n\n if (!query.gzip) {\n return (await res.json()) as T;\n }\n\n const buffer = await res.arrayBuffer();\n return await unzipp(buffer);\n }\n}\n","import { gunzip, InputType } from \"zlib\";\nimport { promisify } from \"util\";\n\nconst gunzipAsync = promisify<InputType, Buffer>(gunzip);\n\nconst decoder = new TextDecoder()\n/**\n * 圧縮されたJSONデータを解凍して解析します。\n * \n * @param data - ArrayBuffer形式の圧縮データ\n * @returns 解凍されたデータからパースされたJSONオブジェクト\n * @throws {string} データが解凍できない、または解凍されたデータが有効なJSONでない場合、\n * 解凍されたデータの文字列表現をスローします。\n * @throws {string} 解凍中にエラーが発生した場合、元のデータの文字列表現をスローします。\n */\nexport async function unzipp(data: ArrayBuffer) {\n try {\n const buffer = await gunzipAsync(data);\n try {\n return JSON.parse(decoder.decode(buffer));\n } catch {\n throw decoder.decode(buffer);\n }\n } catch (e) {\n if (typeof e === \"string\") throw e;\n throw decoder.decode(data);\n }\n}\n","import type {\n BooleanNumber as BooleanNumber,\n Genre,\n R18Site,\n SearchParams,\n Fields,\n BigGenre,\n R18Fields,\n OptionalFields,\n UserFields,\n UserSearchParams,\n} from \"./params.js\";\n\n/**\n * なろう小説API検索結果\n */\nexport default class NarouSearchResults<T, TKey extends keyof T> {\n /**\n * 検索結果数\n */\n allcount: number;\n /**\n * 結果表示上限数\n */\n limit: number;\n /**\n * 結果表示開始数\n */\n start: number;\n /**\n * 結果表示の現在ページ(=start/limit)\n */\n page: number;\n /**\n * 今回取得できた検索結果の数\n */\n length: number;\n /**\n * 検索結果\n */\n values: readonly Pick<T, TKey>[];\n\n /**\n * @constractor\n * @private\n */\n constructor(\n [header, ...result]: [{ allcount: number }, ...Pick<T, TKey>[]],\n params: SearchParams | UserSearchParams\n ) {\n const count = header.allcount;\n const limit = params.lim ?? 20;\n const start = params.st ?? 0;\n\n this.allcount = count;\n this.limit = limit;\n this.start = start;\n this.page = start / limit;\n this.length = result.length;\n this.values = result;\n }\n}\n\n/**\n * 小説情報\n * @see https://dev.syosetu.com/man/api/#output\n * @see https://dev.syosetu.com/xman/api/#output\n */\nexport interface NarouSearchResult {\n /** 小説名 */\n title: string;\n /** Nコード */\n ncode: string;\n /** 作者のユーザID(数値) */\n userid: number;\n /** 作者名 */\n writer: string;\n /** 小説のあらすじ */\n story: string;\n /** 掲載サイト */\n nocgenre: R18Site;\n /** 大ジャンル */\n biggenre: BigGenre;\n /** ジャンル */\n genre: Genre;\n /** キーワード */\n keyword: string;\n /** 初回掲載日 YYYY-MM-DD HH:MM:SSの形式 */\n general_firstup: string;\n /** 最終掲載日 YYYY-MM-DD HH:MM:SSの形式 */\n general_lastup: string;\n /** 連載の場合は1、短編の場合は2 */\n novel_type: NovelType;\n /** 連載の場合は1、短編の場合は2 */\n noveltype: NovelType;\n /** 短編小説と完結済小説は0となっています。連載中は1です。 */\n end: End;\n /** 全掲載話数です。短編の場合は1です。 */\n general_all_no: number;\n /** 小説文字数です。スペースや改行は文字数としてカウントしません。 */\n length: number;\n /** 読了時間(分単位)です。読了時間は小説文字数÷500を切り上げした数値です。 */\n time: number;\n /** 長期連載中は1、それ以外は0です。 */\n isstop: BooleanNumber;\n /** 登録必須キーワードに「R15」が含まれる場合は1、それ以外は0です。 */\n isr15: BooleanNumber;\n /** 登録必須キーワードに「ボーイズラブ」が含まれる場合は1、それ以外は0です。 */\n isbl: BooleanNumber;\n /** 登録必須キーワードに「ガールズラブ」が含まれる場合は1、それ以外は0です。 */\n isgl: BooleanNumber;\n /** 登録必須キーワードに「残酷な描写あり」が含まれる場合は1、それ以外は0です。 */\n iszankoku: BooleanNumber;\n /** 登録必須キーワードに「異世界転生」が含まれる場合は1、それ以外は0です。 */\n istensei: BooleanNumber;\n /** 登録必須キーワードに「異世界転移」が含まれる場合は1、それ以外は0です。 */\n istenni: BooleanNumber;\n /** 総合得点(=(ブックマーク数×2)+評価点) */\n global_point: number;\n /**\n * 日間ポイント\n * ランキング集計時点から過去24時間以内で新たに登録されたブックマークや評価が対象\n */\n daily_point: number;\n /**\n * 週間ポイント\n * ランキング集計時点から過去7日以内で新たに登録されたブックマークや評価が対象\n */\n weekly_point: number;\n /**\n * 月間ポイント\n * ランキング集計時点から過去30日以内で新たに登録されたブックマークや評価が対象\n */\n monthly_point: number;\n /**\n * 四半期ポイント\n * ランキング集計時点から過去90日以内で新たに登録されたブックマークや評価が対象\n */\n quarter_point: number;\n /**\n * 年間ポイント\n * ランキング集計時点から過去365日以内で新たに登録されたブックマークや評価が対象\n */\n yearly_point: number;\n /** ブックマーク数 */\n fav_novel_cnt: number;\n /** 感想数 */\n impression_cnt: number;\n /** レビュー数 */\n review_cnt: number;\n /** 評価ポイント */\n all_point: number;\n /** 評価者数 */\n all_hyoka_cnt: number;\n /** 挿絵の数 */\n sasie_cnt: number;\n /**\n * 会話率\n * @see https://dev.syosetu.com/man/kaiwa/\n */\n kaiwaritu: number;\n /**\n * 小説の更新日時\n */\n novelupdated_at: string;\n /**\n * 最終更新日時\n * システム用で小説更新時とは関係ありません\n */\n updated_at: string;\n /** 週間ユニークユーザー数 */\n weekly_unique: number;\n}\n\n/**\n * ユーザ情報\n * @see https://dev.syosetu.com/man/userapi/#output\n */\nexport interface UserSearchResult {\n /** ユーザID */\n userid: number;\n /** ユーザ名 */\n name: string;\n /** ユーザ名のフリガナ */\n yomikata: string;\n /**\n * ユーザ名のフリガナの頭文字\n * ひらがな以外の場合はnullまたは空文字となります。\n */\n name1st: string;\n /** 小説投稿数 */\n novel_cnt: number;\n /** レビュー投稿数 */\n review_cnt: number;\n /**\n * 小説累計文字数\n * スペースや改行は文字数としてカウントしません。\n */\n novel_length: number;\n /**\n * 総合評価ポイントの合計\n * 投稿済小説でそれぞれ獲得した総合評価ポイントの合計です。\n */\n sum_global_point: number;\n}\n\n/**\n * noveltype/novel_typeの値ヘルパー\n */\nexport const NovelType = {\n /** 連載 */\n Rensai: 1,\n /** 短編 */\n Tanpen: 2,\n} as const;\nexport type NovelType = typeof NovelType[keyof typeof NovelType];\n\n/**\n * endの値ヘルパー\n */\nexport const End = {\n /** 短編小説と完結済小説 */\n KanketsuOrTanpen: 0,\n /** 連載中 */\n Rensai: 1,\n} as const;\nexport type End = typeof End[keyof typeof End];\n\nexport type SearchResultFields<T extends Fields> = {\n [K in keyof typeof Fields]: typeof Fields[K] extends T ? K : never;\n}[keyof typeof Fields];\n\nexport type SearchResultOptionalFields<T extends OptionalFields> = {\n [K in keyof typeof OptionalFields]: typeof OptionalFields[K] extends T\n ? K\n : never;\n}[keyof typeof OptionalFields];\n\nexport type SearchResultR18Fields<T extends R18Fields> = {\n [K in keyof typeof R18Fields]: typeof R18Fields[K] extends T ? K : never;\n}[keyof typeof R18Fields];\n\nexport type UserSearchResultFields<T extends UserFields> = {\n [K in keyof typeof UserFields]: typeof UserFields[K] extends T ? K : never;\n}[keyof typeof UserFields];\n\nexport type PickedNarouSearchResult<T extends keyof NarouSearchResult> = Pick<\n NarouSearchResult,\n T\n>;\n","import type { NarouRankingResult } from \"./narou-ranking-results.js\";\nimport NarouSearchResults from \"./narou-search-results.js\";\nimport type {\n NarouSearchResult,\n UserSearchResult,\n} from \"./narou-search-results.js\";\nimport type {\n RankingHistoryParams,\n RankingParams,\n SearchParams,\n UserSearchParams,\n} from \"./params.js\";\nimport type { RankingHistoryRawResult } from \"./ranking-history.js\";\n\n/**\n * なろう小説APIへのリクエストパラメータ\n */\nexport type NarouParams =\n | SearchParams\n | RankingParams\n | RankingHistoryParams\n | UserSearchParams;\n\n/**\n * なろう小説APIへのリクエストを実行する\n * @class NarouNovel\n * @private\n */\nexport default abstract class NarouNovel {\n /**\n * なろうAPIへのAPIリクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 実行結果\n */\n protected abstract execute<T>(\n params: NarouParams,\n endpoint: string\n ): Promise<T>;\n\n /**\n * APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @param endpoint APIエンドポイント\n * @returns 検索結果\n */\n protected async executeSearch<T extends keyof NarouSearchResult>(\n params: SearchParams,\n endpoint = \"https://api.syosetu.com/novelapi/api/\"\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return new NarouSearchResults(await this.execute(params, endpoint), params);\n }\n\n /**\n * 小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/api/\n */\n async executeNovel<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novelapi/api/\"\n );\n }\n\n /**\n * R18小説APIへの検索リクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/xman/api/\n */\n async executeNovel18<T extends keyof NarouSearchResult>(\n params: SearchParams\n ): Promise<NarouSearchResults<NarouSearchResult, T>> {\n return await this.executeSearch(\n params,\n \"https://api.syosetu.com/novel18api/api/\"\n );\n }\n\n /**\n * ランキングAPIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング結果\n * @see https://dev.syosetu.com/man/rankapi/\n */\n async executeRanking(params: RankingParams): Promise<NarouRankingResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankget/\");\n }\n\n /**\n * 殿堂入りAPiへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns ランキング履歴結果\n * @see https://dev.syosetu.com/man/rankinapi/\n */\n async executeRankingHistory(\n params: RankingHistoryParams\n ): Promise<RankingHistoryRawResult[]> {\n return await this.execute(params, \"https://api.syosetu.com/rank/rankin/\");\n }\n\n /**\n * ユーザー検索APIへのリクエストを実行する\n * @param params クエリパラメータ\n * @returns 検索結果\n * @see https://dev.syosetu.com/man/userapi/\n */\n async executeUserSearch<T extends keyof UserSearchResult>(\n params: UserSearchParams\n ): Promise<NarouSearchResults<UserSearchResult, T>> {\n return new NarouSearchResults<UserSearchResult, T>(\n await this.execute(params, \"https://api.syosetu.com/userapi/api/\"),\n params\n );\n }\n}\n"],"mappings":"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","names":["fetch"]}
|
package/dist/narou-fetch.d.cts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { N as NarouNovel, a as NarouParams } from './narou-DCp4aGfA.cjs';
|
|
2
|
-
import './narou-search-results-C21hWrnL.cjs';
|
|
3
|
-
import './util/type.cjs';
|
|
4
|
-
import './ranking-history.cjs';
|
|
5
|
-
|
|
6
|
-
type Fetch = typeof fetch;
|
|
7
|
-
/**
|
|
8
|
-
* なろう小説APIへのリクエストを実行する
|
|
9
|
-
*/
|
|
10
|
-
declare class NarouNovelFetch extends NarouNovel {
|
|
11
|
-
private fetch?;
|
|
12
|
-
/**
|
|
13
|
-
* コンストラクタ
|
|
14
|
-
* @param fetch fetch関数(デフォルトはネイティブのfetch)
|
|
15
|
-
*/
|
|
16
|
-
constructor(fetch?: Fetch | undefined);
|
|
17
|
-
protected execute<T>(params: NarouParams, endpoint: string): Promise<T>;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export { NarouNovelFetch as default };
|
package/dist/narou-fetch.d.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { N as NarouNovel, a as NarouParams } from './narou-DBa12V_l.js';
|
|
2
|
-
import './narou-search-results-DT0YdaBn.js';
|
|
3
|
-
import './util/type.js';
|
|
4
|
-
import './ranking-history.js';
|
|
5
|
-
|
|
6
|
-
type Fetch = typeof fetch;
|
|
7
|
-
/**
|
|
8
|
-
* なろう小説APIへのリクエストを実行する
|
|
9
|
-
*/
|
|
10
|
-
declare class NarouNovelFetch extends NarouNovel {
|
|
11
|
-
private fetch?;
|
|
12
|
-
/**
|
|
13
|
-
* コンストラクタ
|
|
14
|
-
* @param fetch fetch関数(デフォルトはネイティブのfetch)
|
|
15
|
-
*/
|
|
16
|
-
constructor(fetch?: Fetch | undefined);
|
|
17
|
-
protected execute<T>(params: NarouParams, endpoint: string): Promise<T>;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
export { NarouNovelFetch as default };
|
package/dist/narou-fetch.js
DELETED
package/dist/narou-fetch.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|