@irfanshadikrishad/anilist 1.2.1-forbidden.1 → 1.2.4

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.
@@ -1,28 +1,28 @@
1
- # Mozilla Public License Version 2.0
1
+ Mozilla Public License Version 2.0
2
+ ==================================
2
3
 
3
4
  1. Definitions
4
-
5
- ---
5
+ --------------
6
6
 
7
7
  1.1. "Contributor"
8
- means each individual or legal entity that creates, contributes to
9
- the creation of, or owns Covered Software.
8
+ means each individual or legal entity that creates, contributes to
9
+ the creation of, or owns Covered Software.
10
10
 
11
11
  1.2. "Contributor Version"
12
- means the combination of the Contributions of others (if any) used
13
- by a Contributor and that particular Contributor's Contribution.
12
+ means the combination of the Contributions of others (if any) used
13
+ by a Contributor and that particular Contributor's Contribution.
14
14
 
15
15
  1.3. "Contribution"
16
- means Covered Software of a particular Contributor.
16
+ means Covered Software of a particular Contributor.
17
17
 
18
18
  1.4. "Covered Software"
19
- means Source Code Form to which the initial Contributor has attached
20
- the notice in Exhibit A, the Executable Form of such Source Code
21
- Form, and Modifications of such Source Code Form, in each case
22
- including portions thereof.
19
+ means Source Code Form to which the initial Contributor has attached
20
+ the notice in Exhibit A, the Executable Form of such Source Code
21
+ Form, and Modifications of such Source Code Form, in each case
22
+ including portions thereof.
23
23
 
24
24
  1.5. "Incompatible With Secondary Licenses"
25
- means
25
+ means
26
26
 
27
27
  (a) that the initial Contributor has attached the notice described
28
28
  in Exhibit B to the Covered Software; or
@@ -32,22 +32,22 @@ means
32
32
  terms of a Secondary License.
33
33
 
34
34
  1.6. "Executable Form"
35
- means any form of the work other than Source Code Form.
35
+ means any form of the work other than Source Code Form.
36
36
 
37
37
  1.7. "Larger Work"
38
- means a work that combines Covered Software with other material, in
39
- a separate file or files, that is not Covered Software.
38
+ means a work that combines Covered Software with other material, in
39
+ a separate file or files, that is not Covered Software.
40
40
 
41
41
  1.8. "License"
42
- means this document.
42
+ means this document.
43
43
 
44
44
  1.9. "Licensable"
45
- means having the right to grant, to the maximum extent possible,
46
- whether at the time of the initial grant or subsequently, any and
47
- all of the rights conveyed by this License.
45
+ means having the right to grant, to the maximum extent possible,
46
+ whether at the time of the initial grant or subsequently, any and
47
+ all of the rights conveyed by this License.
48
48
 
49
49
  1.10. "Modifications"
50
- means any of the following:
50
+ means any of the following:
51
51
 
52
52
  (a) any file in Source Code Form that results from an addition to,
53
53
  deletion from, or modification of the contents of Covered
@@ -57,35 +57,34 @@ means any of the following:
57
57
  Software.
58
58
 
59
59
  1.11. "Patent Claims" of a Contributor
60
- means any patent claim(s), including without limitation, method,
61
- process, and apparatus claims, in any patent Licensable by such
62
- Contributor that would be infringed, but for the grant of the
63
- License, by the making, using, selling, offering for sale, having
64
- made, import, or transfer of either its Contributions or its
65
- Contributor Version.
60
+ means any patent claim(s), including without limitation, method,
61
+ process, and apparatus claims, in any patent Licensable by such
62
+ Contributor that would be infringed, but for the grant of the
63
+ License, by the making, using, selling, offering for sale, having
64
+ made, import, or transfer of either its Contributions or its
65
+ Contributor Version.
66
66
 
67
67
  1.12. "Secondary License"
68
- means either the GNU General Public License, Version 2.0, the GNU
69
- Lesser General Public License, Version 2.1, the GNU Affero General
70
- Public License, Version 3.0, or any later versions of those
71
- licenses.
68
+ means either the GNU General Public License, Version 2.0, the GNU
69
+ Lesser General Public License, Version 2.1, the GNU Affero General
70
+ Public License, Version 3.0, or any later versions of those
71
+ licenses.
72
72
 
73
73
  1.13. "Source Code Form"
74
- means the form of the work preferred for making modifications.
74
+ means the form of the work preferred for making modifications.
75
75
 
76
76
  1.14. "You" (or "Your")
77
- means an individual or a legal entity exercising rights under this
78
- License. For legal entities, "You" includes any entity that
79
- controls, is controlled by, or is under common control with You. For
80
- purposes of this definition, "control" means (a) the power, direct
81
- or indirect, to cause the direction or management of such entity,
82
- whether by contract or otherwise, or (b) ownership of more than
83
- fifty percent (50%) of the outstanding shares or beneficial
84
- ownership of such entity.
77
+ means an individual or a legal entity exercising rights under this
78
+ License. For legal entities, "You" includes any entity that
79
+ controls, is controlled by, or is under common control with You. For
80
+ purposes of this definition, "control" means (a) the power, direct
81
+ or indirect, to cause the direction or management of such entity,
82
+ whether by contract or otherwise, or (b) ownership of more than
83
+ fifty percent (50%) of the outstanding shares or beneficial
84
+ ownership of such entity.
85
85
 
86
86
  2. License Grants and Conditions
87
-
88
- ---
87
+ --------------------------------
89
88
 
90
89
  2.1. Grants
91
90
 
@@ -93,14 +92,14 @@ Each Contributor hereby grants You a world-wide, royalty-free,
93
92
  non-exclusive license:
94
93
 
95
94
  (a) under intellectual property rights (other than patent or trademark)
96
- Licensable by such Contributor to use, reproduce, make available,
97
- modify, display, perform, distribute, and otherwise exploit its
98
- Contributions, either on an unmodified basis, with Modifications, or
99
- as part of a Larger Work; and
95
+ Licensable by such Contributor to use, reproduce, make available,
96
+ modify, display, perform, distribute, and otherwise exploit its
97
+ Contributions, either on an unmodified basis, with Modifications, or
98
+ as part of a Larger Work; and
100
99
 
