gitverse-release 3.5.0 → 3.6.0

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/dist/types.d.ts CHANGED
@@ -30,6 +30,10 @@ export interface ReleaseConfig {
30
30
  * Настройки генерации commitlint конфига
31
31
  */
32
32
  commitlint?: CommitlintGeneratorConfig;
33
+ /**
34
+ * Настройки бинарной дистрибуции
35
+ */
36
+ binaries?: BinariesConfig;
33
37
  }
34
38
  /**
35
39
  * Конфигурация monorepo
@@ -576,3 +580,207 @@ export interface GenerateCommitlintOptions {
576
580
  */
577
581
  verbose?: boolean;
578
582
  }
583
+ /**
584
+ * Поддерживаемые платформы для бинарной дистрибуции
585
+ */
586
+ export type BinaryPlatform = "linux-x64" | "linux-arm64" | "darwin-x64" | "darwin-arm64" | "win32-x64" | "win32-arm64";
587
+ /**
588
+ * Допустимые значения для поля os в package.json
589
+ */
590
+ export type NpmOS = "linux" | "darwin" | "win32" | "freebsd" | "openbsd" | "sunos" | "aix";
591
+ /**
592
+ * Допустимые значения для поля cpu в package.json
593
+ */
594
+ export type NpmCPU = "x64" | "arm64" | "ia32" | "arm" | "mips" | "ppc64";
595
+ /**
596
+ * Расширение исполняемого файла
597
+ */
598
+ export type BinaryExtension = "" | ".exe";
599
+ /**
600
+ * npm scope в формате @org
601
+ */
602
+ export type NpmScope = `@${string}`;
603
+ /**
604
+ * Маппинг платформы на os/cpu значения для package.json
605
+ */
606
+ export interface PlatformMapping {
607
+ /** Значение для поля os в package.json */
608
+ os: NpmOS;
609
+ /** Значение для поля cpu в package.json */
610
+ cpu: NpmCPU;
611
+ /** Расширение исполняемого файла */
612
+ extension: BinaryExtension;
613
+ }
614
+ /**
615
+ * Конфигурация бинарной дистрибуции
616
+ */
617
+ export interface BinariesConfig {
618
+ /**
619
+ * Включить бинарную дистрибуцию
620
+ * @default false
621
+ */
622
+ enabled: boolean;
623
+ /**
624
+ * npm scope (например: @rainypixel)
625
+ */
626
+ scope: string;
627
+ /**
628
+ * Базовое имя пакетов (например: yougile)
629
+ */
630
+ name: string;
631
+ /**
632
+ * Имя бинарника в $PATH
633
+ * @default значение name
634
+ */
635
+ binName?: string;
636
+ /**
637
+ * Директория с бинарниками (dist/yougile-linux-x64, etc.)
638
+ * @default "./dist"
639
+ */
640
+ distDir: string;
641
+ /**
642
+ * Директория для генерации пакетов
643
+ * @default "./npm"
644
+ */
645
+ outDir: string;
646
+ /**
647
+ * Список платформ для публикации
648
+ * @default ["linux-x64", "linux-arm64", "darwin-x64", "darwin-arm64", "win32-x64"]
649
+ */
650
+ platforms: BinaryPlatform[];
651
+ /**
652
+ * Команда для публикации пакетов
653
+ * Поддерживает плейсхолдеры: {{packageDir}}, {{version}}, {{platform}}
654
+ * @default "npm publish --access public"
655
+ */
656
+ publishCommand: string;
657
+ /**
658
+ * Путь к основному package.json для обновления optionalDependencies
659
+ * @default "./package.json"
660
+ */
661
+ mainPackage: string;
662
+ /**
663
+ * Продолжать при ошибке публикации отдельной платформы
664
+ * @default false
665
+ */
666
+ continueOnError: boolean;
667
+ /**
668
+ * Количество попыток retry при ошибке публикации
669
+ * @default 3
670
+ */
671
+ retryAttempts: number;
672
+ }
673
+ /**
674
+ * Успешный результат генерации платформенного пакета
675
+ */
676
+ export interface BinaryPackageSuccess {
677
+ /** Платформа */
678
+ platform: BinaryPlatform;
679
+ /** Путь к сгенерированному пакету */
680
+ packageDir: string;
681
+ /** Полное имя пакета (например: @rainypixel/yougile-linux-x64) */
682
+ packageName: string;
683
+ /** Успешно сгенерирован */
684
+ success: true;
685
+ }
686
+ /**
687
+ * Неуспешный результат генерации платформенного пакета
688
+ */
689
+ export interface BinaryPackageFailure {
690
+ /** Платформа */
691
+ platform: BinaryPlatform;
692
+ /** Путь к сгенерированному пакету (может отсутствовать при ошибке) */
693
+ packageDir: string;
694
+ /** Полное имя пакета */
695
+ packageName: string;
696
+ /** Не удалось сгенерировать */
697
+ success: false;
698
+ /** Сообщение об ошибке */
699
+ error: string;
700
+ }
701
+ /**
702
+ * Результат генерации платформенного пакета (discriminated union)
703
+ */
704
+ export type BinaryPackageResult = BinaryPackageSuccess | BinaryPackageFailure;
705
+ /**
706
+ * Успешный результат публикации платформенного пакета
707
+ */
708
+ export interface BinaryPublishSuccess {
709
+ /** Платформа */
710
+ platform: BinaryPlatform;
711
+ /** Полное имя пакета */
712
+ packageName: string;
713
+ /** Успешно опубликован */
714
+ success: true;
715
+ /** Количество попыток */
716
+ attempts: number;
717
+ }
718
+ /**
719
+ * Неуспешный результат публикации платформенного пакета
720
+ */
721
+ export interface BinaryPublishFailure {
722
+ /** Платформа */
723
+ platform: BinaryPlatform;
724
+ /** Полное имя пакета */
725
+ packageName: string;
726
+ /** Не удалось опубликовать */
727
+ success: false;
728
+ /** Сообщение об ошибке */
729
+ error: string;
730
+ /** Количество попыток */
731
+ attempts: number;
732
+ }
733
+ /**
734
+ * Результат публикации платформенного пакета (discriminated union)
735
+ */
736
+ export type BinaryPublishResult = BinaryPublishSuccess | BinaryPublishFailure;
737
+ /**
738
+ * Общий результат бинарной дистрибуции
739
+ */
740
+ export interface BinaryDistributionResult {
741
+ /** Успешно ли выполнена операция */
742
+ success: boolean;
743
+ /** Версия */
744
+ version: string;
745
+ /** Результаты генерации пакетов */
746
+ packages: BinaryPackageResult[];
747
+ /** Результаты публикации */
748
+ published: BinaryPublishResult[];
749
+ /** Ошибки */
750
+ errors: string[];
751
+ /** Предупреждения */
752
+ warnings: string[];
753
+ }
754
+ /**
755
+ * CLI опции для бинарной дистрибуции
756
+ */
757
+ export interface BinaryCliOptions {
758
+ /**
759
+ * Тестовый прогон (не публиковать)
760
+ */
761
+ dryRun?: boolean;
762
+ /**
763
+ * Путь к конфиг файлу
764
+ */
765
+ config?: string;
766
+ /**
767
+ * Override версии
768
+ */
769
+ version?: string;
770
+ /**
771
+ * Только генерация пакетов (без публикации)
772
+ */
773
+ generateOnly?: boolean;
774
+ /**
775
+ * Не обновлять основной package.json
776
+ */
777
+ skipMainPackage?: boolean;
778
+ /**
779
+ * Конкретные платформы для обработки
780
+ */
781
+ platforms?: BinaryPlatform[];
782
+ /**
783
+ * Подробный вывод
784
+ */
785
+ verbose?: boolean;
786
+ }
@@ -0,0 +1,21 @@
1
+ import type { BinariesConfig, BinaryPackageResult, BinaryPlatform } from "../types";
2
+ /**
3
+ * Генерирует package.json для платформенного пакета
4
+ */
5
+ export declare function generatePlatformPackageJson(config: BinariesConfig, platform: BinaryPlatform, version: string): string;
6
+ /**
7
+ * Генерирует README.md для платформенного пакета
8
+ */
9
+ export declare function generatePlatformReadme(config: BinariesConfig, platform: BinaryPlatform, version: string): string;
10
+ /**
11
+ * Генерирует платформенный пакет
12
+ */
13
+ export declare function generatePlatformPackage(config: BinariesConfig, platform: BinaryPlatform, version: string, dryRun?: boolean): Promise<BinaryPackageResult>;
14
+ /**
15
+ * Генерирует все платформенные пакеты
16
+ */
17
+ export declare function generateAllPlatformPackages(config: BinariesConfig, version: string, platforms?: BinaryPlatform[], dryRun?: boolean): Promise<BinaryPackageResult[]>;
18
+ /**
19
+ * Печатает информацию о генерации в dry-run режиме
20
+ */
21
+ export declare function printGenerationDryRun(config: BinariesConfig, version: string, platforms: BinaryPlatform[]): void;
@@ -0,0 +1,62 @@
1
+ import type { BinaryPlatform, PlatformMapping } from "../types";
2
+ /**
3
+ * Маппинг платформ на os/cpu значения для package.json
4
+ */
5
+ export declare const PLATFORM_MAPPINGS: Record<BinaryPlatform, PlatformMapping>;
6
+ /**
7
+ * Все поддерживаемые платформы
8
+ */
9
+ export declare const ALL_PLATFORMS: BinaryPlatform[];
10
+ /**
11
+ * Проверяет, что строка является валидной платформой
12
+ */
13
+ export declare function isValidPlatform(value: string): value is BinaryPlatform;
14
+ /**
15
+ * Парсит список платформ из строки (comma-separated)
16
+ */
17
+ export declare function parsePlatforms(value: string): BinaryPlatform[];
18
+ /**
19
+ * Возвращает путь к бинарнику для указанной платформы
20
+ */
21
+ export declare function getBinaryPath(distDir: string, name: string, platform: BinaryPlatform): string;
22
+ /**
23
+ * Возвращает путь к директории платформы
24
+ */
25
+ export declare function getPlatformDir(distDir: string, name: string, platform: BinaryPlatform): string;
26
+ /**
27
+ * Проверяет существование бинарника для платформы.
28
+ *
29
+ * @returns true если файл существует, false если файл не найден (ENOENT)
30
+ * @throws Error при других ошибках доступа (EACCES, ELOOP, EIO и т.д.)
31
+ */
32
+ export declare function validateBinaryExists(distDir: string, name: string, platform: BinaryPlatform): Promise<boolean>;
33
+ /**
34
+ * Валидирует наличие бинарников для всех указанных платформ
35
+ * @returns Массив отсутствующих платформ
36
+ */
37
+ export declare function validateAllBinaries(distDir: string, name: string, platforms: BinaryPlatform[]): Promise<BinaryPlatform[]>;
38
+ /**
39
+ * Генерирует полное имя пакета для платформы
40
+ */
41
+ export declare function getPackageName(scope: string, name: string, platform: BinaryPlatform): string;
42
+ /**
43
+ * Генерирует путь к пакету в output директории
44
+ */
45
+ export declare function getPackageOutputPath(outDir: string, scope: string, name: string, platform: BinaryPlatform): string;
46
+ /**
47
+ * Раскрывает плейсхолдеры в строке
48
+ */
49
+ export declare function expandPlaceholders(template: string, values: {
50
+ packageDir?: string;
51
+ version?: string;
52
+ platform?: string;
53
+ scope?: string;
54
+ name?: string;
55
+ }): string;
56
+ /**
57
+ * Конвертирует платформу в Node.js process.platform и process.arch
58
+ */
59
+ export declare function platformToNodeValues(platform: BinaryPlatform): {
60
+ platform: string;
61
+ arch: string;
62
+ };
@@ -0,0 +1,53 @@
1
+ import type { BinariesConfig, BinaryPackageResult, BinaryPlatform, BinaryPublishResult } from "../types";
2
+ /**
3
+ * Вычисляет задержку с экспоненциальным backoff.
4
+ *
5
+ * Формула: delay = initialDelay * 2^attempt, ограничено maxDelay.
6
+ *
7
+ * Примеры (с дефолтными параметрами):
8
+ * - attempt 0: 2000ms
9
+ * - attempt 1: 4000ms
10
+ * - attempt 2: 8000ms
11
+ * - attempt 3: 16000ms
12
+ * - attempt 4+: 30000ms (max)
13
+ *
14
+ * @param attempt - Номер попытки (начиная с 0)
15
+ * @param initialDelay - Начальная задержка в мс (default: 2000)
16
+ * @param maxDelay - Максимальная задержка в мс (default: 30000)
17
+ * @returns Задержка в миллисекундах
18
+ */
19
+ export declare function calculateDelay(attempt: number, initialDelay?: number, maxDelay?: number): number;
20
+ /**
21
+ * Проверяет, можно ли повторить операцию после ошибки.
22
+ *
23
+ * Retriable ошибки (временные, имеет смысл повторить):
24
+ * - Сетевые ошибки: network timeout, ECONNRESET, ETIMEDOUT
25
+ * - Ограничения rate limit: HTTP 429, HTTP 503
26
+ * - Временные ошибки npm registry: registry unavailable, ETARGET
27
+ *
28
+ * Не-retriable ошибки (постоянные, повторять бессмысленно):
29
+ * - Ошибки авторизации (401, 403)
30
+ * - Невалидные данные (400)
31
+ * - Пакет уже существует (409)
32
+ * - Ошибки файловой системы
33
+ *
34
+ * @param error - Любое значение ошибки
35
+ * @returns true если ошибка носит временный характер и retry может помочь
36
+ */
37
+ export declare function isRetriableError(error: unknown): boolean;
38
+ /**
39
+ * Публикует один платформенный пакет
40
+ */
41
+ export declare function publishPlatformPackage(config: BinariesConfig, platform: BinaryPlatform, version: string, dryRun?: boolean): Promise<BinaryPublishResult>;
42
+ /**
43
+ * Публикует все платформенные пакеты
44
+ */
45
+ export declare function publishAllPlatformPackages(config: BinariesConfig, version: string, generatedPackages: BinaryPackageResult[], dryRun?: boolean, verbose?: boolean): Promise<BinaryPublishResult[]>;
46
+ /**
47
+ * Печатает информацию о публикации в dry-run режиме
48
+ */
49
+ export declare function printPublishDryRun(config: BinariesConfig, generatedPackages: BinaryPackageResult[]): void;
50
+ /**
51
+ * Печатает итоговую статистику публикации
52
+ */
53
+ export declare function printPublishSummary(results: BinaryPublishResult[], _config: BinariesConfig): void;
@@ -0,0 +1,34 @@
1
+ import type { BinariesConfig, BinaryPlatform } from "../types";
2
+ /**
3
+ * Генерирует JS wrapper скрипт для bin/
4
+ */
5
+ export declare function generateBinaryWrapper(config: BinariesConfig): string;
6
+ /**
7
+ * Интерфейс для optionalDependencies
8
+ */
9
+ export interface OptionalDependencies {
10
+ [key: string]: string;
11
+ }
12
+ /**
13
+ * Генерирует объект optionalDependencies для основного package.json
14
+ */
15
+ export declare function generateOptionalDependencies(config: BinariesConfig, version: string, platforms?: BinaryPlatform[]): OptionalDependencies;
16
+ /**
17
+ * Обновления для основного package.json
18
+ */
19
+ export interface MainPackageUpdates {
20
+ optionalDependencies: OptionalDependencies;
21
+ bin?: Record<string, string>;
22
+ }
23
+ /**
24
+ * Генерирует обновления для основного package.json
25
+ */
26
+ export declare function generateMainPackageUpdates(config: BinariesConfig, version: string, platforms?: BinaryPlatform[]): MainPackageUpdates;
27
+ /**
28
+ * Обновляет основной package.json с optionalDependencies
29
+ */
30
+ export declare function updateMainPackageJson(packagePath: string, config: BinariesConfig, version: string, platforms?: BinaryPlatform[], dryRun?: boolean): Promise<void>;
31
+ /**
32
+ * Печатает информацию об обновлениях main package в dry-run режиме
33
+ */
34
+ export declare function printMainPackageUpdatesDryRun(config: BinariesConfig, version: string, platforms?: BinaryPlatform[]): void;
@@ -9,6 +9,11 @@ export declare function executeCommand(command: string): Promise<string>;
9
9
  * Возвращает false если хук упал с ошибкой
