Some checks are pending
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / preflight (push) Waiting to run
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / vps-smoke (push) Waiting to run
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:frustration-matrix,kei-frustration-loop,kei-skill-importer,kei-projects-index,kei-projects-watcher,kei-gdrive-import,kei-leak-matrix,kei-skills,kei-gateway,kei-cron-scheduler,kei-export-trajectories,kei-backend-daytona,kei-d… (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-compute-baremetal,kei-compute-vultr,kei-compute-linode,kei-compute-digitalocean,kei-svc-systemd,kei-llm-bridge-mlx name:hosted-sleep-compute]) (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-diff,kei-scheduler,kei-watch,kei-prune,kei-discover,kei-brain-view,kei-hibernate,kei-ledger-sign,kei-fork name:wave13-15]) (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-git-gitea,kei-git-forgejo,kei-git-gitlab,kei-git-bitbucket,kei-memory-sled,kei-memory-redis,kei-memory-postgres,kei-memory-sqlite,kei-auth-google,kei-auth-apple,kei-auth-magiclink,kei-auth-webauthn,kei-notify-slack,kei-n… (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-ledger,kei-migrate,kei-changelog,kei-memory,kei-store,kei-conflict-scan,kei-refactor-engine,kei-graph-check,kei-shared,kei-dna-index,kei-pet name:core]) (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-machine-probe,kei-llm-ollama,kei-llm-llamacpp,kei-llm-mlx,kei-llm-router,kei-model name:llm-stack]) (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:kei-router,kei-sage,kei-task,kei-chat-store,kei-crossdomain,kei-search-core,kei-content-store,kei-social-store,kei-curator,kei-auth,kei-artifact name:mcp-lbm]) (push) Blocked by required conditions
CI (Forgejo Actions — self-hosted runner on Mac, host mode) / rust-primitives (map[crates:keisei,kei-forge,kei-runtime,kei-runtime-core,kei-atom-discovery,kei-agent-runtime,kei-capability,kei-provision,kei-entity-store,kei-pipe,kei-cache,kei-spawn,kei-replay name:atom-substrate]) (push) Blocked by required conditions
1. lib-onboarding.sh раскидан на 3 куба (Constructor Pattern <200 LOC):
- lib-onboarding-registry.sh (79 LOC) — парсеры providers/models.toml
+ onboarding_fallback_providers (14 провайдеров)
+ onboarding_auth_env_for_provider helper (был inline в collect_auth)
- lib-onboarding-ui.sh (189 LOC) — pick_language/transport/provider/model
+ collect_auth (whiptail/bash select)
- lib-onboarding-state.sh (57 LOC) — write_secrets + write_config
+ user-model-override.toml для kei-model-router
- lib-onboarding.sh (95 LOC) — тонкий оркестратор: should_run + run
Сам lib-onboarding.sh source'ит 3 подкуба автоматически. Глобалы
(ONBOARDING_*, REGISTRY_*, ONBOARDED_FLAG, etc.) объявлены в
оркестраторе, подкубы их используют через имена.
2. lib-menu.sh локализован:
- whiptail title + radiolist prompt через ${STR_MENU_TITLE} +
${STR_MENU_SUBSTRATE} + ${STR_MENU_PROFILE_PROMPT}.
- Plain heading тоже использует словарь.
- 12 коротких имён профилей (minimal/core/dev/...) — оставлены EN
как стабильные id (не переводятся).
3. _blocks/build-index.sh — детерминированная регенерация INDEX.md.
Группировка по 14 категорийным префиксам + "Прочие" для остальных.
Безопасно перезапускать. INDEX.md обновлён через этот скрипт
(минимальный diff — добавлена ссылка на build-index.sh в шапке).
Проверено: bash -n чисто, unit тесты onboarding_list_providers/
transports/models OK, non-TTY smoke ./install.sh --profile=minimal
--no-execute проходит.
57 lines
2.3 KiB
Bash
57 lines
2.3 KiB
Bash
# shellcheck shell=bash
|
|
# lib-onboarding-state.sh — запись результата мастера на диск.
|
|
#
|
|
# Constructor Pattern: 1 файл = state-запись. UI — в ui.sh, парсеры — в registry.sh.
|
|
#
|
|
# Пишет:
|
|
# ~/.claude/.onboarded — флаг прохождения
|
|
# ~/.claude/config/onboarding.toml — выбор lang/transport/provider/model
|
|
# ~/.claude/config/user-model-override.toml — для kei-model-router (HIGH аудит-1)
|
|
# ~/.claude/secrets/.env — добавляет ключи провайдера (chmod 600)
|
|
|
|
ONBOARDED_FLAG="${ONBOARDED_FLAG:-$HOME/.claude/.onboarded}"
|
|
ONBOARDING_CONFIG="${ONBOARDING_CONFIG:-$HOME/.claude/config/onboarding.toml}"
|
|
SECRETS_ENV="${SECRETS_ENV:-$HOME/.claude/secrets/.env}"
|
|
|
|
onboarding_write_secrets() {
|
|
[ "${#ONBOARDING_AUTH_ENV_KEYS[@]}" = "0" ] && return
|
|
mkdir -p "$(dirname "$SECRETS_ENV")"
|
|
touch "$SECRETS_ENV"; chmod 600 "$SECRETS_ENV"
|
|
local i
|
|
for i in "${!ONBOARDING_AUTH_ENV_KEYS[@]}"; do
|
|
local k="${ONBOARDING_AUTH_ENV_KEYS[$i]}"
|
|
local v="${ONBOARDING_AUTH_ENV_VALUES[$i]}"
|
|
if grep -q "^${k}=" "$SECRETS_ENV" 2>/dev/null; then
|
|
grep -v "^${k}=" "$SECRETS_ENV" > "$SECRETS_ENV.tmp"
|
|
mv "$SECRETS_ENV.tmp" "$SECRETS_ENV"
|
|
fi
|
|
printf '%s=%s\n' "$k" "$v" >> "$SECRETS_ENV"
|
|
done
|
|
chmod 600 "$SECRETS_ENV"
|
|
}
|
|
|
|
onboarding_write_config() {
|
|
mkdir -p "$(dirname "$ONBOARDING_CONFIG")"
|
|
cat > "$ONBOARDING_CONFIG" <<EOF
|
|
# KeiSeiKit onboarding choices. Auto-generated by lib-onboarding.sh.
|
|
# Re-run wizard: rm ~/.claude/.onboarded && ./install.sh
|
|
language = "$ONBOARDING_LANG"
|
|
transport = "$ONBOARDING_TRANSPORT"
|
|
provider = "$ONBOARDING_PROVIDER"
|
|
default_model = "$ONBOARDING_MODEL"
|
|
EOF
|
|
|
|
# Override для kei-model-router (HIGH аудит-1).
|
|
# Приоритет: --pinned flag > этот файл > agent-profiles.toml default_model_ref.
|
|
local override_path="$HOME/.claude/config/user-model-override.toml"
|
|
cat > "$override_path" <<EOF
|
|
# User-tier model override. Auto-generated by onboarding wizard.
|
|
# Format: kei-model-router::Registry::load_user_override().
|
|
# Priority: --pinned flag > этот файл > agent-profiles.toml default_model_ref.
|
|
provider = "$ONBOARDING_PROVIDER"
|
|
model = "$ONBOARDING_MODEL"
|
|
transport = "$ONBOARDING_TRANSPORT"
|
|
EOF
|
|
|
|
: > "$ONBOARDED_FLAG"
|
|
}
|