diff --git a/.claude/skills/db-create/SKILL.md b/.claude/skills/db-create/SKILL.md new file mode 100644 index 00000000..e6aad2af --- /dev/null +++ b/.claude/skills/db-create/SKILL.md @@ -0,0 +1,81 @@ +--- +name: db-create +description: Создание информационной базы 1С. Используй когда пользователь просит создать базу, новую ИБ, пустую базу +argument-hint: +allowed-tools: + - Bash + - Read + - Write + - Glob + - AskUserQuestion +--- + +# /db-create — Создание информационной базы + +Создаёт новую информационную базу 1С (файловую или серверную) и предлагает зарегистрировать в `.v8-project.json`. + +## Usage + +``` +/db-create — файловая база по указанному пути +/db-create / — серверная база +/db-create — интерактивно +``` + +## Разрешение параметров + +1. Прочитай `.v8-project.json` для получения `v8path` (если есть) +2. Если `v8path` не задан — автоопределение платформы: + ```powershell + $v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + ``` + +## Команды + +### Файловая база + +```cmd +"\1cv8.exe" CREATEINFOBASE File="<путь>" /DisableStartupDialogs /Out "<лог>" +``` + +### Серверная база + +```cmd +"\1cv8.exe" CREATEINFOBASE Srvr="<сервер>";Ref="<имя>" /DisableStartupDialogs /Out "<лог>" +``` + +### Параметры + +| Параметр | Описание | +|----------|----------| +| `File="<путь>"` | Строка соединения для файловой базы | +| `Srvr="<сервер>";Ref="<имя>"` | Строка соединения для серверной базы | +| `/AddToList [<имя>]` | Добавить в список баз 1С (необязательно) | +| `/UseTemplate <файл>` | Создать из шаблона (.cf или .dt) | +| `/DisableStartupDialogs` | Подавить диалоги | +| `/Out <файл>` | Лог-файл | + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## После создания + +1. Прочитай лог-файл и покажи результат +2. Предложи зарегистрировать базу в `.v8-project.json` (через `/db-list add`) +3. Если указан шаблон `/UseTemplate` — предупреди что конфигурация будет загружена из шаблона + +## Пример + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + +# Создать файловую базу +& $v8.FullName CREATEINFOBASE File="C:\Bases\NewDB" /DisableStartupDialogs /Out "create.log" + +# Создать из шаблона CF +& $v8.FullName CREATEINFOBASE File="C:\Bases\NewDB" /UseTemplate "C:\Templates\config.cf" /DisableStartupDialogs /Out "create.log" +``` diff --git a/.claude/skills/db-dump-cf/SKILL.md b/.claude/skills/db-dump-cf/SKILL.md new file mode 100644 index 00000000..de7ce9b1 --- /dev/null +++ b/.claude/skills/db-dump-cf/SKILL.md @@ -0,0 +1,73 @@ +--- +name: db-dump-cf +description: Выгрузка конфигурации 1С в CF-файл. Используй когда пользователь просит выгрузить конфигурацию в CF, сохранить конфигурацию, сделать бэкап CF +argument-hint: [database] [output.cf] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-dump-cf — Выгрузка конфигурации в CF-файл + +Выгружает конфигурацию информационной базы в бинарный CF-файл. + +## Usage + +``` +/db-dump-cf [database] [output.cf] +/db-dump-cf dev config.cf +/db-dump-cf — база по умолчанию, файл config.cf +``` + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```cmd +"\1cv8.exe" DESIGNER /F "<база>" /N"" /P"" /DumpCfg "<файл.cf>" /DisableStartupDialogs /Out "<лог>" +``` + +Для серверной базы вместо `/F` используй `/S`: +```cmd +"\1cv8.exe" DESIGNER /S "/" /N"" /P"" /DumpCfg "<файл.cf>" /DisableStartupDialogs /Out "<лог>" +``` + +### Параметры + +| Параметр | Описание | +|----------|----------| +| `/DumpCfg <файл>` | Путь к выходному CF-файлу | +| `-Extension <имя>` | Выгрузить расширение (вместо основной конфигурации) | +| `-AllExtensions` | Выгрузить все расширения (архив расширений) | + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## После выполнения + +Прочитай лог-файл и покажи результат. Если есть ошибки — покажи содержимое лога. + +## Пример + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + +& $v8.FullName DESIGNER /F "C:\Bases\MyDB" /N"Admin" /P"" /DumpCfg "C:\backup\config.cf" /DisableStartupDialogs /Out "dump.log" +``` diff --git a/.claude/skills/db-dump-xml/SKILL.md b/.claude/skills/db-dump-xml/SKILL.md new file mode 100644 index 00000000..b21aa85c --- /dev/null +++ b/.claude/skills/db-dump-xml/SKILL.md @@ -0,0 +1,95 @@ +--- +name: db-dump-xml +description: Выгрузка конфигурации 1С в XML-файлы. Используй когда пользователь просит выгрузить конфигурацию в файлы, XML, исходники, DumpConfigToFiles +argument-hint: [database] [outputDir] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-dump-xml — Выгрузка конфигурации в XML + +Выгружает конфигурацию информационной базы в XML-файлы (исходники). Поддерживает полную, инкрементальную, частичную выгрузку и обновление ConfigDumpInfo. + +## Usage + +``` +/db-dump-xml [database] [outputDir] +/db-dump-xml dev src/config +/db-dump-xml dev src/config -Mode Full +/db-dump-xml dev src/config -Mode Partial -Objects "Справочник.Номенклатура,Документ.Заказ" +``` + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Если в записи базы указан `configSrc` — используй его как каталог выгрузки по умолчанию. + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```powershell +powershell.exe -NoProfile -File .claude\skills\db-dump-xml\scripts\db-dump-xml.ps1 <параметры> +``` + +### Параметры скрипта + +| Параметр | Обязательный | Описание | +|----------|:------------:|----------| +| `-V8Path <путь>` | нет | Каталог bin платформы (или полный путь к 1cv8.exe) | +| `-InfoBasePath <путь>` | * | Файловая база | +| `-InfoBaseServer <сервер>` | * | Сервер 1С (для серверной базы) | +| `-InfoBaseRef <имя>` | * | Имя базы на сервере | +| `-UserName <имя>` | нет | Имя пользователя | +| `-Password <пароль>` | нет | Пароль | +| `-ConfigDir <путь>` | да | Каталог для выгрузки | +| `-Mode <режим>` | нет | `Full` / `Changes` (по умолч.) / `Partial` / `UpdateInfo` | +| `-Objects <список>` | для Partial | Имена объектов через запятую | +| `-Extension <имя>` | нет | Выгрузить расширение | +| `-AllExtensions` | нет | Выгрузить все расширения | +| `-Format <формат>` | нет | `Hierarchical` (по умолч.) / `Plain` | + +> `*` — нужен либо `-InfoBasePath`, либо пара `-InfoBaseServer` + `-InfoBaseRef` + +### Режимы выгрузки + +| Режим | Описание | +|-------|----------| +| `Full` | Полная выгрузка — все объекты конфигурации | +| `Changes` | Инкрементальная — только изменённые с последней выгрузки (использует ConfigDumpInfo.xml) | +| `Partial` | Частичная — выбранные объекты из параметра `-Objects` | +| `UpdateInfo` | Обновить только ConfigDumpInfo.xml без выгрузки файлов | + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## Примеры + +```powershell +# Полная выгрузка +powershell.exe -NoProfile -File .claude\skills\db-dump-xml\scripts\db-dump-xml.ps1 -V8Path "C:\Program Files\1cv8\8.3.25.1257\bin" -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -Password "" -ConfigDir "C:\WS\cfsrc" -Mode Full + +# Инкрементальная выгрузка +powershell.exe -NoProfile -File .claude\skills\db-dump-xml\scripts\db-dump-xml.ps1 -V8Path "C:\Program Files\1cv8\8.3.25.1257\bin" -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Mode Changes + +# Частичная выгрузка +powershell.exe -NoProfile -File .claude\skills\db-dump-xml\scripts\db-dump-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Mode Partial -Objects "Справочник.Номенклатура,Документ.Заказ" + +# Выгрузка расширения +powershell.exe -NoProfile -File .claude\skills\db-dump-xml\scripts\db-dump-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\ext_src" -Mode Full -Extension "МоёРасширение" +``` diff --git a/.claude/skills/db-dump-xml/scripts/db-dump-xml.ps1 b/.claude/skills/db-dump-xml/scripts/db-dump-xml.ps1 new file mode 100644 index 00000000..8bc46360 --- /dev/null +++ b/.claude/skills/db-dump-xml/scripts/db-dump-xml.ps1 @@ -0,0 +1,224 @@ +# db-dump-xml v1.0 — Dump 1C configuration to XML files +# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills +<# +.SYNOPSIS + Выгрузка конфигурации 1С в XML-файлы + +.DESCRIPTION + Выполняет выгрузку конфигурации 1С в файлы в четырёх режимах: + - Full: полная выгрузка всей конфигурации + - Changes: инкрементальная выгрузка изменённых объектов + - Partial: выгрузка конкретных объектов из списка + - UpdateInfo: обновление только ConfigDumpInfo.xml + +.PARAMETER V8Path + Путь к каталогу bin платформы или к 1cv8.exe + +.PARAMETER InfoBasePath + Путь к файловой информационной базе + +.PARAMETER InfoBaseServer + Сервер 1С (для серверной базы) + +.PARAMETER InfoBaseRef + Имя базы на сервере + +.PARAMETER UserName + Имя пользователя 1С + +.PARAMETER Password + Пароль пользователя + +.PARAMETER ConfigDir + Каталог для выгрузки конфигурации + +.PARAMETER Mode + Режим выгрузки: Full, Changes, Partial, UpdateInfo (по умолчанию Changes) + +.PARAMETER Objects + Имена объектов метаданных через запятую (для режима Partial) + +.PARAMETER Extension + Имя расширения для выгрузки + +.PARAMETER AllExtensions + Выгрузить все расширения + +.PARAMETER Format + Формат выгрузки: Hierarchical или Plain (по умолчанию Hierarchical) + +.EXAMPLE + .\db-dump-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Mode Full + +.EXAMPLE + .\db-dump-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Mode Partial -Objects "Справочник.Номенклатура,Документ.Заказ" +#> + +[CmdletBinding()] +param( + [Parameter(Mandatory=$false)] + [string]$V8Path, + + [Parameter(Mandatory=$false)] + [string]$InfoBasePath, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseServer, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseRef, + + [Parameter(Mandatory=$false)] + [string]$UserName, + + [Parameter(Mandatory=$false)] + [string]$Password, + + [Parameter(Mandatory=$true)] + [string]$ConfigDir, + + [Parameter(Mandatory=$false)] + [ValidateSet("Full", "Changes", "Partial", "UpdateInfo")] + [string]$Mode = "Changes", + + [Parameter(Mandatory=$false)] + [string]$Objects, + + [Parameter(Mandatory=$false)] + [string]$Extension, + + [Parameter(Mandatory=$false)] + [switch]$AllExtensions, + + [Parameter(Mandatory=$false)] + [ValidateSet("Hierarchical", "Plain")] + [string]$Format = "Hierarchical" +) + +$OutputEncoding = [System.Text.Encoding]::UTF8 +[Console]::OutputEncoding = [System.Text.Encoding]::UTF8 + +# --- Resolve V8Path --- +if (-not $V8Path) { + $found = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" -ErrorAction SilentlyContinue | Sort-Object FullName -Descending | Select-Object -First 1 + if ($found) { + $V8Path = $found.FullName + } else { + Write-Host "Error: 1cv8.exe not found. Specify -V8Path" -ForegroundColor Red + exit 1 + } +} elseif (Test-Path $V8Path -PathType Container) { + $V8Path = Join-Path $V8Path "1cv8.exe" +} + +if (-not (Test-Path $V8Path)) { + Write-Host "Error: 1cv8.exe not found at $V8Path" -ForegroundColor Red + exit 1 +} + +# --- Validate connection --- +if (-not $InfoBasePath -and (-not $InfoBaseServer -or -not $InfoBaseRef)) { + Write-Host "Error: specify -InfoBasePath or -InfoBaseServer + -InfoBaseRef" -ForegroundColor Red + exit 1 +} + +# --- Validate Partial mode --- +if ($Mode -eq "Partial" -and -not $Objects) { + Write-Host "Error: -Objects required for Partial mode" -ForegroundColor Red + exit 1 +} + +# --- Create output dir if needed --- +if (-not (Test-Path $ConfigDir)) { + New-Item -ItemType Directory -Path $ConfigDir -Force | Out-Null + Write-Host "Created output directory: $ConfigDir" +} + +# --- Temp dir --- +$tempDir = Join-Path $env:TEMP "db_dump_xml_$(Get-Random)" +New-Item -ItemType Directory -Path $tempDir -Force | Out-Null + +try { + # --- Build arguments --- + $arguments = @("DESIGNER") + + if ($InfoBaseServer -and $InfoBaseRef) { + $arguments += "/S", "`"$InfoBaseServer/$InfoBaseRef`"" + } else { + $arguments += "/F", "`"$InfoBasePath`"" + } + + if ($UserName) { $arguments += "/N`"$UserName`"" } + if ($Password) { $arguments += "/P`"$Password`"" } + + $arguments += "/DumpConfigToFiles", "`"$ConfigDir`"" + $arguments += "-Format", $Format + + switch ($Mode) { + "Full" { + Write-Host "Executing full configuration dump..." + } + "Changes" { + Write-Host "Executing incremental configuration dump..." + $arguments += "-update" + $arguments += "-force" + } + "Partial" { + Write-Host "Executing partial configuration dump..." + $objectList = $Objects -split ',' | ForEach-Object { $_.Trim() } | Where-Object { $_ } + + $listFile = Join-Path $tempDir "dump_list.txt" + $utf8Bom = New-Object System.Text.UTF8Encoding($true) + [System.IO.File]::WriteAllLines($listFile, $objectList, $utf8Bom) + + $arguments += "-listFile", "`"$listFile`"" + Write-Host "Objects to dump: $($objectList.Count)" + foreach ($obj in $objectList) { Write-Host " $obj" } + } + "UpdateInfo" { + Write-Host "Updating ConfigDumpInfo.xml..." + $arguments += "-configDumpInfoOnly" + } + } + + # --- Extensions --- + if ($Extension) { + $arguments += "-Extension", "`"$Extension`"" + } elseif ($AllExtensions) { + $arguments += "-AllExtensions" + } + + # --- Output --- + $outFile = Join-Path $tempDir "dump_log.txt" + $arguments += "/Out", "`"$outFile`"" + $arguments += "/DisableStartupDialogs" + + # --- Execute --- + Write-Host "Running: 1cv8.exe $($arguments -join ' ')" + $process = Start-Process -FilePath $V8Path -ArgumentList $arguments -NoNewWindow -Wait -PassThru + $exitCode = $process.ExitCode + + # --- Result --- + if ($exitCode -eq 0) { + Write-Host "Dump completed successfully" -ForegroundColor Green + Write-Host "Configuration dumped to: $ConfigDir" + } else { + Write-Host "Error dumping configuration (code: $exitCode)" -ForegroundColor Red + } + + if (Test-Path $outFile) { + $logContent = Get-Content $outFile -Raw -ErrorAction SilentlyContinue + if ($logContent) { + Write-Host "--- Log ---" + Write-Host $logContent + Write-Host "--- End ---" + } + } + + exit $exitCode + +} finally { + if (Test-Path $tempDir) { + Remove-Item -Path $tempDir -Recurse -Force -ErrorAction SilentlyContinue + } +} diff --git a/.claude/skills/db-list/SKILL.md b/.claude/skills/db-list/SKILL.md new file mode 100644 index 00000000..3e6bb65a --- /dev/null +++ b/.claude/skills/db-list/SKILL.md @@ -0,0 +1,154 @@ +--- +name: db-list +description: Управление реестром баз данных 1С (.v8-project.json). Используй когда пользователь говорит про базы данных, список баз, "добавь базу", "какие базы есть" +argument-hint: [add|remove|show] +allowed-tools: + - Read + - Write + - Glob + - AskUserQuestion +--- + +# /db-list — Управление реестром баз данных + +Управляет файлом `.v8-project.json` — реестром информационных баз проекта. Файл хранит параметры подключения, алиасы, привязку к веткам Git. + +## Usage + +``` +/db-list — показать список баз +/db-list add — добавить базу (интерактивно) +/db-list remove — удалить базу из реестра +/db-list show — подробности по базе +``` + +## Формат `.v8-project.json` + +Файл размещается в корне проекта (рядом с `.git/`). + +```json +{ + "v8path": "C:\\Program Files\\1cv8\\8.3.25.1257\\bin", + "databases": [ + { + "id": "dev", + "name": "Разработка", + "type": "file", + "path": "C:\\Bases\\MyApp_Dev", + "user": "Admin", + "password": "", + "aliases": ["dev", "разработка"], + "branches": ["dev", "develop"], + "configSrc": "C:\\WS\\myapp\\cfsrc" + }, + { + "id": "test", + "name": "Тестовая", + "type": "server", + "server": "srv01", + "ref": "MyApp_Test", + "user": "Admin", + "password": "123", + "aliases": ["test", "тест"] + } + ], + "default": "dev" +} +``` + +### Поля корневого объекта + +| Поле | Тип | Описание | +|------|-----|----------| +| `v8path` | string | Каталог bin платформы 1С. Необязательный — если не задан, автоопределение | +| `databases` | array | Массив баз данных | +| `default` | string | id базы по умолчанию | + +### Поля объекта базы данных + +| Поле | Тип | Обязательное | Описание | +|------|-----|:------------:|----------| +| `id` | string | да | Уникальный идентификатор (латиница, без пробелов) | +| `name` | string | да | Человекочитаемое имя | +| `type` | `"file"` / `"server"` | да | Тип подключения | +| `path` | string | для file | Путь к каталогу файловой базы | +| `server` | string | для server | Адрес сервера 1С | +| `ref` | string | для server | Имя базы на сервере | +| `user` | string | нет | Имя пользователя 1С | +| `password` | string | нет | Пароль | +| `aliases` | string[] | нет | Альтернативные имена для быстрого доступа | +| `branches` | string[] | нет | Git-ветки, привязанные к этой базе | +| `configSrc` | string | нет | Каталог XML-выгрузки конфигурации | + +## Алгоритм разрешения базы данных + +Этот алгоритм используется ВСЕМИ навыками `db-*` для определения целевой базы. + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — ищи совпадение в таком порядке: + 1. По `id` (точное совпадение) + 2. По `aliases` (точное совпадение в массиве) + 3. По `branches` (совпадение с текущей Git-веткой) + 4. По `name` (нечёткое совпадение) +3. Если пользователь не указал базу — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл `.v8-project.json` не найден — спроси параметры подключения и предложи создать файл + +### Автоопределение платформы + +Если `v8path` не задан в конфиге: + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Операции + +### Показать список баз + +Прочитай `.v8-project.json`, выведи таблицу: + +``` +ID Имя Тип Путь/Сервер По умолч. +dev Разработка file C:\Bases\MyApp_Dev ✓ +test Тестовая server srv01/MyApp_Test +``` + +### Добавить базу + +Спроси у пользователя через AskUserQuestion: +- id, name, type (file/server) +- path (для file) или server + ref (для server) +- user, password (необязательно) +- aliases, branches (необязательно) + +Добавь в массив `databases`. Если это первая база — установи как `default`. + +### Удалить базу + +Удали из массива `databases` по id. Если удаляемая была `default` — спросить новый default. + +### Подробности по базе + +Выведи все поля конкретной базы. + +## Формирование строки подключения + +Для использования в шаблонах команд других навыков: + +**Файловая база:** +``` +/F "" +``` + +**Серверная база:** +``` +/S "/" +``` + +**Аутентификация** (добавляется если user задан): +``` +/N"" /P"" +``` + +> **Важно**: между `/N` и именем пробела нет. Между `/P` и паролем пробела нет. Если пароль пустой — `/P""` или опустить `/P`. diff --git a/.claude/skills/db-load-cf/SKILL.md b/.claude/skills/db-load-cf/SKILL.md new file mode 100644 index 00000000..dd6878fb --- /dev/null +++ b/.claude/skills/db-load-cf/SKILL.md @@ -0,0 +1,78 @@ +--- +name: db-load-cf +description: Загрузка конфигурации 1С из CF-файла. Используй когда пользователь просит загрузить конфигурацию из CF, восстановить из бэкапа CF +argument-hint: [database] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-load-cf — Загрузка конфигурации из CF-файла + +Загружает конфигурацию из бинарного CF-файла в информационную базу. + +## Usage + +``` +/db-load-cf [database] +/db-load-cf config.cf dev +``` + +> **Внимание**: загрузка CF **полностью заменяет** конфигурацию в базе. Перед выполнением запроси подтверждение у пользователя. + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```cmd +"\1cv8.exe" DESIGNER /F "<база>" /N"" /P"" /LoadCfg "<файл.cf>" /DisableStartupDialogs /Out "<лог>" +``` + +Для серверной базы вместо `/F` используй `/S`: +```cmd +"\1cv8.exe" DESIGNER /S "/" /N"" /P"" /LoadCfg "<файл.cf>" /DisableStartupDialogs /Out "<лог>" +``` + +### Параметры + +| Параметр | Описание | +|----------|----------| +| `/LoadCfg <файл>` | Путь к CF-файлу | +| `-Extension <имя>` | Загрузить как расширение | +| `-AllExtensions` | Загрузить все расширения из архива | + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## После выполнения + +1. Прочитай лог-файл и покажи результат +2. **Предложи выполнить `/db-update`** — загрузка CF обновляет только «основную» конфигурацию конфигуратора, для применения к БД нужен `/UpdateDBCfg` + +## Пример + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + +& $v8.FullName DESIGNER /F "C:\Bases\MyDB" /N"Admin" /P"" /LoadCfg "C:\backup\config.cf" /DisableStartupDialogs /Out "load.log" + +# Не забудь обновить БД после загрузки! +& $v8.FullName DESIGNER /F "C:\Bases\MyDB" /N"Admin" /P"" /UpdateDBCfg /DisableStartupDialogs /Out "update.log" +``` diff --git a/.claude/skills/db-load-git/SKILL.md b/.claude/skills/db-load-git/SKILL.md new file mode 100644 index 00000000..942c6ca0 --- /dev/null +++ b/.claude/skills/db-load-git/SKILL.md @@ -0,0 +1,110 @@ +--- +name: db-load-git +description: Загрузка изменений из Git в базу 1С. Используй когда пользователь просит загрузить изменения из гита, обновить базу из репозитория, partial load из коммита +argument-hint: [database] [source] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-load-git — Загрузка изменений из Git + +Определяет изменённые файлы конфигурации по данным Git и выполняет частичную загрузку в информационную базу. + +## Usage + +``` +/db-load-git [database] +/db-load-git dev — все незафиксированные изменения +/db-load-git dev -Source Staged — только staged +/db-load-git dev -Source Commit -CommitRange "HEAD~3..HEAD" +/db-load-git dev -DryRun — только показать что будет загружено +``` + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Если в записи базы указан `configSrc` — используй его как каталог конфигурации. + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```powershell +powershell.exe -NoProfile -File .claude\skills\db-load-git\scripts\db-load-git.ps1 <параметры> +``` + +### Параметры скрипта + +| Параметр | Обязательный | Описание | +|----------|:------------:|----------| +| `-V8Path <путь>` | нет | Каталог bin платформы (или полный путь к 1cv8.exe) | +| `-InfoBasePath <путь>` | * | Файловая база | +| `-InfoBaseServer <сервер>` | * | Сервер 1С (для серверной базы) | +| `-InfoBaseRef <имя>` | * | Имя базы на сервере | +| `-UserName <имя>` | нет | Имя пользователя | +| `-Password <пароль>` | нет | Пароль | +| `-ConfigDir <путь>` | да | Каталог XML-выгрузки (git-репозиторий) | +| `-Source <источник>` | нет | `All` (по умолч.) / `Staged` / `Unstaged` / `Commit` | +| `-CommitRange ` | для Commit | Диапазон коммитов (напр. `HEAD~3..HEAD`) | +| `-Extension <имя>` | нет | Загрузить в расширение | +| `-AllExtensions` | нет | Загрузить все расширения | +| `-Format <формат>` | нет | `Hierarchical` (по умолч.) / `Plain` | +| `-DryRun` | нет | Только показать что будет загружено (без загрузки) | + +> `*` — нужен либо `-InfoBasePath`, либо пара `-InfoBaseServer` + `-InfoBaseRef` + +### Источники изменений + +| Source | Описание | +|--------|----------| +| `All` | Все незафиксированные: staged + unstaged + untracked | +| `Staged` | Только проиндексированные (git add) | +| `Unstaged` | Только изменённые но не проиндексированные | +| `Commit` | Файлы из диапазона коммитов (требует `-CommitRange`) | + +### Логика маппинга BSL → XML + +Для `.bsl` файлов скрипт автоматически добавляет: +1. XML объекта верхнего уровня (напр. `Catalogs/Номенклатура.xml`) +2. Все файлы из каталога `Ext/` этого объекта (связанные модули) + +Пропускаются: `ConfigDumpInfo.xml`, файлы вне `ConfigDir`. + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно (или нет изменений) | +| 1 | Ошибка (см. лог) | + +## После выполнения + +1. Показать список загруженных файлов +2. **Предложить `/db-update`** — для применения изменений к БД + +## Примеры + +```powershell +# Загрузить все незафиксированные изменения +powershell.exe -NoProfile -File .claude\skills\db-load-git\scripts\db-load-git.ps1 -V8Path "C:\Program Files\1cv8\8.3.25.1257\bin" -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Source All + +# Только staged +powershell.exe -NoProfile -File .claude\skills\db-load-git\scripts\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Source Staged + +# Из диапазона коммитов +powershell.exe -NoProfile -File .claude\skills\db-load-git\scripts\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Source Commit -CommitRange "HEAD~3..HEAD" + +# Только посмотреть (DryRun) +powershell.exe -NoProfile -File .claude\skills\db-load-git\scripts\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\WS\cfsrc" -DryRun +``` diff --git a/.claude/skills/db-load-git/scripts/db-load-git.ps1 b/.claude/skills/db-load-git/scripts/db-load-git.ps1 new file mode 100644 index 00000000..803f6b91 --- /dev/null +++ b/.claude/skills/db-load-git/scripts/db-load-git.ps1 @@ -0,0 +1,352 @@ +# db-load-git v1.0 — Load Git changes into 1C database +# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills +<# +.SYNOPSIS + Загрузка изменений из Git в базу 1С + +.DESCRIPTION + Определяет изменённые файлы конфигурации по данным Git и выполняет + частичную загрузку в информационную базу. + +.PARAMETER V8Path + Путь к каталогу bin платформы или к 1cv8.exe + +.PARAMETER InfoBasePath + Путь к файловой информационной базе + +.PARAMETER InfoBaseServer + Сервер 1С (для серверной базы) + +.PARAMETER InfoBaseRef + Имя базы на сервере + +.PARAMETER UserName + Имя пользователя 1С + +.PARAMETER Password + Пароль пользователя + +.PARAMETER ConfigDir + Каталог XML-выгрузки конфигурации (git-репозиторий) + +.PARAMETER Source + Источник изменений: All, Staged, Unstaged, Commit (по умолчанию All) + +.PARAMETER CommitRange + Диапазон коммитов (для Source=Commit), напр. HEAD~3..HEAD + +.PARAMETER Extension + Имя расширения для загрузки + +.PARAMETER AllExtensions + Загрузить все расширения + +.PARAMETER Format + Формат файлов: Hierarchical или Plain (по умолчанию Hierarchical) + +.PARAMETER DryRun + Только показать что будет загружено (без загрузки) + +.EXAMPLE + .\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Source All + +.EXAMPLE + .\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Source Commit -CommitRange "HEAD~3..HEAD" + +.EXAMPLE + .\db-load-git.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -DryRun +#> + +[CmdletBinding()] +param( + [Parameter(Mandatory=$false)] + [string]$V8Path, + + [Parameter(Mandatory=$false)] + [string]$InfoBasePath, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseServer, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseRef, + + [Parameter(Mandatory=$false)] + [string]$UserName, + + [Parameter(Mandatory=$false)] + [string]$Password, + + [Parameter(Mandatory=$true)] + [string]$ConfigDir, + + [Parameter(Mandatory=$false)] + [ValidateSet("All", "Staged", "Unstaged", "Commit")] + [string]$Source = "All", + + [Parameter(Mandatory=$false)] + [string]$CommitRange, + + [Parameter(Mandatory=$false)] + [string]$Extension, + + [Parameter(Mandatory=$false)] + [switch]$AllExtensions, + + [Parameter(Mandatory=$false)] + [ValidateSet("Hierarchical", "Plain")] + [string]$Format = "Hierarchical", + + [Parameter(Mandatory=$false)] + [switch]$DryRun +) + +$OutputEncoding = [System.Text.Encoding]::UTF8 +[Console]::OutputEncoding = [System.Text.Encoding]::UTF8 + +# --- Helper: map BSL path to object XML --- +function Get-ObjectXmlFromBsl { + param([string]$RelativePath) + + $parts = $RelativePath -split '[\\/]' + if ($parts.Count -ge 2) { + return "$($parts[0])/$($parts[1]).xml" + } + return $null +} + +# --- Resolve V8Path (skip if DryRun) --- +if (-not $DryRun) { + if (-not $V8Path) { + $found = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" -ErrorAction SilentlyContinue | Sort-Object FullName -Descending | Select-Object -First 1 + if ($found) { + $V8Path = $found.FullName + } else { + Write-Host "Error: 1cv8.exe not found. Specify -V8Path" -ForegroundColor Red + exit 1 + } + } elseif (Test-Path $V8Path -PathType Container) { + $V8Path = Join-Path $V8Path "1cv8.exe" + } + + if (-not (Test-Path $V8Path)) { + Write-Host "Error: 1cv8.exe not found at $V8Path" -ForegroundColor Red + exit 1 + } +} + +# --- Validate connection (skip if DryRun) --- +if (-not $DryRun) { + if (-not $InfoBasePath -and (-not $InfoBaseServer -or -not $InfoBaseRef)) { + Write-Host "Error: specify -InfoBasePath or -InfoBaseServer + -InfoBaseRef" -ForegroundColor Red + exit 1 + } +} + +# --- Validate config dir --- +if (-not (Test-Path $ConfigDir)) { + Write-Host "Error: config directory not found: $ConfigDir" -ForegroundColor Red + exit 1 +} + +# --- Validate Commit mode --- +if ($Source -eq "Commit" -and -not $CommitRange) { + Write-Host "Error: -CommitRange required for Source=Commit" -ForegroundColor Red + exit 1 +} + +# --- Check git --- +try { + $null = git --version 2>&1 +} catch { + Write-Host "Error: git not found in PATH" -ForegroundColor Red + exit 1 +} + +# --- Get changed files from Git --- +$changedFiles = @() +$configDirNormalized = $ConfigDir.TrimEnd('\', '/').Replace('\', '/') + +Push-Location $ConfigDir +try { + switch ($Source) { + "Staged" { + Write-Host "Getting staged changes..." + $raw = git diff --cached --name-only 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + } + "Unstaged" { + Write-Host "Getting unstaged changes..." + $raw = git diff --name-only 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + $raw = git ls-files --others --exclude-standard 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + } + "Commit" { + Write-Host "Getting changes from $CommitRange..." + $raw = git diff --name-only $CommitRange 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + } + "All" { + Write-Host "Getting all uncommitted changes..." + $raw = git diff --cached --name-only 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + $raw = git diff --name-only 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + $raw = git ls-files --others --exclude-standard 2>&1 + if ($LASTEXITCODE -eq 0) { $changedFiles += $raw } + } + } +} finally { + Pop-Location +} + +$changedFiles = $changedFiles | Where-Object { -not [string]::IsNullOrWhiteSpace($_) } | Select-Object -Unique + +if ($changedFiles.Count -eq 0) { + Write-Host "No changes found" + exit 0 +} + +Write-Host "Git changes detected: $($changedFiles.Count) files" + +# --- Filter and map to config files --- +$configFiles = @() + +foreach ($file in $changedFiles) { + $file = $file.Trim().Replace('\', '/') + if ([string]::IsNullOrWhiteSpace($file)) { continue } + + # Skip service files + if ($file -eq "ConfigDumpInfo.xml") { continue } + + # Only process .xml and .bsl files + if ($file -match '\.(xml|bsl)$') { + # Check file exists in config dir + $fullPath = Join-Path $ConfigDir $file + if ($file -match '\.xml$') { + if (Test-Path $fullPath) { + if ($configFiles -notcontains $file) { + $configFiles += $file + } + } + } + elseif ($file -match '\.bsl$') { + # For BSL: add the BSL itself + parent object XML + all Ext/ files + $objectXml = Get-ObjectXmlFromBsl -RelativePath $file + if ($objectXml) { + $fullXmlPath = Join-Path $ConfigDir $objectXml + if (Test-Path $fullXmlPath) { + if ($configFiles -notcontains $objectXml) { + $configFiles += $objectXml + } + if ($configFiles -notcontains $file) { + $configFiles += $file + } + + # Add all files from Ext/ directory of the object + $parts = $file -split '[\\/]' + if ($parts.Count -ge 2) { + $extDir = Join-Path (Join-Path $ConfigDir $parts[0]) "$($parts[1])\Ext" + if (Test-Path $extDir) { + Get-ChildItem -Path $extDir -Recurse -File | ForEach-Object { + $extRelPath = $_.FullName.Replace("$ConfigDir\", '').Replace('\', '/') + if ($configFiles -notcontains $extRelPath) { + $configFiles += $extRelPath + } + } + } + } + } + } + } + } +} + +if ($configFiles.Count -eq 0) { + Write-Host "No configuration files found in changes" + exit 0 +} + +Write-Host "Files for loading: $($configFiles.Count)" +foreach ($f in $configFiles) { Write-Host " $f" } + +# --- DryRun: stop here --- +if ($DryRun) { + Write-Host "" + Write-Host "DryRun mode - no changes applied" + exit 0 +} + +# --- Temp dir --- +$tempDir = Join-Path $env:TEMP "db_load_git_$(Get-Random)" +New-Item -ItemType Directory -Path $tempDir -Force | Out-Null + +try { + # --- Write list file (UTF-8 with BOM) --- + $listFile = Join-Path $tempDir "load_list.txt" + $utf8Bom = New-Object System.Text.UTF8Encoding($true) + [System.IO.File]::WriteAllLines($listFile, $configFiles, $utf8Bom) + + # --- Build arguments --- + $arguments = @("DESIGNER") + + if ($InfoBaseServer -and $InfoBaseRef) { + $arguments += "/S", "`"$InfoBaseServer/$InfoBaseRef`"" + } else { + $arguments += "/F", "`"$InfoBasePath`"" + } + + if ($UserName) { $arguments += "/N`"$UserName`"" } + if ($Password) { $arguments += "/P`"$Password`"" } + + $arguments += "/LoadConfigFromFiles", "`"$ConfigDir`"" + $arguments += "-listFile", "`"$listFile`"" + $arguments += "-Format", $Format + $arguments += "-partial" + $arguments += "-updateConfigDumpInfo" + + # --- Extensions --- + if ($Extension) { + $arguments += "-Extension", "`"$Extension`"" + } elseif ($AllExtensions) { + $arguments += "-AllExtensions" + } + + # --- Output --- + $outFile = Join-Path $tempDir "load_log.txt" + $arguments += "/Out", "`"$outFile`"" + $arguments += "/DisableStartupDialogs" + + # --- Execute --- + Write-Host "" + Write-Host "Executing partial configuration load..." + Write-Host "Running: 1cv8.exe $($arguments -join ' ')" + + $process = Start-Process -FilePath $V8Path -ArgumentList $arguments -NoNewWindow -Wait -PassThru + $exitCode = $process.ExitCode + + # --- Result --- + Write-Host "" + if ($exitCode -eq 0) { + Write-Host "Load completed successfully" -ForegroundColor Green + } else { + Write-Host "Error loading configuration (code: $exitCode)" -ForegroundColor Red + } + + if (Test-Path $outFile) { + $logContent = Get-Content $outFile -Raw -ErrorAction SilentlyContinue + if ($logContent) { + Write-Host "--- Log ---" + Write-Host $logContent + Write-Host "--- End ---" + } + } + + exit $exitCode + +} finally { + if (Test-Path $tempDir) { + Remove-Item -Path $tempDir -Recurse -Force -ErrorAction SilentlyContinue + } +} diff --git a/.claude/skills/db-load-xml/SKILL.md b/.claude/skills/db-load-xml/SKILL.md new file mode 100644 index 00000000..f591bcb8 --- /dev/null +++ b/.claude/skills/db-load-xml/SKILL.md @@ -0,0 +1,108 @@ +--- +name: db-load-xml +description: Загрузка конфигурации 1С из XML-файлов. Используй когда пользователь просит загрузить конфигурацию из файлов, XML, исходников, LoadConfigFromFiles +argument-hint: [database] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-load-xml — Загрузка конфигурации из XML + +Загружает конфигурацию в информационную базу из XML-файлов (исходников). Поддерживает полную и частичную загрузку. + +## Usage + +``` +/db-load-xml [database] +/db-load-xml src/config dev +/db-load-xml src/config dev -Mode Partial -Files "Catalogs/Номенклатура.xml,Catalogs/Номенклатура/Ext/ObjectModule.bsl" +``` + +> **Внимание**: полная загрузка **заменяет всю конфигурацию** в базе. Перед выполнением запроси подтверждение у пользователя. + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Если в записи базы указан `configSrc` — используй его как каталог загрузки по умолчанию. + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```powershell +powershell.exe -NoProfile -File .claude\skills\db-load-xml\scripts\db-load-xml.ps1 <параметры> +``` + +### Параметры скрипта + +| Параметр | Обязательный | Описание | +|----------|:------------:|----------| +| `-V8Path <путь>` | нет | Каталог bin платформы (или полный путь к 1cv8.exe) | +| `-InfoBasePath <путь>` | * | Файловая база | +| `-InfoBaseServer <сервер>` | * | Сервер 1С (для серверной базы) | +| `-InfoBaseRef <имя>` | * | Имя базы на сервере | +| `-UserName <имя>` | нет | Имя пользователя | +| `-Password <пароль>` | нет | Пароль | +| `-ConfigDir <путь>` | да | Каталог XML-исходников | +| `-Mode <режим>` | нет | `Full` (по умолч.) / `Partial` | +| `-Files <список>` | для Partial | Относительные пути файлов через запятую | +| `-ListFile <путь>` | для Partial | Путь к файлу со списком (альтернатива `-Files`) | +| `-Extension <имя>` | нет | Загрузить в расширение | +| `-AllExtensions` | нет | Загрузить все расширения | +| `-Format <формат>` | нет | `Hierarchical` (по умолч.) / `Plain` | + +> `*` — нужен либо `-InfoBasePath`, либо пара `-InfoBaseServer` + `-InfoBaseRef` + +### Режимы загрузки + +| Режим | Описание | +|-------|----------| +| `Full` | Полная загрузка — замена всей конфигурации из каталога XML | +| `Partial` | Частичная — загрузка выбранных файлов (с `-partial -updateConfigDumpInfo`) | + +### Формат файла списка (listFile) + +Файл содержит **относительные пути к файлам** в каталоге выгрузки (один на строку), кодировка **UTF-8 с BOM**: + +``` +Catalogs/Номенклатура.xml +Catalogs/Номенклатура/Ext/ObjectModule.bsl +Documents/Заказ.xml +Documents/Заказ/Forms/ФормаДокумента.xml +``` + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## После выполнения + +1. Прочитай лог и покажи результат +2. **Предложи выполнить `/db-update`** — для применения изменений к БД + +## Примеры + +```powershell +# Полная загрузка +powershell.exe -NoProfile -File .claude\skills\db-load-xml\scripts\db-load-xml.ps1 -V8Path "C:\Program Files\1cv8\8.3.25.1257\bin" -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Mode Full + +# Частичная загрузка конкретных файлов +powershell.exe -NoProfile -File .claude\skills\db-load-xml\scripts\db-load-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\cfsrc" -Mode Partial -Files "Catalogs/Номенклатура.xml,Catalogs/Номенклатура/Ext/ObjectModule.bsl" + +# Загрузка расширения +powershell.exe -NoProfile -File .claude\skills\db-load-xml\scripts\db-load-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -UserName "Admin" -ConfigDir "C:\WS\ext_src" -Mode Full -Extension "МоёРасширение" +``` diff --git a/.claude/skills/db-load-xml/scripts/db-load-xml.ps1 b/.claude/skills/db-load-xml/scripts/db-load-xml.ps1 new file mode 100644 index 00000000..5d2cbb6c --- /dev/null +++ b/.claude/skills/db-load-xml/scripts/db-load-xml.ps1 @@ -0,0 +1,230 @@ +# db-load-xml v1.0 — Load 1C configuration from XML files +# Source: https://github.com/Nikolay-Shirokov/cc-1c-skills +<# +.SYNOPSIS + Загрузка конфигурации 1С из XML-файлов + +.DESCRIPTION + Загружает конфигурацию в информационную базу из XML-файлов. + Поддерживает полную и частичную загрузку. + +.PARAMETER V8Path + Путь к каталогу bin платформы или к 1cv8.exe + +.PARAMETER InfoBasePath + Путь к файловой информационной базе + +.PARAMETER InfoBaseServer + Сервер 1С (для серверной базы) + +.PARAMETER InfoBaseRef + Имя базы на сервере + +.PARAMETER UserName + Имя пользователя 1С + +.PARAMETER Password + Пароль пользователя + +.PARAMETER ConfigDir + Каталог XML-исходников конфигурации + +.PARAMETER Mode + Режим загрузки: Full или Partial (по умолчанию Full) + +.PARAMETER Files + Относительные пути файлов через запятую (для режима Partial) + +.PARAMETER ListFile + Путь к файлу со списком файлов (альтернатива -Files, для режима Partial) + +.PARAMETER Extension + Имя расширения для загрузки + +.PARAMETER AllExtensions + Загрузить все расширения + +.PARAMETER Format + Формат файлов: Hierarchical или Plain (по умолчанию Hierarchical) + +.EXAMPLE + .\db-load-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Mode Full + +.EXAMPLE + .\db-load-xml.ps1 -InfoBasePath "C:\Bases\MyDB" -ConfigDir "C:\src" -Mode Partial -Files "Catalogs/Номенклатура.xml,Catalogs/Номенклатура/Ext/ObjectModule.bsl" +#> + +[CmdletBinding()] +param( + [Parameter(Mandatory=$false)] + [string]$V8Path, + + [Parameter(Mandatory=$false)] + [string]$InfoBasePath, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseServer, + + [Parameter(Mandatory=$false)] + [string]$InfoBaseRef, + + [Parameter(Mandatory=$false)] + [string]$UserName, + + [Parameter(Mandatory=$false)] + [string]$Password, + + [Parameter(Mandatory=$true)] + [string]$ConfigDir, + + [Parameter(Mandatory=$false)] + [ValidateSet("Full", "Partial")] + [string]$Mode = "Full", + + [Parameter(Mandatory=$false)] + [string]$Files, + + [Parameter(Mandatory=$false)] + [string]$ListFile, + + [Parameter(Mandatory=$false)] + [string]$Extension, + + [Parameter(Mandatory=$false)] + [switch]$AllExtensions, + + [Parameter(Mandatory=$false)] + [ValidateSet("Hierarchical", "Plain")] + [string]$Format = "Hierarchical" +) + +$OutputEncoding = [System.Text.Encoding]::UTF8 +[Console]::OutputEncoding = [System.Text.Encoding]::UTF8 + +# --- Resolve V8Path --- +if (-not $V8Path) { + $found = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" -ErrorAction SilentlyContinue | Sort-Object FullName -Descending | Select-Object -First 1 + if ($found) { + $V8Path = $found.FullName + } else { + Write-Host "Error: 1cv8.exe not found. Specify -V8Path" -ForegroundColor Red + exit 1 + } +} elseif (Test-Path $V8Path -PathType Container) { + $V8Path = Join-Path $V8Path "1cv8.exe" +} + +if (-not (Test-Path $V8Path)) { + Write-Host "Error: 1cv8.exe not found at $V8Path" -ForegroundColor Red + exit 1 +} + +# --- Validate connection --- +if (-not $InfoBasePath -and (-not $InfoBaseServer -or -not $InfoBaseRef)) { + Write-Host "Error: specify -InfoBasePath or -InfoBaseServer + -InfoBaseRef" -ForegroundColor Red + exit 1 +} + +# --- Validate config dir --- +if (-not (Test-Path $ConfigDir)) { + Write-Host "Error: config directory not found: $ConfigDir" -ForegroundColor Red + exit 1 +} + +# --- Validate Partial mode --- +if ($Mode -eq "Partial" -and -not $Files -and -not $ListFile) { + Write-Host "Error: -Files or -ListFile required for Partial mode" -ForegroundColor Red + exit 1 +} + +# --- Temp dir --- +$tempDir = Join-Path $env:TEMP "db_load_xml_$(Get-Random)" +New-Item -ItemType Directory -Path $tempDir -Force | Out-Null + +try { + # --- Build arguments --- + $arguments = @("DESIGNER") + + if ($InfoBaseServer -and $InfoBaseRef) { + $arguments += "/S", "`"$InfoBaseServer/$InfoBaseRef`"" + } else { + $arguments += "/F", "`"$InfoBasePath`"" + } + + if ($UserName) { $arguments += "/N`"$UserName`"" } + if ($Password) { $arguments += "/P`"$Password`"" } + + $arguments += "/LoadConfigFromFiles", "`"$ConfigDir`"" + + if ($Mode -eq "Full") { + Write-Host "Executing full configuration load..." + } else { + Write-Host "Executing partial configuration load..." + + # Build list file + $generatedListFile = $null + if ($ListFile) { + # Use provided list file + if (-not (Test-Path $ListFile)) { + Write-Host "Error: list file not found: $ListFile" -ForegroundColor Red + exit 1 + } + $generatedListFile = $ListFile + } else { + # Generate from -Files parameter + $fileList = $Files -split ',' | ForEach-Object { $_.Trim() } | Where-Object { $_ } + $generatedListFile = Join-Path $tempDir "load_list.txt" + $utf8Bom = New-Object System.Text.UTF8Encoding($true) + [System.IO.File]::WriteAllLines($generatedListFile, $fileList, $utf8Bom) + + Write-Host "Files to load: $($fileList.Count)" + foreach ($f in $fileList) { Write-Host " $f" } + } + + $arguments += "-listFile", "`"$generatedListFile`"" + $arguments += "-partial" + $arguments += "-updateConfigDumpInfo" + } + + $arguments += "-Format", $Format + + # --- Extensions --- + if ($Extension) { + $arguments += "-Extension", "`"$Extension`"" + } elseif ($AllExtensions) { + $arguments += "-AllExtensions" + } + + # --- Output --- + $outFile = Join-Path $tempDir "load_log.txt" + $arguments += "/Out", "`"$outFile`"" + $arguments += "/DisableStartupDialogs" + + # --- Execute --- + Write-Host "Running: 1cv8.exe $($arguments -join ' ')" + $process = Start-Process -FilePath $V8Path -ArgumentList $arguments -NoNewWindow -Wait -PassThru + $exitCode = $process.ExitCode + + # --- Result --- + if ($exitCode -eq 0) { + Write-Host "Load completed successfully" -ForegroundColor Green + } else { + Write-Host "Error loading configuration (code: $exitCode)" -ForegroundColor Red + } + + if (Test-Path $outFile) { + $logContent = Get-Content $outFile -Raw -ErrorAction SilentlyContinue + if ($logContent) { + Write-Host "--- Log ---" + Write-Host $logContent + Write-Host "--- End ---" + } + } + + exit $exitCode + +} finally { + if (Test-Path $tempDir) { + Remove-Item -Path $tempDir -Recurse -Force -ErrorAction SilentlyContinue + } +} diff --git a/.claude/skills/db-run/SKILL.md b/.claude/skills/db-run/SKILL.md new file mode 100644 index 00000000..fc23d209 --- /dev/null +++ b/.claude/skills/db-run/SKILL.md @@ -0,0 +1,85 @@ +--- +name: db-run +description: Запуск 1С:Предприятие. Используй когда пользователь просит запустить 1С, открыть базу, запустить предприятие +argument-hint: [database] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-run — Запуск 1С:Предприятие + +Запускает информационную базу в режиме 1С:Предприятие (пользовательский режим). + +## Usage + +``` +/db-run [database] +/db-run dev +/db-run dev /Execute process.epf +/db-run dev /C "параметр запуска" +``` + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```cmd +"\1cv8.exe" ENTERPRISE /F "<база>" /N"" /P"" /DisableStartupDialogs +``` + +Для серверной базы вместо `/F` используй `/S`: +```cmd +"\1cv8.exe" ENTERPRISE /S "/" /N"" /P"" /DisableStartupDialogs +``` + +### Параметры + +| Параметр | Описание | +|----------|----------| +| `/Execute <файл.epf>` | Запуск внешней обработки сразу после старта | +| `/C <строка>` | Передача параметра в прикладное решение | +| `/URL <ссылка>` | Навигационная ссылка (формат `e1cib/...`) | + +> При указании `/Execute` параметр `/URL` игнорируется. + +## Важно + +**Запуск в фоне** — не жди завершения процесса 1С. Используй `Start-Process` без `-Wait`: + +```powershell +Start-Process -FilePath "\1cv8.exe" -ArgumentList 'ENTERPRISE /F "<база>" /N"" /P"" /DisableStartupDialogs' +``` + +Или через Bash: +```bash +"/1cv8.exe" ENTERPRISE /F "<база>" /N"" /P"" /DisableStartupDialogs & +``` + +## Примеры + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + +# Простой запуск +Start-Process -FilePath $v8.FullName -ArgumentList 'ENTERPRISE /F "C:\Bases\MyDB" /N"Admin" /P"" /DisableStartupDialogs' + +# Запуск с обработкой +Start-Process -FilePath $v8.FullName -ArgumentList 'ENTERPRISE /F "C:\Bases\MyDB" /N"Admin" /P"" /Execute "C:\epf\МояОбработка.epf" /DisableStartupDialogs' + +# Открыть по навигационной ссылке +Start-Process -FilePath $v8.FullName -ArgumentList 'ENTERPRISE /F "C:\Bases\MyDB" /N"Admin" /P"" /URL "e1cib/data/Справочник.Номенклатура" /DisableStartupDialogs' +``` diff --git a/.claude/skills/db-update/SKILL.md b/.claude/skills/db-update/SKILL.md new file mode 100644 index 00000000..c7e6f6d7 --- /dev/null +++ b/.claude/skills/db-update/SKILL.md @@ -0,0 +1,93 @@ +--- +name: db-update +description: Обновление конфигурации базы данных 1С. Используй когда пользователь просит обновить БД, применить конфигурацию, UpdateDBCfg +argument-hint: [database] +allowed-tools: + - Bash + - Read + - Glob + - AskUserQuestion +--- + +# /db-update — Обновление конфигурации БД + +Применяет изменения основной конфигурации к конфигурации базы данных (`/UpdateDBCfg`). Обязательный шаг после `/db-load-cf`, `/db-load-xml`, `/db-load-git`. + +## Usage + +``` +/db-update [database] +/db-update dev +/db-update dev -Dynamic+ +``` + +## Разрешение базы данных + +1. Прочитай `.v8-project.json` (в корне проекта или ближайшем родительском каталоге) +2. Если пользователь указал базу — найди по id/alias/branch/имени +3. Если не указал — используй `default` +4. Если не найдено или неоднозначно — спроси пользователя +5. Если файл не найден — спроси пользователя параметры подключения и предложи создать `.v8-project.json` + +Автоопределение платформы (если `v8path` не задан): +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 +``` + +## Команда + +```cmd +"\1cv8.exe" DESIGNER /F "<база>" /N"" /P"" /UpdateDBCfg /DisableStartupDialogs /Out "<лог>" +``` + +Для серверной базы вместо `/F` используй `/S`: +```cmd +"\1cv8.exe" DESIGNER /S "/" /N"" /P"" /UpdateDBCfg /DisableStartupDialogs /Out "<лог>" +``` + +### Параметры + +| Параметр | Описание | +|----------|----------| +| `/UpdateDBCfg` | Обновить конфигурацию БД | +| `-Dynamic+` | Динамическое обновление (без монопольного доступа) | +| `-Dynamic-` | Отключить динамическое обновление | +| `-Server` | Обновление на стороне сервера | +| `-WarningsAsErrors` | Предупреждения считать ошибками | +| `-Extension <имя>` | Обновить расширение | +| `-AllExtensions` | Обновить все расширения | + +### Фоновое обновление (серверная база) + +| Параметр | Описание | +|----------|----------| +| `-BackgroundStart` | Начать фоновое обновление | +| `-BackgroundFinish` | Дождаться окончания | +| `-BackgroundCancel` | Отменить | +| `-BackgroundSuspend` | Приостановить | +| `-BackgroundResume` | Возобновить | + +## Коды возврата + +| Код | Описание | +|-----|----------| +| 0 | Успешно | +| 1 | Ошибка (см. лог) | + +## Предупреждения + +- Если обновление **не динамическое** — потребуется **монопольный доступ** к базе (все пользователи должны выйти) +- Для серверных баз рекомендуется `-Dynamic+` для обновления без остановки +- Если структура данных существенно изменилась (удаление реквизитов, изменение типов) — динамическое обновление может быть невозможно + +## Пример + +```powershell +$v8 = Get-ChildItem "C:\Program Files\1cv8\*\bin\1cv8.exe" | Sort-Object -Descending | Select-Object -First 1 + +# Обычное обновление +& $v8.FullName DESIGNER /F "C:\Bases\MyDB" /N"Admin" /P"" /UpdateDBCfg /DisableStartupDialogs /Out "update.log" + +# Динамическое обновление +& $v8.FullName DESIGNER /S "srv01/MyDB" /N"Admin" /P"secret" /UpdateDBCfg -Dynamic+ /DisableStartupDialogs /Out "update.log" +``` diff --git a/README.md b/README.md index 41eb300f..58585ad4 100644 --- a/README.md +++ b/README.md @@ -33,6 +33,7 @@ | Расширения (CFE) | 5 навыков `/cfe-*` | Создание, заимствование, перехват методов, валидация, анализ расширений | [Подробнее](docs/cfe-guide.md) | | Подсистемы (Subsystem) | 4 навыка `/subsystem-*` | Анализ, создание, редактирование, валидация подсистем конфигурации | — | | Командный интерфейс (CI) | 2 навыка `/interface-*` | Редактирование и валидация CommandInterface.xml подсистем | — | +| Базы данных (DB) | 9 навыков `/db-*` | Создание баз, загрузка/выгрузка конфигураций, обновление БД, загрузка из Git | [Подробнее](docs/db-guide.md) | | Утилиты | `/img-grid` | Наложение сетки на изображение для определения пропорций колонок | — | ## Требования @@ -46,7 +47,7 @@ - [XML-формат внешних отчётов](docs/1c-erf-spec.md) — отличия ERF от EPF, Properties, MainDataCompositionSchema - [Управляемая форма](docs/1c-form-spec.md) — Form.xml, элементы, команды, реквизиты - [Встроенная справка](docs/1c-help-spec.md) — Help.xml, HTML-страницы, кнопка справки на форме -- [Сборка и разборка EPF/ERF](docs/build-spec.md) — команды `1cv8.exe`, параметры, коды возврата +- [Пакетный режим конфигуратора 1С](docs/build-spec.md) — команды `1cv8.exe`, DESIGNER, ENTERPRISE, CREATEINFOBASE - [Табличный документ (MXL)](docs/1c-spreadsheet-spec.md) — XML-формат SpreadsheetDocument, совместимость версий - [MXL DSL](docs/mxl-dsl-spec.md) — JSON-формат описания макета для `/mxl-compile` и `/mxl-decompile` - [Form DSL](docs/form-dsl-spec.md) — JSON-формат описания формы для `/form-compile` @@ -112,6 +113,15 @@ ├── subsystem-validate/ # Валидация подсистемы ├── interface-edit/ # Редактирование CommandInterface.xml ├── interface-validate/ # Валидация CommandInterface.xml +├── db-list/ # Управление реестром баз данных +├── db-create/ # Создание информационной базы +├── db-dump-cf/ # Выгрузка конфигурации в CF +├── db-load-cf/ # Загрузка конфигурации из CF +├── db-dump-xml/ # Выгрузка конфигурации в XML +├── db-load-xml/ # Загрузка конфигурации из XML +├── db-update/ # Обновление конфигурации БД +├── db-run/ # Запуск 1С:Предприятие +├── db-load-git/ # Загрузка изменений из Git └── img-grid/ # Сетка для анализа изображений docs/ ├── epf-guide.md # Гайд: внешние обработки и отчёты @@ -122,12 +132,13 @@ docs/ ├── meta-guide.md # Гайд: объекты метаданных конфигурации ├── cf-guide.md # Гайд: корневые файлы конфигурации ├── cfe-guide.md # Гайд: расширения конфигурации (CFE) +├── db-guide.md # Гайд: базы данных 1С ├── 1c-epf-spec.md # Спецификация XML-формата (EPF) ├── 1c-erf-spec.md # Спецификация XML-формата (ERF) ├── 1c-form-spec.md # Спецификация управляемых форм ├── 1c-help-spec.md # Спецификация встроенной справки ├── 1c-config-objects-spec.md # Спецификация объектов конфигурации -├── build-spec.md # Спецификация сборки/разборки +├── build-spec.md # Пакетный режим конфигуратора 1С ├── 1c-spreadsheet-spec.md # Спецификация табличного документа ├── mxl-dsl-spec.md # Спецификация MXL DSL ├── form-dsl-spec.md # Спецификация Form DSL diff --git a/docs/build-spec.md b/docs/build-spec.md index 01880a65..8f3e8464 100644 --- a/docs/build-spec.md +++ b/docs/build-spec.md @@ -355,8 +355,3 @@ Documents/РеализацияТоваровУслуг/Forms/ФормаДоку | `V8_PATH` | Каталог `bin` платформы 1С (например, `C:\Program Files\1cv8\8.3.27.1859\bin`) | | `V8_BASE` | Путь к пустой ИБ для EPF-сборки (создаётся автоматически при первом запуске) | -## Claude Code Skills - -Сборка и разборка доступны как навыки Claude Code: -- `/epf-build` — сборка EPF из XML -- `/epf-dump` — разборка EPF в XML diff --git a/docs/db-guide.md b/docs/db-guide.md new file mode 100644 index 00000000..13f59b89 --- /dev/null +++ b/docs/db-guide.md @@ -0,0 +1,142 @@ +# Базы данных 1С + +Навыки группы `/db-*` позволяют управлять информационными базами 1С из Claude Code: создавать базы, загружать и выгружать конфигурации, обновлять БД, запускать предприятие, загружать изменения из Git. + +## Навыки + +| Навык | Скрипт | Описание | +|-------|:------:|----------| +| `/db-list` | — | Управление реестром баз (.v8-project.json) | +| `/db-create` | — | Создание информационной базы | +| `/db-dump-cf` | — | Выгрузка конфигурации в CF-файл | +| `/db-load-cf` | — | Загрузка конфигурации из CF-файла | +| `/db-dump-xml` | `.ps1` | Выгрузка конфигурации в XML-файлы (полная/инкрементальная/частичная) | +| `/db-load-xml` | `.ps1` | Загрузка конфигурации из XML-файлов (полная/частичная) | +| `/db-update` | — | Обновление конфигурации БД | +| `/db-run` | — | Запуск 1С:Предприятие | +| `/db-load-git` | `.ps1` | Загрузка изменений из Git в базу | + +## Рабочий цикл + +``` +.v8-project.json → /db-create → /db-load-cf или /db-load-xml → /db-update → /db-run + ↑ + /db-dump-xml ←→ правки в исходниках → /db-load-git → /db-update +``` + +### Типичный цикл разработки + +1. **Настройка** — `/db-list add` зарегистрировать базу в `.v8-project.json` +2. **Создание** — `/db-create` создать базу (если нет) +3. **Загрузка** — `/db-load-xml` или `/db-load-cf` загрузить конфигурацию +4. **Обновление** — `/db-update` применить к БД +5. **Работа** — редактирование XML-исходников +6. **Синхронизация** — `/db-load-git` загрузить изменения из Git +7. **Обновление** — `/db-update` применить +8. **Запуск** — `/db-run` открыть предприятие + +## Формат `.v8-project.json` + +Файл размещается в корне проекта (рядом с `.git/`). + +```json +{ + "v8path": "C:\\Program Files\\1cv8\\8.3.25.1257\\bin", + "databases": [ + { + "id": "dev", + "name": "Разработка", + "type": "file", + "path": "C:\\Bases\\MyApp_Dev", + "user": "Admin", + "password": "", + "aliases": ["dev", "разработка"], + "branches": ["dev", "develop"], + "configSrc": "C:\\WS\\myapp\\cfsrc" + }, + { + "id": "test", + "name": "Тестовая", + "type": "server", + "server": "srv01", + "ref": "MyApp_Test", + "user": "Admin", + "password": "123", + "aliases": ["test", "тест"] + } + ], + "default": "dev" +} +``` + +### Поля базы данных + +| Поле | Тип | Обязательное | Описание | +|------|-----|:------------:|----------| +| `id` | string | да | Уникальный идентификатор | +| `name` | string | да | Имя | +| `type` | `"file"` / `"server"` | да | Тип подключения | +| `path` | string | для file | Каталог файловой базы | +| `server` | string | для server | Адрес сервера | +| `ref` | string | для server | Имя базы на сервере | +| `user` | string | нет | Пользователь 1С | +| `password` | string | нет | Пароль | +| `aliases` | string[] | нет | Альтернативные имена | +| `branches` | string[] | нет | Git-ветки | +| `configSrc` | string | нет | Каталог XML-выгрузки | + +### Разрешение базы + +Все навыки `db-*` используют единый алгоритм: id → alias → branch → name → default → спросить пользователя. + +## Сценарии использования + +### Создать базу и загрузить конфигурацию + +``` +> Создай файловую базу C:\Bases\Test и загрузи в неё конфигурацию из C:\WS\cfsrc +``` + +Claude вызовет `/db-create` → `/db-load-xml -Mode Full` → предложит `/db-update`. + +### Загрузить изменения из Git + +``` +> Загрузи мои последние правки в базу разработки +``` + +Claude вызовет `/db-load-git dev -Source All` → предложит `/db-update`. + +### Выгрузить конфигурацию + +``` +> Выгрузи конфигурацию из тестовой базы в C:\WS\cfsrc +``` + +Claude вызовет `/db-dump-xml test C:\WS\cfsrc -Mode Full`. + +### Работа с расширениями + +``` +> Выгрузи расширение МоёРасширение из базы dev в C:\WS\ext_src +``` + +Claude вызовет `/db-dump-xml dev C:\WS\ext_src -Extension МоёРасширение`. + +``` +> Загрузи расширение обратно в базу +``` + +Claude вызовет `/db-load-xml C:\WS\ext_src dev -Extension МоёРасширение` → предложит `/db-update -Extension МоёРасширение`. + +### Запустить предприятие + +``` +> Запусти базу разработки +``` + +Claude вызовет `/db-run dev`. + +## Спецификации + +- [build-spec.md](build-spec.md) — пакетный режим конфигуратора 1С (CREATEINFOBASE, DESIGNER, ENTERPRISE, параметры, коды возврата)