10
10
  */
11
11
  export declare function runBeforeCommitHook(command: string): Promise<boolean>;
12
+ /**
13
+ * Выполняет git команду
14
+ * Экспортируется для тестирования (позволяет мокать через spyOn)
15
+ */
16
+ export declare function gitCommand(command: string): Promise<string>;
12
17
  /**
13
18
  * Получает информацию о Git репозитории
14
19
  *
@@ -69,6 +74,9 @@ export declare function isWorkingTreeClean(): Promise<boolean>;
69
74
  */
70
75
  export declare function addChangedFiles(): Promise<void>;
71
76
  /**
72
- * Проверяет, что тег существует
77
+ * Проверяет, что тег существует.
78
+ *
79
+ * @returns true если тег существует, false если тег не найден
80
+ * @throws Error при критических ошибках git (повреждённый репозиторий, git не найден)
73
81
  */
74
82
  export declare function tagExists(tag: string): Promise<boolean>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "gitverse-release",
3
- "version": "3.5.0",
3
+ "version": "3.6.0",
4
4
  "description": "Conventional Commits release automation tool for GitVerse",
5
5
  "keywords": [
6
6
  "gitverse",
@@ -47,11 +47,11 @@
47
47
  "typecheck": "tsc --noEmit"
48
48
  },
