@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.
- package/{LICENSE.md → LICENSE} +115 -124
- package/README.md +0 -5
- package/bin/helpers/auth.d.ts +0 -4
- package/bin/helpers/auth.js +26 -236
- package/bin/helpers/mutations.d.ts +1 -2
- package/bin/helpers/mutations.js +1 -6
- package/bin/helpers/queries.d.ts +3 -6
- package/bin/helpers/queries.js +6 -35
- package/bin/index.js +0 -7
- package/package.json +80 -80
- package/assets/binance.jpg +0 -0
package/{LICENSE.md → LICENSE}
RENAMED
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
|
|
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
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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 💙_**
|
package/bin/helpers/auth.d.ts
CHANGED
|
@@ -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 };
|
package/bin/helpers/auth.js
CHANGED
|
@@ -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,
|
|
19
|
-
import { activityAllQuery, activityAnimeListQuery, activityMangaListQuery, activityMediaList, activityMessageQuery, activityTextQuery, currentUserAnimeList, currentUserMangaList, currentUserQuery, deleteMangaEntryMutation, deleteMediaEntryMutation,
|
|
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
|
-
|
|
8
|
-
export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, likeActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
|
|
7
|
+
export { addAnimeToListMutation, addMangaToListMutation, deleteActivityMutation, saveAnimeWithProgressMutation, saveMangaWithProgressMutation, saveTextActivityMutation, };
|
package/bin/helpers/mutations.js
CHANGED
|
@@ -35,9 +35,4 @@ mutation ($mediaId: Int, $progress: Int, $status: MediaListStatus, $hiddenFromSt
|
|
|
35
35
|
) { id progress hiddenFromStatusLists private }
|
|
36
36
|
}
|
|
37
37
|
`;
|
|
38
|
-
|
|
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, };
|
package/bin/helpers/queries.d.ts
CHANGED
|
@@ -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) {
|
|
21
|
-
declare const malIdToAnilistMangaId = "query ($malId: Int) {\n Media(idMal: $malId, type: MANGA) {
|
|
22
|
-
|
|
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, };
|
package/bin/helpers/queries.js
CHANGED
|
@@ -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) {
|
|
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
|
|
151
|
-
|
|
152
|
-
|
|
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,
|
|
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.
|
|
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
|
+
}
|
package/assets/binance.jpg
DELETED
|
Binary file
|