del-repos
Version:
A command-line tool for bulk deleting GitHub or Gitee repositories
140 lines (139 loc) • 6.54 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.promptRepositories = exports.promptToken = exports.promptPlatform = void 0;
const inquirer_1 = __importDefault(require("inquirer"));
const inquirer_search_checkbox_1 = __importDefault(require("inquirer-search-checkbox"));
const open_1 = __importDefault(require("open"));
const kolorist_1 = require("kolorist");
const config_1 = require("./config");
// 注册搜索多选框插件
inquirer_1.default.registerPrompt('search-checkbox', inquirer_search_checkbox_1.default);
const promptPlatform = () => __awaiter(void 0, void 0, void 0, function* () {
console.log((0, kolorist_1.cyan)('\n🚀 Platform Selection'));
console.log((0, kolorist_1.dim)('Choose the platform where you want to delete repositories.\n'));
const { platform } = yield inquirer_1.default.prompt([
{
type: 'list',
name: 'platform',
message: 'Choose a platform:',
choices: [
{ name: '🐙 GitHub', value: 'GitHub' },
{ name: '🦊 Gitee', value: 'Gitee' },
],
},
]);
console.log((0, kolorist_1.green)(`✅ Selected platform: ${platform}\n`));
return platform;
});
exports.promptPlatform = promptPlatform;
const promptToken = (platform) => __awaiter(void 0, void 0, void 0, function* () {
// 检查是否已存在token配置
const existingToken = (0, config_1.getToken)(platform);
if (existingToken) {
console.log((0, kolorist_1.green)(`✅ Found existing ${platform} token in config\n`));
return existingToken;
}
console.log((0, kolorist_1.cyan)('\n🔑 Token Authentication'));
console.log((0, kolorist_1.dim)('You need a personal access token to authenticate with the API.\n'));
if (platform === 'GitHub') {
console.log((0, kolorist_1.yellow)('🌐 Opening GitHub token generation page...'));
console.log((0, kolorist_1.dim)('Required scopes: delete_repo, project, repo\n'));
yield (0, open_1.default)('https://github.com/settings/tokens/new?scopes=delete_repo,project,repo&description=deleteRepos');
}
else {
console.log((0, kolorist_1.yellow)('🌐 Opening Gitee token generation page...'));
console.log((0, kolorist_1.dim)('Make sure to grant repository deletion permissions\n'));
yield (0, open_1.default)('https://gitee.com/profile/personal_access_tokens/new');
}
const { token } = yield inquirer_1.default.prompt([
{
type: 'password',
name: 'token',
message: `Please enter your ${platform} token:`,
mask: '*',
validate: input => {
if (input.trim().length === 0) {
return 'Token cannot be empty';
}
if (input.trim().length < 10) {
return 'Token seems too short, please check';
}
return true;
},
},
]);
// 询问是否保存token
const { saveTokenChoice } = yield inquirer_1.default.prompt([
{
type: 'confirm',
name: 'saveTokenChoice',
message: 'Save this token to config file for future use?',
default: true,
},
]);
if (saveTokenChoice) {
(0, config_1.saveToken)(platform, token);
console.log((0, kolorist_1.green)('💾 Token saved to config file'));
}
console.log((0, kolorist_1.green)('✅ Token received successfully\n'));
return token;
});
exports.promptToken = promptToken;
const promptRepositories = (repos) => __awaiter(void 0, void 0, void 0, function* () {
console.log((0, kolorist_1.cyan)('\n📦 Repository Selection'));
console.log((0, kolorist_1.dim)('🔍 Use search to filter repositories, Space to select/deselect, Enter to confirm.\n'));
// 为每个仓库添加序号并格式化显示,确保每个选项占一行
const formattedChoices = repos.map((repo, index) => {
const paddedIndex = String(index + 1).padStart(3, ' ');
return {
name: `${paddedIndex}. ${repo}`,
value: repo,
short: repo // 选中后显示的简短名称
};
});
const { selectedRepos } = yield inquirer_1.default.prompt([
{
type: 'search-checkbox',
name: 'selectedRepos',
message: `Search and select repositories to delete (${repos.length} total): \n`,
choices: formattedChoices,
pageSize: 20,
loop: false,
searchPlaceholder: 'Type to search repositories...',
emptyText: 'No repositories match your search',
validate: answer => {
if (answer.length === 0) {
return 'You must choose at least one repository.';
}
return true;
},
},
], {
// 设置输出流,确保正确的终端显示
output: process.stdout,
input: process.stdin
});
// 显示选择结果
if (selectedRepos.length > 0) {
console.log((0, kolorist_1.green)(`\n✅ Selected ${selectedRepos.length} repositories for deletion:`));
selectedRepos.forEach((repo, index) => {
const cleanRepoName = repo.split(' ')[0]; // 移除链接部分显示
console.log((0, kolorist_1.dim)(` ${index + 1}. ${cleanRepoName}`));
});
console.log('');
}
return selectedRepos;
});
exports.promptRepositories = promptRepositories;