101
100
  (b) under Patent Claims of such Contributor to make, use, sell, offer
102
- for sale, have made, import, and otherwise transfer either its
103
- Contributions or its Contributor Version.
101
+ for sale, have made, import, and otherwise transfer either its
102
+ Contributions or its Contributor Version.
104
103
 
105
104
  2.2. Effective Date
106
105
 
@@ -117,15 +116,15 @@ Notwithstanding Section 2.1(b) above, no patent license is granted by a
117
116
  Contributor:
118
117
 
119
118
  (a) for any code that a Contributor has removed from Covered Software;
120
- or
119
+ or
121
120
 
122
121
  (b) for infringements caused by: (i) Your and any other third party's
123
- modifications of Covered Software, or (ii) the combination of its
124
- Contributions with other software (except as part of its Contributor
125
- Version); or
122
+ modifications of Covered Software, or (ii) the combination of its
123
+ Contributions with other software (except as part of its Contributor
124
+ Version); or
126
125
 
127
126
  (c) under Patent Claims infringed by Covered Software in the absence of
128
- its Contributions.
127
+ its Contributions.
129
128
 
130
129
  This License does not grant any rights in the trademarks, service marks,
131
130
  or logos of any Contributor (except as may be necessary to comply with
@@ -156,8 +155,7 @@ Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted
156
155
  in Section 2.1.
157
156
 
158
157
  3. Responsibilities
159
-
160
- ---
158
+ -------------------
161
159
 
162
160
  3.1. Distribution of Source Form
163
161
 
@@ -174,15 +172,15 @@ Form.
174
172
  If You distribute Covered Software in Executable Form then:
175
173
 
176
174
  (a) such Covered Software must also be made available in Source Code
177
- Form, as described in Section 3.1, and You must inform recipients of
178
- the Executable Form how they can obtain a copy of such Source Code
179
- Form by reasonable means in a timely manner, at a charge no more
180
- than the cost of distribution to the recipient; and
175
+ Form, as described in Section 3.1, and You must inform recipients of
176
+ the Executable Form how they can obtain a copy of such Source Code
177
+ Form by reasonable means in a timely manner, at a charge no more
178
+ than the cost of distribution to the recipient; and
181
179
 
182
180
  (b) You may distribute such Executable Form under the terms of this
183
- License, or sublicense it under different terms, provided that the
184
- license for the Executable Form does not attempt to limit or alter
185
- the recipients' rights in the Source Code Form under this License.
181
+ License, or sublicense it under different terms, provided that the
182
+ license for the Executable Form does not attempt to limit or alter
183
+ the recipients' rights in the Source Code Form under this License.
186
184
 
187
185
  3.3. Distribution of a Larger Work
188
186
 
@@ -219,8 +217,7 @@ disclaimers of warranty and limitations of liability specific to any
219
217
  jurisdiction.
220
218
 
221
219
  4. Inability to Comply Due to Statute or Regulation
222
-
223
- ---
220
+ ---------------------------------------------------
224
221
 
225
222
  If it is impossible for You to comply with any of the terms of this
226
223
  License with respect to some or all of the Covered Software due to
@@ -233,8 +230,7 @@ or regulation, such description must be sufficiently detailed for a
233
230
  recipient of ordinary skill to be able to understand it.
234
231
 
235
232
  5. Termination
236
-
237
- ---
233
+ --------------
238
234
 
239
235
  5.1. The rights granted under this License will terminate automatically
240
236
  if You fail to comply with any of its terms. However, if You become
@@ -262,55 +258,50 @@ end user license agreements (excluding distributors and resellers) which
262
258
  have been validly granted by You or Your distributors under this License
263
259
  prior to termination shall survive termination.
264
260
 
265
- ---
266
-
267
- - *
268
- - 6. Disclaimer of Warranty \*
269
- - ------------------------- \*
270
- - *
271
- - Covered Software is provided under this License on an "as is" \*
272
- - basis, without warranty of any kind, either expressed, implied, or \*
273
- - statutory, including, without limitation, warranties that the \*
274
- - Covered Software is free of defects, merchantable, fit for a \*
275
- - particular purpose or non-infringing. The entire risk as to the \*
276
- - quality and performance of the Covered Software is with You. \*
277
- - Should any Covered Software prove defective in any respect, You \*
278
- - (not any Contributor) assume the cost of any necessary servicing, \*
279
- - repair, or correction. This disclaimer of warranty constitutes an \*
280
- - essential part of this License. No use of any Covered Software is \*
281
- - authorized under this License except under this disclaimer. \*
282
- - *
283
-
284
- ---
285
-
286
- ---
287
-
288
- - *
289
- - 7. Limitation of Liability \*
290
- - -------------------------- \*
291
- - *
292
- - Under no circumstances and under no legal theory, whether tort \*
293
- - (including negligence), contract, or otherwise, shall any \*
294
- - Contributor, or anyone who distributes Covered Software as \*
295
- - permitted above, be liable to You for any direct, indirect, \*
296
- - special, incidental, or consequential damages of any character \*
297
- - including, without limitation, damages for lost profits, loss of \*
298
- - goodwill, work stoppage, computer failure or malfunction, or any \*
299
- - and all other commercial damages or losses, even if such party \*
300
- - shall have been informed of the possibility of such damages. This \*
301
- - limitation of liability shall not apply to liability for death or \*
302
- - personal injury resulting from such party's negligence to the \*
303
- - extent applicable law prohibits such limitation. Some \*
304
- - jurisdictions do not allow the exclusion or limitation of \*
305
- - incidental or consequential damages, so this exclusion and \*
306
- - limitation may not apply to You. \*
307
- - *
308
-
309
- ---
261
+ ************************************************************************
262
+ * *
263
+ * 6. Disclaimer of Warranty *
264
+ * ------------------------- *
265
+ * *
266
+ * Covered Software is provided under this License on an "as is" *
267
+ * basis, without warranty of any kind, either expressed, implied, or *
268
+ * statutory, including, without limitation, warranties that the *
269
+ * Covered Software is free of defects, merchantable, fit for a *
270
+ * particular purpose or non-infringing. The entire risk as to the *
271
+ * quality and performance of the Covered Software is with You. *
272
+ * Should any Covered Software prove defective in any respect, You *
273
+ * (not any Contributor) assume the cost of any necessary servicing, *
274
+ * repair, or correction. This disclaimer of warranty constitutes an *
275
+ * essential part of this License. No use of any Covered Software is *
276
+ * authorized under this License except under this disclaimer. *
277
+ * *
278
+ ************************************************************************
279
+
280
+ ************************************************************************
281
+ * *
282
+ * 7. Limitation of Liability *
283
+ * -------------------------- *
284
+ * *
285
+ * Under no circumstances and under no legal theory, whether tort *
286
+ * (including negligence), contract, or otherwise, shall any *
287
+ * Contributor, or anyone who distributes Covered Software as *
288
+ * permitted above, be liable to You for any direct, indirect, *
289
+ * special, incidental, or consequential damages of any character *
290
+ * including, without limitation, damages for lost profits, loss of *
291
+ * goodwill, work stoppage, computer failure or malfunction, or any *
292
+ * and all other commercial damages or losses, even if such party *
293
+ * shall have been informed of the possibility of such damages. This *
294
+ * limitation of liability shall not apply to liability for death or *
295
+ * personal injury resulting from such party's negligence to the *
296
+ * extent applicable law prohibits such limitation. Some *
297
+ * jurisdictions do not allow the exclusion or limitation of *
298
+ * incidental or consequential damages, so this exclusion and *
299
+ * limitation may not apply to You. *
300
+ * *
301
+ ************************************************************************
310
302
 
311
303
  8. Litigation
312
-
313
- ---
304
+ -------------
314
305
 
315
306
  Any litigation relating to this License may be brought only in the
316
307
  courts of a jurisdiction where the defendant maintains its principal
@@ -320,8 +311,7 @@ Nothing in this Section shall prevent a party's ability to bring
320
311
  cross-claims or counter-claims.
321
312
 
322
313
  9. Miscellaneous
323
-
324
- ---
314
+ ----------------
325
315
 
326
316
  This License represents the complete agreement concerning the subject
327
317
  matter hereof. If any provision of this License is held to be
@@ -331,8 +321,7 @@ that the language of a contract shall be construed against the drafter
331
321
  shall not be used to construe this License against a Contributor.
332
322
 
333
323
  10. Versions of the License
334
-
335
- ---
324
+ ---------------------------
336
325
 
337
326
  10.1. New Versions
338
327
 
@@ -363,11 +352,12 @@ If You choose to distribute Source Code Form that is Incompatible With
363
352
  Secondary Licenses under the terms of this version of the License, the
364
353
  notice described in Exhibit B of this License must be attached.
365
354
 
366
- ## Exhibit A - Source Code Form License Notice
355
+ Exhibit A - Source Code Form License Notice
356
+ -------------------------------------------
367
357
 
368
- This Source Code Form is subject to the terms of the Mozilla Public
369
- License, v. 2.0. If a copy of the MPL was not distributed with this
370
- file, You can obtain one at http://mozilla.org/MPL/2.0/.
358
+ This Source Code Form is subject to the terms of the Mozilla Public
359
+ License, v. 2.0. If a copy of the MPL was not distributed with this
360
+ file, You can obtain one at http://mozilla.org/MPL/2.0/.
371
361
 
372
362
  If it is not possible or desirable to put the notice in a particular
373
363
  file, then You may include the notice in a location (such as a LICENSE
@@ -376,7 +366,8 @@ for such a notice.
376
366
 
377
367
  You may add additional accurate notices of copyright ownership.
378
368
 
379
- ## Exhibit B - "Incompatible With Secondary Licenses" Notice
369
+ Exhibit B - "Incompatible With Secondary Licenses" Notice
370
+ ---------------------------------------------------------
380
371
 
381
- This Source Code Form is "Incompatible With Secondary Licenses", as
382
- defined by the Mozilla Public License, v. 2.0.
372
+ This Source Code Form is "Incompatible With Secondary Licenses", as
373
+ defined by the Mozilla Public License, v. 2.0.
package/README.md CHANGED
@@ -237,9 +237,4 @@ Since you are creating your own API client for login no else else can get your c
237
237
 
238
238
  Want to contribute to the project? Check out complete guideline [here](CONTRIBUTING.md).
239
239
 
240
- #### Donation
241
-
242
- <img src='/assets/binance.jpg' alt='irfanshadikrishad_binance_pay' width='200px'><br>
243
- Support the project if you find it useful to you.
244
-
245
240
  #### **_Thanks for visiting 💙_**
@@ -48,9 +48,5 @@ declare class Auth {
48
48
  static Write(status: string): Promise<void>;
49
49
  static callAnimeImporter(): Promise<void>;
50
50
  static callMangaImporter(): Promise<void>;
51
- private static LikeFollowing;
52
- private static Like;
53
- private static LikeSpecificUser;
54
- static AutoLike(): Promise<void>;
55
51
  }
56
52
  export { Auth };
@@ -15,8 +15,8 @@ import os from "os";
15
15
  import path from "path";
16
16
  import { fetcher } from "./fetcher.js";
17
17
  import { AniList, MyAnimeList } from "./lists.js";
18
- import { deleteActivityMutation, likeActivityMutation, saveTextActivityMutation, } from "./mutations.js";
19
- import { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, followingActivitiesQuery, globalActivitiesQuery, specificUserActivitiesQuery, userActivityQuery, userQuery, } from "./queries.js";
18
+ import { deleteActivityMutation, saveTextActivityMutation, } from "./mutations.js";
19
+ import { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, userActivityQuery, } from "./queries.js";
20
20
  import { aniListEndpoint, getTitle, redirectUri, timestampToTimeAgo, } from "./workers.js";
21
21
  const home_dir = os.homedir();
22
22
  const save_path = path.join(home_dir, ".anilist_token");
@@ -130,30 +130,30 @@ class Auth {
130
130
  perPage: 10,
131
131
  });
132
132
  const activities = (_b = (_a = activiResponse === null || activiResponse === void 0 ? void 0 : activiResponse.data) === null || _a === void 0 ? void 0 : _a.Page) === null || _b === void 0 ? void 0 : _b.activities;
133
- console.log(`
134
- ID: ${user === null || user === void 0 ? void 0 : user.id}
135
- Name: ${user === null || user === void 0 ? void 0 : user.name}
136
- siteUrl: ${user === null || user === void 0 ? void 0 : user.siteUrl}
137
- profileColor: ${(_c = user === null || user === void 0 ? void 0 : user.options) === null || _c === void 0 ? void 0 : _c.profileColor}
138
- timeZone: ${(_d = user === null || user === void 0 ? void 0 : user.options) === null || _d === void 0 ? void 0 : _d.timezone}
139
- activityMergeTime: ${(_e = user === null || user === void 0 ? void 0 : user.options) === null || _e === void 0 ? void 0 : _e.activityMergeTime}
140
- donatorTier: ${user === null || user === void 0 ? void 0 : user.donatorTier}
141
- donatorBadge: ${user === null || user === void 0 ? void 0 : user.donatorBadge}
142
- unreadNotificationCount:${user === null || user === void 0 ? void 0 : user.unreadNotificationCount}
143
- Account Created: ${new Date((user === null || user === void 0 ? void 0 : user.createdAt) * 1000).toUTCString()}
144
- Account Updated: ${new Date((user === null || user === void 0 ? void 0 : user.updatedAt) * 1000).toUTCString()}
145
-
146
- Statistics (Anime):
147
- Count: ${(_g = (_f = user === null || user === void 0 ? void 0 : user.statistics) === null || _f === void 0 ? void 0 : _f.anime) === null || _g === void 0 ? void 0 : _g.count}
148
- Mean Score: ${(_j = (_h = user === null || user === void 0 ? void 0 : user.statistics) === null || _h === void 0 ? void 0 : _h.anime) === null || _j === void 0 ? void 0 : _j.meanScore}
149
- Minutes Watched: ${(_l = (_k = user === null || user === void 0 ? void 0 : user.statistics) === null || _k === void 0 ? void 0 : _k.anime) === null || _l === void 0 ? void 0 : _l.minutesWatched}
150
- Episodes Watched: ${(_o = (_m = user === null || user === void 0 ? void 0 : user.statistics) === null || _m === void 0 ? void 0 : _m.anime) === null || _o === void 0 ? void 0 : _o.episodesWatched}
151
-
152
- Statistics (Manga):
153
- Count: ${(_q = (_p = user === null || user === void 0 ? void 0 : user.statistics) === null || _p === void 0 ? void 0 : _p.manga) === null || _q === void 0 ? void 0 : _q.count}
154
- Mean Score: ${(_s = (_r = user === null || user === void 0 ? void 0 : user.statistics) === null || _r === void 0 ? void 0 : _r.manga) === null || _s === void 0 ? void 0 : _s.meanScore}
155
- Chapters Read: ${(_u = (_t = user === null || user === void 0 ? void 0 : user.statistics) === null || _t === void 0 ? void 0 : _t.manga) === null || _u === void 0 ? void 0 : _u.chaptersRead}
156
- Volumes Read: ${(_w = (_v = user === null || user === void 0 ? void 0 : user.statistics) === null || _v === void 0 ? void 0 : _v.manga) === null || _w === void 0 ? void 0 : _w.volumesRead}
133
+ console.log(`
134
+ ID: ${user === null || user === void 0 ? void 0 : user.id}
135
+ Name: ${user === null || user === void 0 ? void 0 : user.name}
136
+ siteUrl: ${user === null || user === void 0 ? void 0 : user.siteUrl}
137
+ profileColor: ${(_c = user === null || user === void 0 ? void 0 : user.options) === null || _c === void 0 ? void 0 : _c.profileColor}
138
+ timeZone: ${(_d = user === null || user === void 0 ? void 0 : user.options) === null || _d === void 0 ? void 0 : _d.timezone}
139
+ activityMergeTime: ${(_e = user === null || user === void 0 ? void 0 : user.options) === null || _e === void 0 ? void 0 : _e.activityMergeTime}
140
+ donatorTier: ${user === null || user === void 0 ? void 0 : user.donatorTier}
141
+ donatorBadge: ${user === null || user === void 0 ? void 0 : user.donatorBadge}
142
+ unreadNotificationCount:${user === null || user === void 0 ? void 0 : user.unreadNotificationCount}
143
+ Account Created: ${new Date((user === null || user === void 0 ? void 0 : user.createdAt) * 1000).toUTCString()}
144
+ Account Updated: ${new Date((user === null || user === void 0 ? void 0 : user.updatedAt) * 1000).toUTCString()}
145
+
146
+ Statistics (Anime):
147
+ Count: ${(_g = (_f = user === null || user === void 0 ? void 0 : user.statistics) === null || _f === void 0 ? void 0 : _f.anime) === null || _g === void 0 ? void 0 : _g.count}
148
+ Mean Score: ${(_j = (_h = user === null || user === void 0 ? void 0 : user.statistics) === null || _h === void 0 ? void 0 : _h.anime) === null || _j === void 0 ? void 0 : _j.meanScore}
149
+ Minutes Watched: ${(_l = (_k = user === null || user === void 0 ? void 0 : user.statistics) === null || _k === void 0 ? void 0 : _k.anime) === null || _l === void 0 ? void 0 : _l.minutesWatched}
150
+ Episodes Watched: ${(_o = (_m = user === null || user === void 0 ? void 0 : user.statistics) === null || _m === void 0 ? void 0 : _m.anime) === null || _o === void 0 ? void 0 : _o.episodesWatched}
151
+
152
+ Statistics (Manga):
153
+ Count: ${(_q = (_p = user === null || user === void 0 ? void 0 : user.statistics) === null || _p === void 0 ? void 0 : _p.manga) === null || _q === void 0 ? void 0 : _q.count}
154
+ Mean Score: ${(_s = (_r = user === null || user === void 0 ? void 0 : user.statistics) === null || _r === void 0 ? void 0 : _r.manga) === null || _s === void 0 ? void 0 : _s.meanScore}
155
+ Chapters Read: ${(_u = (_t = user === null || user === void 0 ? void 0 : user.statistics) === null || _t === void 0 ? void 0 : _t.manga) === null || _u === void 0 ? void 0 : _u.chaptersRead}
156
+ Volumes Read: ${(_w = (_v = user === null || user === void 0 ? void 0 : user.statistics) === null || _v === void 0 ? void 0 : _v.manga) === null || _w === void 0 ? void 0 : _w.volumesRead}
157
157
  `);
158
158
  console.log(`\nRecent Activities:`);
159
159
  if (activities.length > 0) {
@@ -581,215 +581,5 @@ Statistics (Manga):
581
581
  }
582
582
  });
583
583
  }
584
- static LikeFollowing() {
585
- return __awaiter(this, void 0, void 0, function* () {
586
- var _a, _b, _c, _d, _e;
587
- try {
588
- let page = 1;
589
- let hasMoreActivities = true;
590
- let retryCount = 0;
591
- const maxRetries = 5;
592
- while (hasMoreActivities) {
593
- const activities = yield fetcher(followingActivitiesQuery, {
594
- page,
595
- perPage: 50,
596
- });
597
- if (activities && ((_b = (_a = activities === null || activities === void 0 ? void 0 : activities.data) === null || _a === void 0 ? void 0 : _a.Page) === null || _b === void 0 ? void 0 : _b.activities.length) > 0) {
598
- retryCount = 0; // Reset retry count on successful fetch
599
- const activiti = (_d = (_c = activities === null || activities === void 0 ? void 0 : activities.data) === null || _c === void 0 ? void 0 : _c.Page) === null || _d === void 0 ? void 0 : _d.activities;
600
- for (let activ of activiti) {
601
- if (!activ.isLiked && activ.id) {
602
- try {
603
- const like = yield fetcher(likeActivityMutation, {
604
- activityId: activ.id,
605
- });
606
- console.info(`[${activ.id}]\t${(_e = activ.user) === null || _e === void 0 ? void 0 : _e.name} ${(like === null || like === void 0 ? void 0 : like.data) ? "✅" : "❌"}`);
607
- }
608
- catch (error) {
609
- console.error(`Activity possibly deleted. ${error.message}`);
610
- }
611
- }
612
- else {
613
- console.log(`[${activ === null || activ === void 0 ? void 0 : activ.id}]\t${activ.user.name} already-liked`);
614
- }
615
- // avoiding rate-limit
616
- yield new Promise((resolve) => {
617
- setTimeout(resolve, 2000);
618
- });
619
- }
620
- page++;
621
- }
622
- else {
623
- if (retryCount < maxRetries) {
624
- retryCount++;
625
- console.warn(`Empty activities returned. Retrying... (${retryCount}/${maxRetries})`);
626
- yield new Promise((resolve) => setTimeout(resolve, 3000));
627
- }
628
- else {
629
- console.log(`\nProbably the end of activities after ${maxRetries} retries.`);
630
- console.info(activities);
631
- hasMoreActivities = false;
632
- }
633
- }
634
- }
635
- }
636
- catch (error) {
637
- console.error(`\nError from likeFollowing. ${error.message}`);
638
- }
639
- });
640
- }
641
- static Like(type) {
642
- return __awaiter(this, void 0, void 0, function* () {
643
- var _a, _b, _c, _d, _e;
644
- try {
645
- let page = 1;
646
- let hasMoreActivities = true;
647
- let activity = type === 0
648
- ? followingActivitiesQuery
649
- : type === 1
650
- ? globalActivitiesQuery
651
- : followingActivitiesQuery;
652
- while (hasMoreActivities) {
653
- const activities = yield fetcher(activity, {
654
- page,
655
- perPage: 50,
656
- });
657
- if (activities && ((_b = (_a = activities === null || activities === void 0 ? void 0 : activities.data) === null || _a === void 0 ? void 0 : _a.Page) === null || _b === void 0 ? void 0 : _b.activities.length) > 0) {
658
- const activiti = (_d = (_c = activities === null || activities === void 0 ? void 0 : activities.data) === null || _c === void 0 ? void 0 : _c.Page) === null || _d === void 0 ? void 0 : _d.activities;
659
- for (let activ of activiti) {
660
- if (!activ.isLiked && activ.id) {
661
- try {
662
- const like = yield fetcher(likeActivityMutation, {
663
- activityId: activ.id,
664
- });
665
- // const ToggleLike = like?.data?.ToggleLike
666
- console.info(`[${activ.id}]\t${(_e = activ.user) === null || _e === void 0 ? void 0 : _e.name} ${(like === null || like === void 0 ? void 0 : like.data) ? "✅" : "❌"}`);
667
- }
668
- catch (error) {
669
- console.error(`Activity possibly deleted. ${error.message}`);
670
- }
671
- }
672
- else {
673
- console.log(`[${activ === null || activ === void 0 ? void 0 : activ.id}]\t${activ.user.name} already-liked`);
674
- }
675
- // avoiding rate-limit
676
- yield new Promise((resolve) => {
677
- setTimeout(resolve, 1500);
678
- });
679
- }
680
- page++;
681
- }
682
- else {
683
- // No more activities to like
684
- console.log(`\nProbably the end of activities.`);
685
- console.info(activities);
686
- hasMoreActivities = false;
687
- }
688
- }
689
- }
690
- catch (error) {
691
- console.error(`\nError from likeFollowing. ${error.message}`);
692
- }
693
- });
694
- }
695
- static LikeSpecificUser() {
696
- return __awaiter(this, void 0, void 0, function* () {
697
- var _a, _b, _c, _d, _e, _f;
698
- try {
699
- const { username } = yield inquirer.prompt([
700
- {
701
- type: "input",
702
- name: "username",
703
- message: "Username of the user:",
704
- },
705
- ]);
706
- const userDetails = yield fetcher(userQuery, { username: username });
707
- if (userDetails) {
708
- let page = 1;
709
- const perPage = 50;
710
- const userId = (_b = (_a = userDetails === null || userDetails === void 0 ? void 0 : userDetails.data) === null || _a === void 0 ? void 0 : _a.User) === null || _b === void 0 ? void 0 : _b.id;
711
- if (userId) {
712
- while (true) {
713
- const activities = yield fetcher(specificUserActivitiesQuery, {
714
- page,
715
- perPage,
716
- userId,
717
- });
718
- const activiti = (_d = (_c = activities === null || activities === void 0 ? void 0 : activities.data) === null || _c === void 0 ? void 0 : _c.Page) === null || _d === void 0 ? void 0 : _d.activities;
719
- // Break the loop if no more activities are found
720
- if (!activiti || activiti.length === 0) {
721
- console.log("No more activities found.");
722
- break;
723
- }
724
- for (let activ of activiti) {
725
- if (!activ.isLiked && activ.id) {
726
- try {
727
- const like = yield fetcher(likeActivityMutation, {
728
- activityId: activ.id,
729
- });
730
- console.info(`[${activ.id}]\t${(_e = activ.user) === null || _e === void 0 ? void 0 : _e.name} ${(like === null || like === void 0 ? void 0 : like.data) ? "✅" : "❌"}`);
731
- }
732
- catch (error) {
733
- console.error(`Activity possibly deleted. ${error.message}`);
734
- }
735
- }
736
- else {
737
- console.log(`[${activ === null || activ === void 0 ? void 0 : activ.id}]\t${(_f = activ.user) === null || _f === void 0 ? void 0 : _f.name} already-liked`);
738
- }
739
- // Avoiding rate limit
740
- yield new Promise((resolve) => {
741
- setTimeout(resolve, 1500);
742
- });
743
- }
744
- // Go to the next page
745
- page += 1;
746
- }
747
- }
748
- }
749
- }
750
- catch (error) {
751
- console.error(`\nError from LikeSpecificUser. ${error.message}`);
752
- }
753
- });
754
- }
755
- static AutoLike() {
756
- return __awaiter(this, void 0, void 0, function* () {
757
- try {
758
- if (!(yield Auth.isLoggedIn())) {
759
- console.error(`\nPlease login to use this feature.`);
760
- return;
761
- }
762
- const { activityType } = yield inquirer.prompt([
763
- {
764
- type: "list",
765
- name: "activityType",
766
- message: "Select activity type:",
767
- choices: [
768
- { name: "Following", value: 1 },
769
- { name: "Global", value: 2 },
770
- { name: "Specific User", value: 3 },
771
- ],
772
- pageSize: 10,
773
- },
774
- ]);
775
- switch (activityType) {
776
- case 1:
777
- yield this.LikeFollowing();
778
- break;
779
- case 2:
780
- yield this.Like(1);
781
- break;
782
- case 3:
783
- yield this.LikeSpecificUser();
784
- break;
785
- default:
786
- console.error(`\nInvalid choice. (${activityType})`);
787
- }
788
- }
789
- catch (error) {
790
- console.error(`\nError from autolike. ${error.message}`);
791
- }
792
- });
793
- }
794
584
  }
795
585
  export { Auth };
@@ -4,5 +4,4 @@ declare const deleteActivityMutation = "\nmutation($id: Int!) {\n DeleteActivit
4
4
  declare const saveTextActivityMutation = "\nmutation SaveTextActivity($status: String!) {\n SaveTextActivity(text: $status) { id text userId createdAt }\n}\n";
5
5
  declare const saveAnimeWithProgressMutation = "\nmutation ($mediaId: Int, $progress: Int, $status: MediaListStatus, $hiddenFromStatusLists: Boolean) {\n SaveMediaListEntry(mediaId: $mediaId, progress: $progress, status: $status, hiddenFromStatusLists: $hiddenFromStatusLists) {\n id progress hiddenFromStatusLists\n }\n}\n";
6
6
  declare const saveMangaWithProgressMutation = "\nmutation ($mediaId: Int, $progress: Int, $status: MediaListStatus, $hiddenFromStatusLists: Boolean, $private: Boolean) {\n SaveMediaListEntry( mediaId: $mediaId, progress: $progress, status: $status, hiddenFromStatusLists: $hiddenFromStatusLists, private: $private\n ) { id progress hiddenFromStatusLists private }\n}\n";
7
- declare const likeActivityMutation = "\nmutation($activityId: Int!) {\n ToggleLike(id: $activityId, type: ACTIVITY) { id }\n}\n";
8
- export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, likeActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
7
+ export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
@@ -35,9 +35,4 @@ mutation ($mediaId: Int, $progress: Int, $status: MediaListStatus, $hiddenFromSt
35
35
  ) { id progress hiddenFromStatusLists private }
36
36
  }
37
37
  `;
38
- const likeActivityMutation = `
39
- mutation($activityId: Int!) {
40
- ToggleLike(id: $activityId, type: ACTIVITY) { id }
41
- }
42
- `;
43
- export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, likeActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
38
+ export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
@@ -17,9 +17,6 @@ declare const activityMangaListQuery = "query ($userId: Int, $page: Int, $perPag
17
17
  declare const activityMessageQuery = "query ($userId: Int, $page: Int, $perPage: Int) {\n Page(page: $page, perPage: $perPage) {\n activities(userId: $userId, type: MESSAGE, sort: ID_DESC) {\n ... on MessageActivity { id type message recipient { id name } createdAt }\n }\n }\n}";
18
18
  declare const activityAllQuery = "query ($userId: Int, $page: Int, $perPage: Int) {\n Page(page: $page, perPage: $perPage) {\n activities(userId: $userId, sort: ID_DESC) {\n ... on TextActivity { id type text createdAt user { id name } }\n ... on ListActivity { id type status progress createdAt media { id title { romaji english native } } }\n ... on MessageActivity { id type message recipient { id name } createdAt }\n }\n }\n}";
19
19
  declare const activityMediaList = "query ($userId: Int, $page: Int, $perPage: Int, $type: ActivityType) {\n Page(page: $page, perPage: $perPage) {\n pageInfo { total currentPage lastPage hasNextPage perPage }\n activities(userId: $userId, type: $type, sort: ID_DESC) {\n ... on ListActivity { id type status progress media { id title { romaji english native } format } createdAt }\n }\n }\n}";
20
- declare const malIdToAnilistAnimeId = "query ($malId: Int) {\n Media(idMal: $malId, type: ANIME) { id title { romaji english } } }\n";
21
- declare const malIdToAnilistMangaId = "query ($malId: Int) {\n Media(idMal: $malId, type: MANGA) { id title { romaji english } } }\n";
22
- declare const followingActivitiesQuery = "\nquery ($page: Int, $perPage: Int) {\n Page(page: $page, perPage: $perPage) {\n activities(isFollowing: true, sort: ID_DESC) {\n ... on TextActivity { id type isLiked createdAt user { id name } }\n ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }\n ... on MessageActivity { id type isLiked message createdAt recipient { id name } }\n }\n }\n}\n";
23
- declare const globalActivitiesQuery = "\nquery ($page: Int, $perPage: Int) {\n Page(page: $page, perPage: $perPage) {\n activities(sort: ID_DESC) {\n ... on TextActivity { id type isLiked createdAt user { id name } }\n ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }\n ... on MessageActivity { id type isLiked message createdAt recipient { id name } }\n }\n }\n}\n";
24
- declare const specificUserActivitiesQuery = "\nquery ($page: Int, $perPage: Int, $userId: Int) {\n Page(page: $page, perPage: $perPage) {\n activities(userId: $userId, sort: ID_DESC) {\n ... on TextActivity { id type isLiked createdAt user { id name } }\n ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }\n ... on MessageActivity { id type isLiked message createdAt recipient { id name } }\n }\n }\n}\n";
25
- export { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, animeDetailsQuery, animeSearchQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, followingActivitiesQuery, globalActivitiesQuery, malIdToAnilistAnimeId, malIdToAnilistMangaId, mangaSearchQuery, popularQuery, specificUserActivitiesQuery, trendingQuery, upcomingAnimesQuery, userActivityQuery, userQuery, };
20
+ declare const malIdToAnilistAnimeId = "query ($malId: Int) {\n Media(idMal: $malId, type: ANIME) {\n id title { romaji english } } \n}\n";
21
+ declare const malIdToAnilistMangaId = "query ($malId: Int) {\n Media(idMal: $malId, type: MANGA) {\n id title { romaji english } } \n}\n";
22
+ export { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, animeDetailsQuery, animeSearchQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, malIdToAnilistAnimeId, malIdToAnilistMangaId, mangaSearchQuery, popularQuery, trendingQuery, upcomingAnimesQuery, userActivityQuery, userQuery, };
@@ -120,42 +120,13 @@ const activityMediaList = `query ($userId: Int, $page: Int, $perPage: Int, $type
120
120
  }
121
121
  }`;
122
122
  const malIdToAnilistAnimeId = `query ($malId: Int) {
123
- Media(idMal: $malId, type: ANIME) { id title { romaji english } } }
124
- `;
125
- const malIdToAnilistMangaId = `query ($malId: Int) {
126
- Media(idMal: $malId, type: MANGA) { id title { romaji english } } }
127
- `;
128
- const followingActivitiesQuery = `
129
- query ($page: Int, $perPage: Int) {
130
- Page(page: $page, perPage: $perPage) {
131
- activities(isFollowing: true, sort: ID_DESC) {
132
- ... on TextActivity { id type isLiked createdAt user { id name } }
133
- ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }
134
- ... on MessageActivity { id type isLiked message createdAt recipient { id name } }
135
- }
136
- }
137
- }
138
- `;
139
- const globalActivitiesQuery = `
140
- query ($page: Int, $perPage: Int) {
141
- Page(page: $page, perPage: $perPage) {
142
- activities(sort: ID_DESC) {
143
- ... on TextActivity { id type isLiked createdAt user { id name } }
144
- ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }
145
- ... on MessageActivity { id type isLiked message createdAt recipient { id name } }
146
- }
147
- }
123
+ Media(idMal: $malId, type: ANIME) {
124
+ id title { romaji english } }
148
125
  }
149
126
  `;
150
- const specificUserActivitiesQuery = `
151
- query ($page: Int, $perPage: Int, $userId: Int) {
152
- Page(page: $page, perPage: $perPage) {
153
- activities(userId: $userId, sort: ID_DESC) {
154
- ... on TextActivity { id type isLiked createdAt user { id name } }
155
- ... on ListActivity { id type isLiked status progress media { title { userPreferred } } createdAt user { id name } }
156
- ... on MessageActivity { id type isLiked message createdAt recipient { id name } }
157
- }
158
- }
127
+ const malIdToAnilistMangaId = `query ($malId: Int) {
128
+ Media(idMal: $malId, type: MANGA) {
129
+ id title { romaji english } }
159
130
  }
160
131
  `;
161
- export { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, animeDetailsQuery, animeSearchQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, followingActivitiesQuery, globalActivitiesQuery, malIdToAnilistAnimeId, malIdToAnilistMangaId, mangaSearchQuery, popularQuery, specificUserActivitiesQuery, trendingQuery, upcomingAnimesQuery, userActivityQuery, userQuery, };
132
+ export { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, animeDetailsQuery, animeSearchQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation, malIdToAnilistAnimeId, malIdToAnilistMangaId, mangaSearchQuery, popularQuery, trendingQuery, upcomingAnimesQuery, userActivityQuery, userQuery, };
package/bin/index.js CHANGED
@@ -203,11 +203,4 @@ cli
203
203
  }
204
204
  }
205
205
  }));
206
- cli
207
- .command("autolike")
208
- .alias("al")
209
- .description("Autolike following or global activities.")
210
- .action(() => __awaiter(void 0, void 0, void 0, function* () {
211
- yield Auth.AutoLike();
212
- }));
213
206
  cli.parse(process.argv);
package/package.json CHANGED
@@ -1,80 +1,80 @@
1
- {
2
- "name": "@irfanshadikrishad/anilist",
3
- "description": "Minimalist unofficial AniList CLI for Anime and Manga Enthusiasts",
4
- "author": "Irfan Shadik Rishad",
5
- "version": "1.2.1-forbidden.1",
6
- "main": "./bin/index.js",
7
- "type": "module",
8
- "types": "./bin/index.d.ts",
9
- "bin": {
10
- "anilist": "./bin/index.js"
11
- },
12
- "publishConfig": {
13
- "access": "public"
14
- },
15
- "scripts": {
16
- "build": "rm -rf ./bin && tsc",
17
- "buildw": "rm -rf ./bin && tsc -w",
18
- "format": "prettier . --write",
19
- "format:check": "prettier . --check",
20
- "lint": "eslint ./dist",
21
- "lint:fix": "eslint ./dist --fix",
22
- "all": "npm run lint && npm run lint:fix && npm run format && npm test",
23
- "test": "jest ./tests"
24
- },
25
- "keywords": [
26
- "anilist",
27
- "CLI",
28
- "anime",
29
- "manga",
30
- "anime list",
31
- "manga list",
32
- "anime tracker",
33
- "manga tracker",
34
- "anilist API",
35
- "anime progress",
36
- "manga progress",
37
- "media list",
38
- "export anime",
39
- "import anime",
40
- "export manga",
41
- "import manga",
42
- "status tracker",
43
- "watchlist",
44
- "reading list",
45
- "graphql"
46
- ],
47
- "repository": {
48
- "type": "git",
49
- "url": "https://github.com/irfanshadikrishad/anilist"
50
- },
51
- "homepage": "https://github.com/irfanshadikrishad/anilist",
52
- "bugs": {
53
- "url": "https://github.com/irfanshadikrishad/anilist/issues"
54
- },
55
- "license": "MPL-2.0",
56
- "devDependencies": {
57
- "@eslint/js": "^9.17.0",
58
- "@types/jest": "^29.5.14",
59
- "@types/json2csv": "^5.0.7",
60
- "@types/node": "^22.10.5",
61
- "eslint": "^9.17.0",
62
- "globals": "^15.14.0",
63
- "jest": "^29.7.0",
64
- "prettier": "^3.4.2",
65
- "prettier-plugin-organize-imports": "^4.1.0",
66
- "ts-jest": "^29.2.5",
67
- "ts-node": "^10.9.2",
68
- "typescript": "^5.7.2",
69
- "@babel/preset-env": "^7.26.0",
70
- "@typescript-eslint/eslint-plugin": "^8.19.0"
71
- },
72
- "dependencies": {
73
- "commander": "^13.0.0",
74
- "fast-xml-parser": "^4.5.1",
75
- "inquirer": "^12.3.0",
76
- "json2csv": "^6.0.0-alpha.2",
77
- "node-fetch": "^3.3.2",
78
- "open": "^10.1.0"
79
- }
80
- }
1
+ {
2
+ "name": "@irfanshadikrishad/anilist",
3
+ "description": "Minimalist unofficial AniList CLI for Anime and Manga Enthusiasts",
4
+ "author": "Irfan Shadik Rishad",
5
+ "version": "1.2.4",
6
+ "main": "./bin/index.js",
7
+ "type": "module",
8
+ "types": "./bin/index.d.ts",
9
+ "bin": {
10
+ "anilist": "./bin/index.js"
11
+ },
12
+ "publishConfig": {
13
+ "access": "public"
14
+ },
15
+ "scripts": {
16
+ "build": "rm -rf ./bin && tsc",
17
+ "buildw": "rm -rf ./bin && tsc -w",
18
+ "format": "prettier . --write",
19
+ "format:check": "prettier . --check",
20
+ "lint": "eslint ./dist",
21
+ "lint:fix": "eslint ./dist --fix",
22
+ "all": "npm run lint && npm run lint:fix && npm run format && npm test",
23
+ "test": "jest ./tests"
24
+ },
25
+ "keywords": [
26
+ "anilist",
27
+ "CLI",
28
+ "anime",
29
+ "manga",
30
+ "anime list",
31
+ "manga list",
32
+ "anime tracker",
33
+ "manga tracker",
34
+ "anilist API",
35
+ "anime progress",
36
+ "manga progress",
37
+ "media list",
38
+ "export anime",
39
+ "import anime",
40
+ "export manga",
41
+ "import manga",
42
+ "status tracker",
43
+ "watchlist",
44
+ "reading list",
45
+ "graphql"
46
+ ],
47
+ "repository": {
48
+ "type": "git",
49
+ "url": "https://github.com/irfanshadikrishad/anilist"
50
+ },
51
+ "homepage": "https://github.com/irfanshadikrishad/anilist",
52
+ "bugs": {
53
+ "url": "https://github.com/irfanshadikrishad/anilist/issues"
54
+ },
55
+ "license": "MPL-2.0",
56
+ "devDependencies": {
57
+ "@eslint/js": "^9.17.0",
58
+ "@types/jest": "^29.5.14",
59
+ "@types/json2csv": "^5.0.7",
60
+ "@types/node": "^22.10.5",
61
+ "eslint": "^9.17.0",
62
+ "globals": "^15.14.0",
63
+ "jest": "^29.7.0",
64
+ "prettier": "^3.4.2",
65
+ "prettier-plugin-organize-imports": "^4.1.0",
66
+ "ts-jest": "^29.2.5",
67
+ "ts-node": "^10.9.2",
68
+ "typescript": "^5.7.2",
69
+ "@babel/preset-env": "^7.26.0",
70
+ "@typescript-eslint/eslint-plugin": "^8.19.0"
71
+ },
72
+ "dependencies": {
73
+ "commander": "^13.0.0",
74
+ "fast-xml-parser": "^4.5.1",
75
+ "inquirer": "^12.3.0",
76
+ "json2csv": "^6.0.0-alpha.2",
77
+ "node-fetch": "^3.3.2",
78
+ "open": "^10.1.0"
79
+ }
80
+ }
Binary file