49
49
  "dependencies": {
50
- "gitverse-api-sdk": "4.0.2"
50
+ "gitverse-api-sdk": "5.2.0",
51
+ "jsonc-parser": "^3.3.1"
51
52
  },
52
53
  "devDependencies": {
53
54
  "@types/bun": "1.3.6",
54
- "bun-plugin-dts": "^0.3.0",
55
55
  "typescript": "^5.9.3"
56
56
  },
57
57
  "publishConfig": {
package/schema.json CHANGED
@@ -3,6 +3,87 @@
3
3
  "additionalProperties": false,
4
4
  "description": "Configuration file for gitverse-release tool",
5
5
  "properties": {
6
+ "$schema": {
7
+ "description": "JSON Schema reference for IDE support",
8
+ "type": "string"
9
+ },
10
+ "binaries": {
11
+ "default": {
12
+ "continueOnError": false,
13
+ "distDir": "./dist",
14
+ "enabled": false,
15
+ "mainPackage": "./package.json",
16
+ "name": "",
17
+ "outDir": "./npm",
18
+ "platforms": ["linux-x64", "linux-arm64", "darwin-x64", "darwin-arm64", "win32-x64"],
19
+ "publishCommand": "npm publish --access public",
20
+ "retryAttempts": 3,
21
+ "scope": ""
22
+ },
23
+ "description": "Binary distribution settings for publishing platform-specific npm packages",
24
+ "properties": {
25
+ "binName": {
26
+ "description": "Binary name in $PATH. Defaults to 'name' value",
27
+ "type": "string"
28
+ },
29
+ "continueOnError": {
30
+ "default": false,
31
+ "description": "Continue publishing remaining packages if one fails",
32
+ "type": "boolean"
33
+ },
34
+ "distDir": {
35
+ "default": "./dist",
36
+ "description": "Directory containing platform-specific binaries (e.g., dist/yougile-linux-x64/yougile)",
37
+ "type": "string"
38
+ },
39
+ "enabled": {
40
+ "default": false,
41
+ "description": "Enable binary distribution",
42
+ "type": "boolean"
43
+ },
44
+ "mainPackage": {
45
+ "default": "./package.json",
46
+ "description": "Path to main package.json for updating optionalDependencies",
47
+ "type": "string"
48
+ },
49
+ "name": {
50
+ "description": "Base name for packages (e.g., 'yougile' creates @scope/yougile-linux-x64)",
51
+ "type": "string"
52
+ },
53
+ "outDir": {
54
+ "default": "./npm",
55
+ "description": "Output directory for generated npm packages",
56
+ "type": "string"
57
+ },
58
+ "platforms": {
59
+ "default": ["linux-x64", "linux-arm64", "darwin-x64", "darwin-arm64", "win32-x64"],
60
+ "description": "Platforms to publish",
61
+ "items": {
62
+ "enum": ["linux-x64", "linux-arm64", "darwin-x64", "darwin-arm64", "win32-x64", "win32-arm64"],
63
+ "type": "string"
64
+ },
65
+ "type": "array",
66
+ "uniqueItems": true
67
+ },
68
+ "publishCommand": {
69
+ "default": "npm publish --access public",
70
+ "description": "Command to publish packages. Supports placeholders: {{packageDir}}, {{version}}, {{platform}}, {{scope}}, {{name}}",
71
+ "type": "string"
72
+ },
73
+ "retryAttempts": {
74
+ "default": 3,
75
+ "description": "Number of retry attempts for publish command",
76
+ "maximum": 10,
77
+ "minimum": 1,
78
+ "type": "integer"
79
+ },
80
+ "scope": {
81
+ "description": "npm scope for platform packages (e.g., '@rainypixel')",
82
+ "type": "string"
83
+ }
84
+ },
85
+ "type": "object"
86
+ },
6
87
  "changelog": {
7
88
  "default": {
8
89
  "showAuthor": true,