UNPKG

del-repos

Version:

A command-line tool for bulk deleting GitHub or Gitee repositories

140 lines (139 loc) 6.54 kB
"use strict"; 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;