feat(delete-coop): add delete count
parent
a53dc9985f
commit
52ef6863a9
|
|
@ -4,7 +4,7 @@ import { readline } from "../src/utils.ts";
|
||||||
const [key, ...params] = Deno.args;
|
const [key, ...params] = Deno.args;
|
||||||
if (!key || params.length === 0) {
|
if (!key || params.length === 0) {
|
||||||
console.log("Usage: delete-coop.ts <key> <uuid> <uuid...>");
|
console.log("Usage: delete-coop.ts <key> <uuid> <uuid...>");
|
||||||
console.log(" or: delete-coop.ts <key> @<stat.ink's id>");
|
console.log(" or: delete-coop.ts <key> @<stat.ink's id> <count>");
|
||||||
console.log(
|
console.log(
|
||||||
" You can find your id at here: https://stat.ink/@YOUR_ID_HERE",
|
" You can find your id at here: https://stat.ink/@YOUR_ID_HERE",
|
||||||
);
|
);
|
||||||
|
|
@ -12,9 +12,10 @@ if (!key || params.length === 0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
let deleted = 0;
|
let deleted = 0;
|
||||||
if (params.length === 1 && params[0].startsWith("@")) {
|
if (params.length === 2 && params[0].startsWith("@")) {
|
||||||
const [uid] = params;
|
const [uid, countStr] = params;
|
||||||
console.warn("This script will delete all your coop battles.");
|
const count = parseInt(countStr);
|
||||||
|
console.warn(`This script will delete your first ${count} coop battles.`);
|
||||||
console.warn("Are you sure? (y/N)");
|
console.warn("Are you sure? (y/N)");
|
||||||
const answer = await readline({
|
const answer = await readline({
|
||||||
skipEmpty: false,
|
skipEmpty: false,
|
||||||
|
|
@ -27,13 +28,14 @@ if (params.length === 1 && params[0].startsWith("@")) {
|
||||||
const res = await (await fetch(`https://stat.ink/${uid}/salmon3`)).text();
|
const res = await (await fetch(`https://stat.ink/${uid}/salmon3`)).text();
|
||||||
const re = /href="\/@\w+\/salmon3\/([0-9a-fA-F-]{36})/g;
|
const re = /href="\/@\w+\/salmon3\/([0-9a-fA-F-]{36})/g;
|
||||||
const matches = [...res.matchAll(re)].map((m) => m[1]);
|
const matches = [...res.matchAll(re)].map((m) => m[1]);
|
||||||
|
const toDelete = matches.slice(0, count - deleted);
|
||||||
|
|
||||||
if (matches.length === 0) {
|
if (toDelete.length === 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
await deleteUuids(matches);
|
await deleteUuids(toDelete);
|
||||||
deleted += matches.length;
|
deleted += toDelete.length;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
await deleteUuids(params);
|
await deleteUuids(params);
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue