machineconfig 6.82__py3-none-any.whl → 8.51__py3-none-any.whl
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.
- machineconfig/cluster/remote/cloud_manager.py +1 -1
- machineconfig/cluster/remote/run_cluster.py +1 -1
- machineconfig/cluster/remote/run_remote.py +1 -1
- machineconfig/cluster/sessions_managers/utils/maker.py +29 -15
- machineconfig/cluster/sessions_managers/wt_local.py +17 -222
- machineconfig/cluster/sessions_managers/wt_local_manager.py +56 -194
- machineconfig/cluster/sessions_managers/wt_remote_manager.py +42 -198
- machineconfig/cluster/sessions_managers/wt_utils/manager_persistence.py +52 -0
- machineconfig/cluster/sessions_managers/wt_utils/monitoring_helpers.py +50 -0
- machineconfig/cluster/sessions_managers/wt_utils/status_reporting.py +76 -0
- machineconfig/cluster/sessions_managers/wt_utils/wt_helpers.py +199 -0
- machineconfig/cluster/sessions_managers/zellij_local.py +1 -1
- machineconfig/cluster/sessions_managers/zellij_local_manager.py +4 -2
- machineconfig/cluster/sessions_managers/zellij_remote_manager.py +3 -2
- machineconfig/cluster/sessions_managers/zellij_utils/process_monitor.py +2 -2
- machineconfig/jobs/installer/checks/check_installations.py +133 -0
- machineconfig/jobs/installer/checks/install_utils.py +132 -0
- machineconfig/jobs/installer/checks/report_utils.py +39 -0
- machineconfig/jobs/installer/checks/vt_utils.py +89 -0
- machineconfig/jobs/installer/installer_data.json +1500 -310
- machineconfig/jobs/installer/linux_scripts/docker.sh +6 -9
- machineconfig/jobs/installer/linux_scripts/q.sh +10 -7
- machineconfig/jobs/installer/linux_scripts/redis.sh +1 -0
- machineconfig/jobs/installer/package_groups.py +62 -91
- machineconfig/jobs/installer/powershell_scripts/install_fonts.ps1 +129 -34
- machineconfig/jobs/installer/{custom → python_scripts}/boxes.py +2 -3
- machineconfig/jobs/installer/{custom_dev → python_scripts}/brave.py +5 -3
- machineconfig/jobs/installer/python_scripts/cloudflare_warp_cli.py +23 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/code.py +14 -9
- machineconfig/jobs/installer/{custom_dev → python_scripts}/dubdb_adbc.py +1 -1
- machineconfig/jobs/installer/python_scripts/hx.py +214 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/nerdfont.py +2 -2
- machineconfig/jobs/installer/{custom_dev → python_scripts}/nerfont_windows_helper.py +32 -26
- machineconfig/jobs/installer/python_scripts/sysabc.py +145 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/wezterm.py +2 -19
- machineconfig/jobs/installer/{custom_dev → python_scripts}/winget.py +10 -14
- machineconfig/jobs/installer/python_scripts/yazi.py +139 -0
- machineconfig/{scripts/python/nw → jobs/scripts/bash_scripts}/mount_nfs +0 -1
- machineconfig/jobs/scripts/powershell_scripts/cmatrix.ps1 +52 -0
- machineconfig/jobs/scripts/powershell_scripts/mount_ssh.ps1 +13 -0
- machineconfig/jobs/scripts/powershell_scripts/obs.ps1 +4 -0
- machineconfig/jobs/scripts_dynamic/a.py +428 -0
- machineconfig/logger.py +1 -2
- machineconfig/profile/create_helper.py +56 -18
- machineconfig/profile/create_links.py +79 -21
- machineconfig/profile/create_links_export.py +87 -36
- machineconfig/profile/create_shell_profile.py +92 -127
- machineconfig/profile/mapper_data.toml +45 -0
- machineconfig/profile/mapper_dotfiles.toml +249 -0
- machineconfig/scripts/__init__.py +0 -4
- machineconfig/scripts/linux/wrap_mcfg +46 -0
- machineconfig/scripts/nu/wrap_mcfg.nu +69 -0
- machineconfig/scripts/python/agents.py +85 -165
- machineconfig/scripts/python/ai/initai.py +4 -2
- machineconfig/scripts/python/ai/scripts/__init__.py +1 -0
- machineconfig/scripts/python/ai/scripts/command_runner.ps1 +33 -0
- machineconfig/scripts/python/ai/{command_runner → scripts}/command_runner.sh +1 -1
- machineconfig/scripts/python/ai/scripts/lint_and_type_check.ps1 +2 -0
- machineconfig/scripts/python/ai/scripts/lint_and_type_check.sh +8 -6
- machineconfig/scripts/python/ai/solutions/claude/claude.py +1 -1
- machineconfig/scripts/python/ai/solutions/cline/cline.py +1 -1
- machineconfig/scripts/python/ai/solutions/copilot/{chatmodes/Thinking-Beast-Mode.chatmode.md → agents/Thinking-Beast-Mode.agent.md} +0 -1
- machineconfig/scripts/python/ai/solutions/copilot/{chatmodes/Ultimate-Transparent-Thinking-Beast-Mode.chatmode.md → agents/Ultimate-Transparent-Thinking-Beast-Mode.agent.md} +0 -1
- machineconfig/scripts/python/ai/solutions/copilot/{chatmodes/deepResearch.chatmode.md → agents/deepResearch.agent.md} +2 -2
- machineconfig/scripts/python/ai/solutions/copilot/github_copilot.py +6 -6
- machineconfig/scripts/python/ai/solutions/copilot/instructions/python/dev.instructions.md +33 -0
- machineconfig/scripts/python/ai/solutions/copilot/instructions/python/watch_exec.prompt.md +20 -0
- machineconfig/scripts/python/ai/solutions/crush/crush.py +1 -1
- machineconfig/scripts/python/ai/solutions/cursor/cursors.py +1 -1
- machineconfig/scripts/python/ai/solutions/gemini/gemini.py +1 -1
- machineconfig/scripts/python/ai/solutions/gemini/settings.json +3 -0
- machineconfig/scripts/python/ai/{generate_files.py → utils/generate_files.py} +2 -2
- machineconfig/scripts/python/ai/{solutions → utils}/generic.py +2 -15
- machineconfig/scripts/python/ai/{vscode_tasks.py → utils/vscode_tasks.py} +13 -5
- machineconfig/scripts/python/cloud.py +58 -11
- machineconfig/scripts/python/croshell.py +10 -162
- machineconfig/scripts/python/devops.py +73 -36
- machineconfig/scripts/python/devops_navigator.py +16 -6
- machineconfig/scripts/python/fire_jobs.py +8 -222
- machineconfig/scripts/python/ftpx.py +7 -200
- machineconfig/scripts/python/graph/cli_graph.json +8743 -0
- machineconfig/scripts/python/{env_manager → helper_env}/path_manager_tui.py +2 -2
- machineconfig/scripts/python/helpers/helper_env/env_manager_tui.py +204 -0
- machineconfig/scripts/python/helpers/helper_env/path_manager_tui.py +228 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/agentic_frameworks/fire_crush.json +1 -1
- machineconfig/scripts/python/helpers/helpers_agents/agentic_frameworks/fire_crush.py +39 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/agentic_frameworks/fire_cursor_agents.py +3 -4
- machineconfig/scripts/python/helpers/helpers_agents/agentic_frameworks/fire_gemini.py +55 -0
- machineconfig/scripts/python/helpers/helpers_agents/agentic_frameworks/fire_qwen.py +30 -0
- machineconfig/scripts/python/helpers/helpers_agents/agents_impl.py +168 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/fire_agents_help_launch.py +38 -16
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/fire_agents_helper_types.py +11 -14
- machineconfig/scripts/python/helpers/helpers_agents/privacy/configs/aichat/config.yaml +5 -0
- machineconfig/scripts/python/helpers/helpers_agents/privacy/configs/aider/.aider.conf.yml +2 -0
- machineconfig/scripts/python/helpers/helpers_agents/privacy/configs/copilot/config.yml +1 -0
- machineconfig/scripts/python/helpers/helpers_agents/privacy/configs/crush/crush.json +10 -0
- machineconfig/scripts/python/helpers/helpers_agents/privacy/configs/gemini/settings.json +12 -0
- machineconfig/scripts/python/helpers/helpers_agents/privacy/privacy.py +109 -0
- machineconfig/scripts/python/helpers/helpers_agents/templates/prompt.txt +10 -0
- machineconfig/scripts/python/helpers/helpers_agents/templates/template.sh +34 -0
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_copy.py +32 -25
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_mount.py +29 -22
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_sync.py +9 -8
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/helpers2.py +1 -1
- machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/crosh.py +3 -3
- machineconfig/scripts/python/helpers/helpers_croshell/croshell_impl.py +225 -0
- machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/scheduler.py +4 -4
- machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/start_slidev.py +12 -12
- machineconfig/scripts/python/helpers/helpers_devops/backup_config.py +149 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_backup_retrieve.py +262 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_config.py +98 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_config_dotfile.py +274 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_data.py +67 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_nw.py +201 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_repos.py +274 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_self.py +197 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_share_file.py +151 -0
- machineconfig/scripts/python/helpers/helpers_devops/cli_share_server.py +125 -0
- machineconfig/scripts/python/{helpers_devops/cli_terminal.py → helpers/helpers_devops/cli_share_terminal.py} +26 -22
- machineconfig/scripts/python/helpers/helpers_devops/cli_ssh.py +167 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/devops_status.py +17 -23
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/devops_update_repos.py +1 -1
- machineconfig/scripts/python/{interactive.py → helpers/helpers_devops/interactive.py} +78 -71
- machineconfig/scripts/python/helpers/helpers_devops/run_script.py +197 -0
- machineconfig/scripts/python/helpers/helpers_devops/themes/choose_starship_theme.ps1 +41 -0
- machineconfig/scripts/python/helpers/helpers_devops/themes/choose_starship_theme.sh +48 -0
- machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/themes/choose_wezterm_theme.py +4 -4
- machineconfig/scripts/python/{helpers_fire/helpers4.py → helpers/helpers_fire_command/file_wrangler.py} +57 -20
- machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/fire_jobs_args_helper.py +1 -0
- machineconfig/scripts/python/helpers/helpers_fire_command/fire_jobs_impl.py +233 -0
- machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/fire_jobs_route_helper.py +26 -16
- machineconfig/scripts/python/helpers/helpers_msearch/__init__.py +5 -0
- machineconfig/scripts/python/helpers/helpers_msearch/msearch_impl.py +248 -0
- machineconfig/scripts/{linux → python/helpers/helpers_msearch/scripts_linux}/fzfg +6 -5
- machineconfig/scripts/python/helpers/helpers_msearch/scripts_linux/search_with_context.sh +48 -0
- machineconfig/scripts/python/helpers/helpers_msearch/scripts_windows/fzfg.ps1 +59 -0
- machineconfig/scripts/python/helpers/helpers_navigator/__init__.py +20 -0
- machineconfig/scripts/python/helpers/helpers_navigator/cli_graph_loader.py +234 -0
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/command_builder.py +61 -13
- machineconfig/scripts/python/helpers/helpers_navigator/command_detail.py +153 -0
- machineconfig/scripts/python/helpers/helpers_navigator/command_tree.py +45 -0
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/data_models.py +18 -11
- machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/main_app.py +5 -5
- machineconfig/scripts/python/helpers/helpers_network/address.py +174 -0
- machineconfig/scripts/python/helpers/helpers_network/address_switch.py +78 -0
- machineconfig/scripts/python/helpers/helpers_network/ftpx_impl.py +276 -0
- machineconfig/scripts/python/{nw → helpers/helpers_network}/mount_nfs.py +2 -2
- machineconfig/scripts/python/{nw → helpers/helpers_network}/mount_ssh.py +3 -3
- machineconfig/scripts/python/helpers/helpers_network/ssh_add_identity.py +73 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_add_ssh_key.py +175 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_debug_linux.py +319 -0
- machineconfig/scripts/python/helpers/helpers_network/ssh_debug_windows.py +275 -0
- machineconfig/scripts/python/{nw → helpers/helpers_network}/wifi_conn.py +1 -53
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/action.py +3 -3
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/action_helper.py +3 -3
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/clone.py +0 -1
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/cloud_repo_sync.py +159 -48
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/grource.py +4 -3
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/record.py +33 -12
- machineconfig/scripts/python/helpers/helpers_repos/repo_analyzer_1.py +160 -0
- machineconfig/scripts/python/{helpers_repos/count_lines.py → helpers/helpers_repos/repo_analyzer_2.py} +156 -191
- machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/update.py +0 -6
- machineconfig/scripts/python/helpers/helpers_search/ast_search.py +74 -0
- machineconfig/scripts/python/helpers/helpers_search/qr_code.py +166 -0
- machineconfig/scripts/python/helpers/helpers_search/repo_rag.py +325 -0
- machineconfig/scripts/python/helpers/helpers_search/script_help.py +81 -0
- machineconfig/scripts/python/helpers/helpers_search/symantic_search.py +25 -0
- machineconfig/scripts/python/helpers/helpers_sessions/__init__.py +0 -0
- machineconfig/scripts/python/helpers/helpers_sessions/sessions_impl.py +186 -0
- machineconfig/scripts/python/{helpers_sessions → helpers/helpers_sessions}/sessions_multiprocess.py +20 -14
- machineconfig/scripts/python/helpers/helpers_terminal/__init__.py +0 -0
- machineconfig/scripts/python/helpers/helpers_terminal/terminal_impl.py +96 -0
- machineconfig/scripts/python/helpers/helpers_utils/download.py +150 -0
- machineconfig/scripts/python/helpers/helpers_utils/pdf.py +96 -0
- machineconfig/scripts/python/helpers/helpers_utils/python.py +210 -0
- machineconfig/scripts/python/helpers/helpers_utils/specs.py +246 -0
- machineconfig/scripts/python/mcfg_entry.py +143 -0
- machineconfig/scripts/python/msearch.py +26 -0
- machineconfig/scripts/python/sessions.py +69 -135
- machineconfig/scripts/python/terminal.py +58 -0
- machineconfig/scripts/python/utils.py +115 -38
- machineconfig/scripts/windows/wrap_mcfg.ps1 +63 -0
- machineconfig/settings/atuin/config.toml +294 -0
- machineconfig/settings/atuin/themes/catppuccin-mocha-mauve.toml +12 -0
- machineconfig/settings/broot/conf.toml +1 -1
- machineconfig/settings/helix/config.toml +16 -0
- machineconfig/settings/helix/languages.toml +13 -4
- machineconfig/settings/helix/yazi-picker.sh +12 -0
- machineconfig/settings/lf/linux/exe/lfcd.sh +1 -0
- machineconfig/settings/lf/linux/exe/previewer.sh +3 -2
- machineconfig/settings/lf/windows/lfcd.ps1 +1 -1
- machineconfig/settings/lf/windows/lfrc +14 -16
- machineconfig/settings/linters/.ruff.toml +2 -1
- machineconfig/settings/marimo/marimo.toml +1 -1
- machineconfig/settings/marimo/snippets/globalize.py +34 -0
- machineconfig/settings/mprocs/windows/mprocs.yaml +2 -2
- machineconfig/settings/shells/bash/init.sh +47 -12
- machineconfig/settings/shells/ipy/profiles/default/startup/playext.py +1 -1
- machineconfig/settings/shells/nushell/config.nu +25 -33
- machineconfig/settings/shells/nushell/env.nu +21 -8
- machineconfig/settings/shells/nushell/init.nu +138 -0
- machineconfig/settings/shells/pwsh/init.ps1 +111 -17
- machineconfig/settings/shells/pwsh/search_pwsh_history.ps1 +99 -0
- machineconfig/settings/shells/starship/starship.toml +16 -0
- machineconfig/settings/shells/wezterm/wezterm.lua +6 -1
- machineconfig/settings/shells/wt/settings.json +27 -18
- machineconfig/settings/shells/zsh/init.sh +42 -23
- machineconfig/settings/television/cable_unix/alias.toml +8 -0
- machineconfig/settings/television/cable_unix/aws-buckets.toml +14 -0
- machineconfig/settings/television/cable_unix/aws-instances.toml +13 -0
- machineconfig/settings/television/cable_unix/bash-history.toml +8 -0
- machineconfig/settings/television/cable_unix/channels.toml +19 -0
- machineconfig/settings/television/cable_unix/dirs.toml +13 -0
- machineconfig/settings/television/cable_unix/distrobox-list.toml +42 -0
- machineconfig/settings/television/cable_unix/docker-images.toml +13 -0
- machineconfig/settings/television/cable_unix/dotfiles.toml +11 -0
- machineconfig/settings/television/cable_unix/env.toml +17 -0
- machineconfig/settings/television/cable_unix/files.toml +11 -0
- machineconfig/settings/television/cable_unix/fish-history.toml +8 -0
- machineconfig/settings/television/cable_unix/git-branch.toml +11 -0
- machineconfig/settings/television/cable_unix/git-diff.toml +10 -0
- machineconfig/settings/television/cable_unix/git-log.toml +12 -0
- machineconfig/settings/television/cable_unix/git-reflog.toml +12 -0
- machineconfig/settings/television/cable_unix/git-repos.toml +16 -0
- machineconfig/settings/television/cable_unix/guix.toml +20 -0
- machineconfig/settings/television/cable_unix/just-recipes.toml +18 -0
- machineconfig/settings/television/cable_unix/k8s-deployments.toml +36 -0
- machineconfig/settings/television/cable_unix/k8s-pods.toml +50 -0
- machineconfig/settings/television/cable_unix/k8s-services.toml +36 -0
- machineconfig/settings/television/cable_unix/man-pages.toml +24 -0
- machineconfig/settings/television/cable_unix/nu-history.toml +7 -0
- machineconfig/settings/television/cable_unix/procs.toml +20 -0
- machineconfig/settings/television/cable_unix/text.toml +17 -0
- machineconfig/settings/television/cable_unix/tldr.toml +18 -0
- machineconfig/settings/television/cable_unix/zsh-history.toml +9 -0
- machineconfig/settings/television/cable_windows/alias.toml +7 -0
- machineconfig/settings/television/cable_windows/dirs.toml +13 -0
- machineconfig/settings/television/cable_windows/docker-images.toml +13 -0
- machineconfig/settings/television/cable_windows/dotfiles.toml +11 -0
- machineconfig/settings/television/cable_windows/env.toml +17 -0
- machineconfig/settings/television/cable_windows/files.toml +14 -0
- machineconfig/settings/television/cable_windows/git-branch.toml +11 -0
- machineconfig/settings/television/cable_windows/git-diff.toml +10 -0
- machineconfig/settings/television/cable_windows/git-log.toml +11 -0
- machineconfig/settings/television/cable_windows/git-reflog.toml +11 -0
- machineconfig/settings/television/cable_windows/git-repos.toml +15 -0
- machineconfig/settings/television/cable_windows/nu-history.toml +7 -0
- machineconfig/settings/television/cable_windows/pwsh-history.toml +6 -0
- machineconfig/settings/television/cable_windows/text.toml +17 -0
- machineconfig/settings/tv/config.toml +234 -0
- machineconfig/settings/tv/themes/catppuccin-mocha-sky.toml +22 -0
- machineconfig/settings/wsl/.wslconfig +5 -30
- machineconfig/settings/wt/__init__.py +0 -0
- machineconfig/settings/yazi/init.lua +61 -0
- machineconfig/settings/yazi/keymap_linux.toml +94 -0
- machineconfig/settings/yazi/keymap_windows.toml +78 -0
- machineconfig/settings/yazi/shell/yazi_cd.ps1 +33 -0
- machineconfig/settings/yazi/shell/yazi_cd.sh +8 -0
- machineconfig/settings/yazi/theme.toml +4 -0
- machineconfig/settings/yazi/yazi_linux.toml +94 -0
- machineconfig/settings/yazi/yazi_windows.toml +58 -0
- machineconfig/settings/zellij/layouts/st.kdl +40 -9
- machineconfig/settings/zellij/layouts/st2.kdl +1 -1
- machineconfig/setup_linux/__init__.py +2 -2
- machineconfig/setup_linux/apps_desktop.sh +8 -27
- machineconfig/setup_linux/web_shortcuts/interactive.sh +27 -12
- machineconfig/setup_linux/web_shortcuts/live_from_github.sh +34 -0
- machineconfig/setup_mac/__init__.py +1 -4
- machineconfig/setup_mac/apps_gui.sh +248 -0
- machineconfig/setup_windows/__init__.py +2 -5
- machineconfig/setup_windows/uv.ps1 +8 -1
- machineconfig/setup_windows/web_shortcuts/interactive.ps1 +28 -12
- machineconfig/setup_windows/web_shortcuts/live_from_github.ps1 +31 -0
- machineconfig/setup_windows/web_shortcuts/quick_init.ps1 +17 -0
- machineconfig/type_hinting/sql/__init__.py +1 -0
- machineconfig/type_hinting/sql/base.py +216 -0
- machineconfig/type_hinting/sql/core_schema.py +64 -0
- machineconfig/type_hinting/sql/core_schema_typeddict.py +41 -0
- machineconfig/type_hinting/sql/typeddict_codegen.py +222 -0
- machineconfig/type_hinting/typedict/__init__.py +1 -0
- machineconfig/type_hinting/typedict/ast_utils.py +130 -0
- machineconfig/type_hinting/typedict/generator_helpers.py +319 -0
- machineconfig/type_hinting/typedict/generators.py +231 -0
- machineconfig/type_hinting/typedict/polars_schema.py +24 -0
- machineconfig/type_hinting/typedict/polars_schema_typeddict.py +63 -0
- machineconfig/utils/accessories.py +31 -4
- machineconfig/utils/code.py +163 -51
- machineconfig/utils/files/ascii_art.py +11 -15
- machineconfig/utils/files/headers.py +6 -7
- machineconfig/utils/files/read.py +8 -1
- machineconfig/utils/installer_utils/github_release_bulk.py +95 -138
- machineconfig/utils/installer_utils/github_release_scraper.py +99 -0
- machineconfig/utils/installer_utils/install_from_url.py +183 -0
- machineconfig/utils/installer_utils/installer_class.py +53 -102
- machineconfig/utils/installer_utils/installer_cli.py +161 -0
- machineconfig/utils/installer_utils/installer_helper.py +129 -0
- machineconfig/utils/installer_utils/{installer_abc.py → installer_locator_utils.py} +42 -91
- machineconfig/utils/{installer.py → installer_utils/installer_runner.py} +20 -65
- machineconfig/utils/io.py +94 -9
- machineconfig/utils/links.py +56 -38
- machineconfig/utils/meta.py +38 -21
- machineconfig/utils/options.py +81 -23
- machineconfig/utils/options_utils/__init__.py +0 -0
- machineconfig/utils/options_utils/options_tv_linux.py +211 -0
- machineconfig/utils/options_utils/options_tv_windows.py +88 -0
- machineconfig/utils/options_utils/tv_options.py +37 -0
- machineconfig/utils/path_extended.py +52 -102
- machineconfig/utils/path_helper.py +76 -23
- machineconfig/utils/procs.py +1 -1
- machineconfig/utils/scheduler.py +26 -53
- machineconfig/utils/scheduling.py +0 -2
- machineconfig/utils/schemas/fire_agents/fire_agents_input.py +1 -1
- machineconfig/utils/schemas/layouts/layout_types.py +1 -1
- machineconfig/utils/source_of_truth.py +6 -1
- machineconfig/utils/ssh.py +216 -419
- machineconfig/utils/ssh_utils/abc.py +5 -0
- machineconfig/utils/ssh_utils/copy_from_here.py +116 -0
- machineconfig/utils/ssh_utils/copy_to_here.py +303 -0
- machineconfig/utils/ssh_utils/utils.py +158 -0
- machineconfig/utils/ssh_utils/wsl.py +147 -0
- machineconfig/utils/ssh_utils/wsl_helper.py +217 -0
- machineconfig/utils/terminal.py +1 -0
- machineconfig/utils/upgrade_packages.py +107 -35
- machineconfig/utils/ve.py +12 -4
- machineconfig-8.51.dist-info/METADATA +140 -0
- machineconfig-8.51.dist-info/RECORD +543 -0
- {machineconfig-6.82.dist-info → machineconfig-8.51.dist-info}/entry_points.txt +4 -1
- machineconfig/jobs/installer/check_installations.py +0 -248
- machineconfig/jobs/installer/custom/hx.py +0 -140
- machineconfig/jobs/installer/linux_scripts/pgsql.sh +0 -41
- machineconfig/jobs/installer/linux_scripts/timescaledb.sh +0 -71
- machineconfig/jobs/installer/powershell_scripts/archive_pygraphviz.ps1 +0 -12
- machineconfig/jobs/installer/powershell_scripts/openssh-server_add_key.ps1 +0 -7
- machineconfig/jobs/installer/powershell_scripts/openssh-server_copy-ssh-id.ps1 +0 -14
- machineconfig/profile/backup.toml +0 -49
- machineconfig/profile/mapper.toml +0 -256
- machineconfig/scripts/linux/fzf2g +0 -21
- machineconfig/scripts/linux/fzfag +0 -17
- machineconfig/scripts/linux/fzffg +0 -25
- machineconfig/scripts/linux/fzfrga +0 -21
- machineconfig/scripts/linux/mcfgs +0 -38
- machineconfig/scripts/linux/other/share_smb +0 -1
- machineconfig/scripts/linux/other/switch_ip +0 -20
- machineconfig/scripts/linux/skrg +0 -4
- machineconfig/scripts/linux/warp-cli.sh +0 -122
- machineconfig/scripts/linux/z_ls +0 -104
- machineconfig/scripts/python/ai/command_runner/prompt.txt +0 -9
- machineconfig/scripts/python/helpers_devops/cli_config.py +0 -120
- machineconfig/scripts/python/helpers_devops/cli_config_dotfile.py +0 -77
- machineconfig/scripts/python/helpers_devops/cli_data.py +0 -25
- machineconfig/scripts/python/helpers_devops/cli_nw.py +0 -73
- machineconfig/scripts/python/helpers_devops/cli_repos.py +0 -181
- machineconfig/scripts/python/helpers_devops/cli_self.py +0 -122
- machineconfig/scripts/python/helpers_devops/cli_share_server.py +0 -104
- machineconfig/scripts/python/helpers_devops/cli_utils.py +0 -221
- machineconfig/scripts/python/helpers_devops/devops_backup_retrieve.py +0 -80
- machineconfig/scripts/python/helpers_devops/themes/choose_starship_theme.bash +0 -3
- machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_crush.py +0 -37
- machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_gemini.py +0 -44
- machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_qwen.py +0 -43
- machineconfig/scripts/python/helpers_fire/prompt.txt +0 -2
- machineconfig/scripts/python/helpers_fire/template.sh +0 -15
- machineconfig/scripts/python/helpers_navigator/__init__.py +0 -20
- machineconfig/scripts/python/helpers_navigator/command_detail.py +0 -44
- machineconfig/scripts/python/helpers_navigator/command_tree.py +0 -588
- machineconfig/scripts/python/helpers_repos/count_lines_frontend.py +0 -17
- machineconfig/scripts/python/helpers_repos/entrypoint.py +0 -76
- machineconfig/scripts/python/helpers_repos/secure_repo.py +0 -15
- machineconfig/scripts/python/mcfg.py +0 -48
- machineconfig/scripts/python/nw/add_ssh_key.py +0 -148
- machineconfig/scripts/python/nw/devops_add_identity.py +0 -82
- machineconfig/scripts/python/nw/devops_add_ssh_key.py +0 -134
- machineconfig/scripts/python/nw/ssh_debug_linux.py +0 -391
- machineconfig/scripts/python/nw/ssh_debug_windows.py +0 -338
- machineconfig/scripts/python/nw/wsl_windows_transfer.py +0 -66
- machineconfig/scripts/windows/fzfb.ps1 +0 -3
- machineconfig/scripts/windows/fzfg.ps1 +0 -2
- machineconfig/scripts/windows/fzfrga.bat +0 -20
- machineconfig/scripts/windows/mcfgs.ps1 +0 -17
- machineconfig/scripts/windows/mounts/mount_ssh.ps1 +0 -13
- machineconfig/settings/lf/linux/exe/fzf_nano.sh +0 -16
- machineconfig/settings/lf/windows/fzf_edit.ps1 +0 -6
- machineconfig/settings/lf/windows/tst.ps1 +0 -1
- machineconfig/settings/yazi/yazi.toml +0 -4
- machineconfig/setup_linux/apps.sh +0 -66
- machineconfig/setup_linux/others/cli_installation.sh +0 -137
- machineconfig/setup_linux/others/mint_keyboard_shortcuts.sh +0 -30
- machineconfig/setup_linux/ssh/openssh_all.sh +0 -25
- machineconfig/setup_linux/ssh/openssh_wsl.sh +0 -38
- machineconfig/setup_mac/apps.sh +0 -73
- machineconfig/setup_mac/ssh/openssh_setup.sh +0 -114
- machineconfig/setup_windows/apps.ps1 +0 -62
- machineconfig/setup_windows/others/obs.ps1 +0 -4
- machineconfig/setup_windows/ssh/add-sshkey.ps1 +0 -29
- machineconfig/setup_windows/ssh/add_identity.ps1 +0 -11
- machineconfig/setup_windows/ssh/openssh-server.ps1 +0 -37
- machineconfig/utils/installer_utils/installer.py +0 -225
- machineconfig/utils/tst.py +0 -20
- machineconfig-6.82.dist-info/METADATA +0 -82
- machineconfig-6.82.dist-info/RECORD +0 -441
- machineconfig/jobs/installer/{custom_dev → checks}/__init__.py +0 -0
- machineconfig/jobs/installer/linux_scripts/{warp-cli.sh → cloudflare_warp_cli.sh} +0 -0
- machineconfig/{scripts/python/helpers_cloud → jobs/installer/python_scripts}/__init__.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/alacritty.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/bypass_paywall.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/cursor.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/espanso.py +0 -0
- machineconfig/jobs/installer/{custom → python_scripts}/gh.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/goes.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/lvim.py +0 -0
- machineconfig/jobs/installer/{custom_dev → python_scripts}/redis.py +0 -0
- machineconfig/{setup_linux/others → jobs/scripts/bash_scripts}/android.sh +0 -0
- machineconfig/jobs/{installer/linux_scripts → scripts/bash_scripts}/lid.sh +0 -0
- machineconfig/{scripts/python/nw → jobs/scripts/bash_scripts}/mount_drive +0 -0
- machineconfig/{scripts/python/nw → jobs/scripts/bash_scripts}/mount_nw_drive +0 -0
- machineconfig/{scripts/python/nw → jobs/scripts/bash_scripts}/mount_smb +0 -0
- machineconfig/{scripts/linux/other → jobs/scripts/bash_scripts}/share_cloud.sh +0 -0
- machineconfig/{scripts/linux/other → jobs/scripts/bash_scripts}/share_nfs +0 -0
- machineconfig/{scripts/linux/other → jobs/scripts/bash_scripts}/start_docker +0 -0
- machineconfig/{scripts → jobs/scripts/powershell_scripts}/Restore-ThunderbirdProfile.ps1 +0 -0
- machineconfig/{setup_windows/others → jobs/scripts/powershell_scripts}/docker.ps1 +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/mount_nfs.ps1 +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/mount_nw.ps1 +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/mount_smb.ps1 +0 -0
- machineconfig/{setup_windows/others → jobs/scripts/powershell_scripts}/power_options.ps1 +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/share_cloud.cmd +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/share_smb.ps1 +0 -0
- machineconfig/{scripts/windows/mounts → jobs/scripts/powershell_scripts}/unlock_bitlocker.ps1 +0 -0
- machineconfig/scripts/python/{helpers_croshell → ai/utils}/__init__.py +0 -0
- machineconfig/scripts/python/ai/{solutions/_shared.py → utils/shared.py} +0 -0
- machineconfig/scripts/python/{helpers_devops → graph}/__init__.py +0 -0
- machineconfig/scripts/python/{helpers_devops/themes → helpers}/__init__.py +0 -0
- machineconfig/scripts/python/{env_manager → helpers/helper_env}/__init__.py +0 -0
- machineconfig/scripts/python/{env_manager → helpers/helper_env}/path_manager_backend.py +0 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/__init__.py +0 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/agentic_frameworks/__init__.py +0 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/fire_agents_help_search.py +0 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents}/fire_agents_load_balancer.py +0 -0
- machineconfig/scripts/python/{helpers_fire → helpers/helpers_agents/templates}/template.ps1 +0 -0
- machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_cloud}/__init__.py +0 -0
- machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/cloud_helpers.py +1 -1
- /machineconfig/scripts/python/{helpers_cloud → helpers/helpers_cloud}/helpers5.py +0 -0
- /machineconfig/scripts/python/{helpers_sessions → helpers/helpers_croshell}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/pomodoro.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/viewer.py +0 -0
- /machineconfig/scripts/python/{helpers_croshell → helpers/helpers_croshell}/viewer_template.py +0 -0
- /machineconfig/scripts/python/{nw → helpers/helpers_devops}/__init__.py +0 -0
- /machineconfig/{setup_windows/wt_and_pwsh → scripts/python/helpers/helpers_devops/themes}/__init__.py +0 -0
- /machineconfig/scripts/python/{helpers_devops → helpers/helpers_devops}/themes/choose_pwsh_theme.ps1 +0 -0
- /machineconfig/scripts/python/{helpers_devops/themes/choose_starship_theme.ps1 → helpers/helpers_fire_command/__init__.py} +0 -0
- /machineconfig/scripts/python/{helpers_fire_command → helpers/helpers_fire_command}/cloud_manager.py +0 -0
- /machineconfig/scripts/python/{helpers_fire_command/fire_jobs_streamlit_helper.py → helpers/helpers_fire_command/f.py} +0 -0
- /machineconfig/{settings/shells/pwsh/profile.ps1 → scripts/python/helpers/helpers_fire_command/fire_jobs_streamlit_helper.py} +0 -0
- /machineconfig/scripts/python/{helpers_navigator → helpers/helpers_navigator}/search_bar.py +0 -0
- /machineconfig/{settings/yazi/keymap.toml → scripts/python/helpers/helpers_network/__init__.py} +0 -0
- /machineconfig/scripts/python/{nw → helpers/helpers_network}/mount_nw_drive.py +0 -0
- /machineconfig/scripts/python/{nw → helpers/helpers_network}/onetimeshare.py +0 -0
- /machineconfig/scripts/python/{helpers_repos → helpers/helpers_repos}/sync.py +0 -0
- /machineconfig/{setup_windows/wt_and_pwsh → settings/wt}/set_wt_settings.py +0 -0
- {machineconfig-6.82.dist-info → machineconfig-8.51.dist-info}/WHEEL +0 -0
- {machineconfig-6.82.dist-info → machineconfig-8.51.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
from platform import system
|
|
4
|
+
from pathlib import Path
|
|
5
|
+
from rich.console import Console
|
|
6
|
+
from rich.panel import Panel
|
|
7
|
+
from rich.table import Table
|
|
8
|
+
from rich import box
|
|
9
|
+
import subprocess
|
|
10
|
+
import os
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
console = Console()
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
def _run_ps(cmd: str) -> tuple[bool, str]:
|
|
17
|
+
result = subprocess.run(["powershell", "-Command", cmd], capture_output=True, text=True, check=False)
|
|
18
|
+
return result.returncode == 0, result.stdout.strip()
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
def _check_sshd_binary_exists() -> tuple[bool, str]:
|
|
22
|
+
sshd_locations = [
|
|
23
|
+
Path("C:/Windows/System32/OpenSSH/sshd.exe"),
|
|
24
|
+
Path("C:/Program Files/OpenSSH/sshd.exe"),
|
|
25
|
+
Path("C:/Program Files (x86)/OpenSSH/sshd.exe"),
|
|
26
|
+
]
|
|
27
|
+
for loc in sshd_locations:
|
|
28
|
+
if loc.exists():
|
|
29
|
+
return True, str(loc)
|
|
30
|
+
ok, which_out = _run_ps("Get-Command sshd -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Source")
|
|
31
|
+
if ok and which_out:
|
|
32
|
+
return True, which_out
|
|
33
|
+
return False, ""
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
def _detect_openssh() -> tuple[str, Path | None, Path | None]:
|
|
37
|
+
capability_sshd = Path("C:/Windows/System32/OpenSSH/sshd.exe")
|
|
38
|
+
winget_sshd = Path("C:/Program Files/OpenSSH/sshd.exe")
|
|
39
|
+
programdata_config = Path("C:/ProgramData/ssh")
|
|
40
|
+
capability_config = Path("C:/ProgramData/ssh")
|
|
41
|
+
if capability_sshd.exists():
|
|
42
|
+
return ("capability", capability_sshd, capability_config)
|
|
43
|
+
if winget_sshd.exists():
|
|
44
|
+
return ("winget", winget_sshd, programdata_config)
|
|
45
|
+
return ("not_found", None, None)
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
def ssh_debug_windows() -> dict[str, dict[str, str | bool]]:
|
|
49
|
+
if system() != "Windows":
|
|
50
|
+
raise NotImplementedError("ssh_debug_windows is only supported on Windows")
|
|
51
|
+
|
|
52
|
+
results: dict[str, dict[str, str | bool]] = {}
|
|
53
|
+
issues: list[tuple[str, str, str]] = []
|
|
54
|
+
current_user = os.environ.get("USERNAME", "unknown")
|
|
55
|
+
ssh_port = "22"
|
|
56
|
+
ip_addresses: list[str] = []
|
|
57
|
+
|
|
58
|
+
sshd_exists, sshd_path = _check_sshd_binary_exists()
|
|
59
|
+
install_type, _sshd_exe, config_dir = _detect_openssh()
|
|
60
|
+
ok, hostname = _run_ps("hostname")
|
|
61
|
+
hostname = hostname if ok else "unknown"
|
|
62
|
+
|
|
63
|
+
install_info: list[str] = []
|
|
64
|
+
if not sshd_exists:
|
|
65
|
+
results["installation"] = {"status": "error", "message": "sshd.exe not found on system"}
|
|
66
|
+
issues.append(("sshd.exe not found", "OpenSSH Server binary missing entirely", "Add-WindowsCapability -Online -Name OpenSSH.Server~~~~0.0.1.0"))
|
|
67
|
+
install_info.append("❌ sshd.exe: [red]NOT FOUND[/red]")
|
|
68
|
+
install_info.append(" [dim]OpenSSH Server is not installed on this system[/dim]")
|
|
69
|
+
elif install_type == "not_found":
|
|
70
|
+
results["installation"] = {"status": "warning", "message": f"sshd found at {sshd_path} but not in standard location"}
|
|
71
|
+
install_info.append(f"⚠️ sshd.exe: found at [yellow]{sshd_path}[/yellow]")
|
|
72
|
+
install_info.append(" [dim]Non-standard location - may need manual configuration[/dim]")
|
|
73
|
+
else:
|
|
74
|
+
results["installation"] = {"status": "ok", "message": f"OpenSSH installed ({install_type})"}
|
|
75
|
+
install_info.append(f"✅ OpenSSH Server: installed via {'Windows Capability' if install_type == 'capability' else 'winget'}")
|
|
76
|
+
install_info.append(f" Binary: {sshd_path}")
|
|
77
|
+
install_info.append(f" Config: {config_dir}")
|
|
78
|
+
|
|
79
|
+
ok, status = _run_ps("Get-Service -Name sshd -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Status")
|
|
80
|
+
if not ok or not status:
|
|
81
|
+
results["ssh_service"] = {"status": "error", "message": "sshd service not found"}
|
|
82
|
+
issues.append(("sshd service missing", "SSH daemon not installed", "Install OpenSSH Server first"))
|
|
83
|
+
install_info.append("❌ sshd service: [red]NOT FOUND[/red]")
|
|
84
|
+
elif status != "Running":
|
|
85
|
+
results["ssh_service"] = {"status": "error", "message": f"sshd is {status}"}
|
|
86
|
+
issues.append((f"sshd is {status}", "SSH connections will be refused", "Start-Service sshd ; Set-Service sshd -StartupType Automatic"))
|
|
87
|
+
install_info.append(f"❌ sshd service: [yellow]{status}[/yellow]")
|
|
88
|
+
else:
|
|
89
|
+
results["ssh_service"] = {"status": "ok", "message": "sshd running"}
|
|
90
|
+
ok, startup = _run_ps("Get-Service -Name sshd | Select-Object -ExpandProperty StartType")
|
|
91
|
+
startup_note = f" (startup: {startup})" if ok else ""
|
|
92
|
+
install_info.append(f"✅ sshd service: [green]Running[/green]{startup_note}")
|
|
93
|
+
|
|
94
|
+
console.print(Panel("\n".join(install_info), title="[bold]Installation & Service[/bold]", border_style="blue"))
|
|
95
|
+
|
|
96
|
+
ssh_dir = Path.home().joinpath(".ssh")
|
|
97
|
+
authorized_keys = ssh_dir.joinpath("authorized_keys")
|
|
98
|
+
admin_auth_keys = Path("C:/ProgramData/ssh/administrators_authorized_keys")
|
|
99
|
+
perm_info: list[str] = []
|
|
100
|
+
|
|
101
|
+
ok, is_admin_str = _run_ps("([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)")
|
|
102
|
+
is_admin = "True" in is_admin_str
|
|
103
|
+
|
|
104
|
+
if is_admin:
|
|
105
|
+
perm_info.append(f"👤 User [cyan]{current_user}[/cyan] is an [yellow]Administrator[/yellow]")
|
|
106
|
+
perm_info.append(" ➜ Keys must be in: [cyan]C:\\ProgramData\\ssh\\administrators_authorized_keys[/cyan]")
|
|
107
|
+
target_auth_keys = admin_auth_keys
|
|
108
|
+
else:
|
|
109
|
+
perm_info.append(f"👤 User [cyan]{current_user}[/cyan] is a standard user")
|
|
110
|
+
perm_info.append(f" ➜ Keys should be in: [cyan]{authorized_keys}[/cyan]")
|
|
111
|
+
target_auth_keys = authorized_keys
|
|
112
|
+
|
|
113
|
+
if not target_auth_keys.exists():
|
|
114
|
+
results["authorized_keys"] = {"status": "error", "message": f"{target_auth_keys.name} missing"}
|
|
115
|
+
issues.append((f"{target_auth_keys.name} missing", "No public keys authorized - SSH login will fail", f"Create file and add your public key to {target_auth_keys}"))
|
|
116
|
+
perm_info.append(f"\n❌ [red]{target_auth_keys.name} does not exist[/red]")
|
|
117
|
+
perm_info.append(" [dim]No keys = no login. Add your public key to this file.[/dim]")
|
|
118
|
+
else:
|
|
119
|
+
try:
|
|
120
|
+
keys = [line for line in target_auth_keys.read_text(encoding="utf-8").split("\n") if line.strip()]
|
|
121
|
+
results["authorized_keys"] = {"status": "ok", "message": f"{len(keys)} key(s)"}
|
|
122
|
+
perm_info.append(f"\n✅ {target_auth_keys.name}: [green]{len(keys)} key(s)[/green]")
|
|
123
|
+
except Exception as e:
|
|
124
|
+
perm_info.append(f"\n⚠️ Could not read {target_auth_keys.name}: {e}")
|
|
125
|
+
|
|
126
|
+
if is_admin and admin_auth_keys.exists():
|
|
127
|
+
ok, icacls_out = _run_ps(f'icacls "{admin_auth_keys}"')
|
|
128
|
+
if ok:
|
|
129
|
+
needs_fix = "BUILTIN\\Users" in icacls_out or "Everyone" in icacls_out
|
|
130
|
+
if needs_fix:
|
|
131
|
+
results["admin_keys_perms"] = {"status": "error", "message": "Permissions too open"}
|
|
132
|
+
issues.append(("administrators_authorized_keys permissions wrong", "sshd ignores file if permissions allow other users", f'icacls "{admin_auth_keys}" /inheritance:r /grant "Administrators:F" /grant "SYSTEM:F"'))
|
|
133
|
+
perm_info.append("❌ [red]Permissions too open[/red] - sshd will ignore this file!")
|
|
134
|
+
else:
|
|
135
|
+
perm_info.append("✅ Permissions: restricted to Administrators/SYSTEM")
|
|
136
|
+
|
|
137
|
+
console.print(Panel("\n".join(perm_info), title="[bold]Keys & Permissions[/bold]", border_style="blue"))
|
|
138
|
+
|
|
139
|
+
net_info: list[str] = []
|
|
140
|
+
ok, ip_out = _run_ps("Get-NetIPAddress -AddressFamily IPv4 -PrefixOrigin Dhcp,Manual | Where-Object {$_.IPAddress -notlike '127.*' -and $_.IPAddress -notlike '169.254.*'} | Select-Object -ExpandProperty IPAddress")
|
|
141
|
+
if ok and ip_out:
|
|
142
|
+
ip_addresses = [ip.strip() for ip in ip_out.split("\n") if ip.strip()]
|
|
143
|
+
net_info.append(f"🌐 IP addresses: [cyan]{', '.join(ip_addresses)}[/cyan]")
|
|
144
|
+
|
|
145
|
+
sshd_config: Path | None = config_dir.joinpath("sshd_config") if config_dir else None
|
|
146
|
+
config_text: str | None = None
|
|
147
|
+
if sshd_config and sshd_config.exists():
|
|
148
|
+
try:
|
|
149
|
+
config_text = sshd_config.read_text(encoding="utf-8")
|
|
150
|
+
except PermissionError:
|
|
151
|
+
ok, config_text_ps = _run_ps(f'Get-Content "{sshd_config}" -Raw')
|
|
152
|
+
config_text = config_text_ps if ok and config_text_ps else None
|
|
153
|
+
except Exception:
|
|
154
|
+
config_text = None
|
|
155
|
+
if config_text:
|
|
156
|
+
port_lines = [line for line in config_text.split("\n") if line.strip().startswith("Port") and not line.strip().startswith("#")]
|
|
157
|
+
if port_lines:
|
|
158
|
+
ssh_port = port_lines[0].split()[1]
|
|
159
|
+
|
|
160
|
+
auth_info: list[str] = []
|
|
161
|
+
auth_info.append(f"📄 Config file: [cyan]{sshd_config}[/cyan]" if sshd_config else "📄 Config file: [red]not found[/red]")
|
|
162
|
+
if config_text:
|
|
163
|
+
pubkey_lines = [line for line in config_text.split("\n") if "PubkeyAuthentication" in line and not line.strip().startswith("#")]
|
|
164
|
+
if pubkey_lines and "no" in pubkey_lines[-1].lower():
|
|
165
|
+
results["pubkey_auth"] = {"status": "error", "message": "PubkeyAuthentication disabled"}
|
|
166
|
+
issues.append(("PubkeyAuthentication disabled", "Key-based login won't work", f'Edit {sshd_config} and set PubkeyAuthentication yes, then Restart-Service sshd'))
|
|
167
|
+
auth_info.append("❌ PubkeyAuthentication: [red]disabled[/red]")
|
|
168
|
+
else:
|
|
169
|
+
results["pubkey_auth"] = {"status": "ok", "message": "PubkeyAuthentication enabled (default)"}
|
|
170
|
+
auth_info.append("✅ PubkeyAuthentication: [green]enabled[/green] (default: yes)")
|
|
171
|
+
|
|
172
|
+
password_lines = [line for line in config_text.split("\n") if "PasswordAuthentication" in line and not line.strip().startswith("#")]
|
|
173
|
+
if password_lines:
|
|
174
|
+
password_enabled = "yes" in password_lines[-1].lower()
|
|
175
|
+
if password_enabled:
|
|
176
|
+
results["password_auth"] = {"status": "ok", "message": "PasswordAuthentication enabled"}
|
|
177
|
+
auth_info.append("✅ PasswordAuthentication: [green]enabled[/green]")
|
|
178
|
+
else:
|
|
179
|
+
results["password_auth"] = {"status": "info", "message": "PasswordAuthentication disabled"}
|
|
180
|
+
auth_info.append("🔐 PasswordAuthentication: [yellow]disabled[/yellow] (key-only)")
|
|
181
|
+
else:
|
|
182
|
+
results["password_auth"] = {"status": "ok", "message": "PasswordAuthentication enabled (default)"}
|
|
183
|
+
auth_info.append("✅ PasswordAuthentication: [green]enabled[/green] (default: yes)")
|
|
184
|
+
else:
|
|
185
|
+
auth_info.append("⚠️ Could not read sshd_config - auth settings unknown")
|
|
186
|
+
results["pubkey_auth"] = {"status": "unknown", "message": "Could not read config"}
|
|
187
|
+
results["password_auth"] = {"status": "unknown", "message": "Could not read config"}
|
|
188
|
+
|
|
189
|
+
console.print(Panel("\n".join(auth_info), title="[bold]Authentication Settings[/bold]", border_style="blue"))
|
|
190
|
+
|
|
191
|
+
net_info.append(f"🔌 SSH port: [cyan]{ssh_port}[/cyan]")
|
|
192
|
+
netstat = subprocess.run(["netstat", "-an"], capture_output=True, text=True, check=False)
|
|
193
|
+
if netstat.returncode == 0:
|
|
194
|
+
listening_lines = [line for line in netstat.stdout.split("\n") if f":{ssh_port}" in line and "LISTENING" in line]
|
|
195
|
+
if not listening_lines:
|
|
196
|
+
results["ssh_listening"] = {"status": "error", "message": f"Not listening on port {ssh_port}"}
|
|
197
|
+
issues.append((f"SSH not listening on port {ssh_port}", "No connections possible", "Restart-Service sshd"))
|
|
198
|
+
net_info.append(f"❌ Listening: [red]NOT listening on port {ssh_port}[/red]")
|
|
199
|
+
elif all("127.0.0.1" in line or "[::1]" in line for line in listening_lines):
|
|
200
|
+
results["ssh_listening"] = {"status": "error", "message": "Listening on localhost only"}
|
|
201
|
+
issues.append(("SSH bound to localhost only", "Only local connections work", f"Check ListenAddress in {sshd_config}"))
|
|
202
|
+
net_info.append("❌ Listening: [red]localhost only[/red] (remote connections blocked)")
|
|
203
|
+
else:
|
|
204
|
+
results["ssh_listening"] = {"status": "ok", "message": f"Listening on port {ssh_port}"}
|
|
205
|
+
net_info.append(f"✅ Listening: 0.0.0.0:{ssh_port}")
|
|
206
|
+
|
|
207
|
+
fw_cmd = f"""
|
|
208
|
+
$rules = Get-NetFirewallRule -ErrorAction SilentlyContinue | Where-Object {{
|
|
209
|
+
($_.DisplayName -like '*SSH*' -or $_.DisplayName -like '*OpenSSH*' -or $_.Name -like '*SSH*' -or $_.Name -like '*sshd*') -and
|
|
210
|
+
$_.Direction -eq 'Inbound'
|
|
211
|
+
}}
|
|
212
|
+
if (-not $rules) {{
|
|
213
|
+
$portFilter = Get-NetFirewallPortFilter -ErrorAction SilentlyContinue | Where-Object {{ $_.LocalPort -eq '{ssh_port}' -and $_.Protocol -eq 'TCP' }}
|
|
214
|
+
if ($portFilter) {{
|
|
215
|
+
$rules = $portFilter | ForEach-Object {{ Get-NetFirewallRule -AssociatedNetFirewallPortFilter $_ -ErrorAction SilentlyContinue }} | Where-Object {{ $_.Direction -eq 'Inbound' }}
|
|
216
|
+
}}
|
|
217
|
+
}}
|
|
218
|
+
if ($rules) {{
|
|
219
|
+
$rules | Select-Object Name, DisplayName, Enabled, Action | Format-List
|
|
220
|
+
}}
|
|
221
|
+
"""
|
|
222
|
+
ok, fw_out = _run_ps(fw_cmd)
|
|
223
|
+
if ok and fw_out.strip():
|
|
224
|
+
has_allow = "Enabled : True" in fw_out and "Action : Allow" in fw_out
|
|
225
|
+
if has_allow:
|
|
226
|
+
results["firewall"] = {"status": "ok", "message": "Firewall allows SSH"}
|
|
227
|
+
net_info.append("✅ Firewall: SSH rule exists and enabled")
|
|
228
|
+
else:
|
|
229
|
+
results["firewall"] = {"status": "warning", "message": "Firewall rule exists but may not be active"}
|
|
230
|
+
issues.append(("Firewall rule not active", "Incoming SSH may be blocked", f'New-NetFirewallRule -Name "SSH" -DisplayName "SSH" -Protocol TCP -LocalPort {ssh_port} -Action Allow -Enabled True'))
|
|
231
|
+
net_info.append("⚠️ Firewall: SSH rule exists but [yellow]not enabled[/yellow]")
|
|
232
|
+
else:
|
|
233
|
+
if not is_admin:
|
|
234
|
+
results["firewall"] = {"status": "warning", "message": "Cannot verify firewall (run as Admin)"}
|
|
235
|
+
net_info.append("⚠️ Firewall: [yellow]Cannot verify - run script as Administrator[/yellow]")
|
|
236
|
+
net_info.append(" [dim]Firewall rules may exist but require elevation to query.[/dim]")
|
|
237
|
+
else:
|
|
238
|
+
results["firewall"] = {"status": "error", "message": "No SSH firewall rule"}
|
|
239
|
+
issues.append(("No SSH firewall rule", "Windows Firewall blocks incoming SSH by default", f'New-NetFirewallRule -Name "SSH" -DisplayName "SSH" -Protocol TCP -LocalPort {ssh_port} -Action Allow -Enabled True'))
|
|
240
|
+
net_info.append("❌ Firewall: [red]No SSH rule found[/red]")
|
|
241
|
+
net_info.append(" [dim]Windows blocks all incoming by default. Must create allow rule.[/dim]")
|
|
242
|
+
|
|
243
|
+
console.print(Panel("\n".join(net_info), title="[bold]Network & Firewall[/bold]", border_style="blue"))
|
|
244
|
+
|
|
245
|
+
if issues:
|
|
246
|
+
fix_table = Table(title="Issues & Fixes", box=box.ROUNDED, show_lines=True, title_style="bold red")
|
|
247
|
+
fix_table.add_column("Issue", style="yellow", width=30)
|
|
248
|
+
fix_table.add_column("Impact", style="white", width=35)
|
|
249
|
+
fix_table.add_column("Fix Command", style="green", width=60)
|
|
250
|
+
for issue, impact, fix in issues:
|
|
251
|
+
fix_table.add_row(issue, impact, fix)
|
|
252
|
+
console.print(fix_table)
|
|
253
|
+
|
|
254
|
+
fix_script_path = Path(os.environ.get("TEMP", "C:/Temp")).joinpath("ssh_fix.ps1")
|
|
255
|
+
script_lines = ["# SSH Fix Script - Generated by ssh_debug_windows", f"# {len(issues)} issue(s) to fix", "# Run this script as Administrator", "", "$ErrorActionPreference = 'Stop'", ""]
|
|
256
|
+
for issue, _impact, fix in issues:
|
|
257
|
+
script_lines.append(f"# Fix: {issue}")
|
|
258
|
+
script_lines.append(f"Write-Host 'Fixing: {issue}' -ForegroundColor Yellow")
|
|
259
|
+
script_lines.append(fix)
|
|
260
|
+
script_lines.append("")
|
|
261
|
+
script_lines.append("Write-Host 'All fixes applied. Re-run ssh_debug_windows to verify.' -ForegroundColor Green")
|
|
262
|
+
fix_script_path.write_text("\n".join(script_lines), encoding="utf-8")
|
|
263
|
+
|
|
264
|
+
console.print(Panel(f"[bold yellow]⚠️ {len(issues)} issue(s) found[/bold yellow]\n\nFix script generated: [cyan]{fix_script_path}[/cyan]\nRun as Administrator: [green]powershell -ExecutionPolicy Bypass -File \"{fix_script_path}\"[/green]", title="[bold]Summary[/bold]", border_style="yellow"))
|
|
265
|
+
else:
|
|
266
|
+
conn_info = f"👤 {current_user} 🖥️ {hostname} 🔌 :{ssh_port}"
|
|
267
|
+
if ip_addresses:
|
|
268
|
+
conn_info += f"\n\n[bold]Connect:[/bold] ssh {current_user}@{ip_addresses[0]}"
|
|
269
|
+
console.print(Panel(f"[bold green]✅ All checks passed[/bold green]\n\n{conn_info}", title="[bold]Ready[/bold]", border_style="green"))
|
|
270
|
+
|
|
271
|
+
return results
|
|
272
|
+
|
|
273
|
+
|
|
274
|
+
if __name__ == "__main__":
|
|
275
|
+
ssh_debug_windows()
|
|
@@ -28,8 +28,6 @@ Usage examples:
|
|
|
28
28
|
|
|
29
29
|
"""
|
|
30
30
|
|
|
31
|
-
from typing import Annotated
|
|
32
|
-
import typer
|
|
33
31
|
import configparser
|
|
34
32
|
from pathlib import Path
|
|
35
33
|
import os
|
|
@@ -38,8 +36,7 @@ import subprocess
|
|
|
38
36
|
import getpass
|
|
39
37
|
from typing import List, Dict, Optional
|
|
40
38
|
from rich.console import Console
|
|
41
|
-
from rich.
|
|
42
|
-
from rich.prompt import Prompt, Confirm
|
|
39
|
+
from rich.prompt import Prompt
|
|
43
40
|
from rich.table import Table
|
|
44
41
|
|
|
45
42
|
console = Console()
|
|
@@ -263,51 +260,6 @@ def manual_network_selection() -> bool:
|
|
|
263
260
|
return False
|
|
264
261
|
|
|
265
262
|
|
|
266
|
-
def main(
|
|
267
|
-
ssid: Annotated[str, typer.Option("-n", "--ssid", help="🔗 SSID of WiFi (from config)")] = "MyPhoneHotSpot",
|
|
268
|
-
manual: Annotated[bool, typer.Option("-m", "--manual", help="🔍 Manual network selection mode")] = False,
|
|
269
|
-
list_: Annotated[bool, typer.Option("-l", "--list", help="📡 List available networks only")] = False,
|
|
270
|
-
) -> None:
|
|
271
|
-
"""Main function with fallback network selection"""
|
|
272
|
-
console.print(Panel("📶 Welcome to the WiFi Connector Tool", title="[bold blue]WiFi Connection[/bold blue]", border_style="blue"))
|
|
273
|
-
|
|
274
|
-
# If user just wants to list networks
|
|
275
|
-
if list_:
|
|
276
|
-
display_available_networks()
|
|
277
|
-
return
|
|
278
|
-
|
|
279
|
-
# If user wants manual mode, skip config and go straight to selection
|
|
280
|
-
if manual:
|
|
281
|
-
console.print("[blue]🔍 Manual network selection mode[/blue]")
|
|
282
|
-
if manual_network_selection():
|
|
283
|
-
console.print("[green]🎉 Successfully connected![/green]")
|
|
284
|
-
else:
|
|
285
|
-
console.print("[red]❌ Failed to connect[/red]")
|
|
286
|
-
return
|
|
287
|
-
|
|
288
|
-
# Try to connect using configuration first
|
|
289
|
-
console.print(f"[blue]🔍 Attempting to connect to configured network: {ssid}[/blue]")
|
|
290
|
-
|
|
291
|
-
if try_config_connection(ssid):
|
|
292
|
-
console.print("[green]🎉 Successfully connected using configuration![/green]")
|
|
293
|
-
return
|
|
294
|
-
|
|
295
|
-
# Configuration failed, offer fallback options
|
|
296
|
-
console.print("\n[yellow]⚠️ Configuration connection failed or not available[/yellow]")
|
|
297
|
-
|
|
298
|
-
if Confirm.ask("[blue]Would you like to manually select a network?[/blue]", default=True):
|
|
299
|
-
if manual_network_selection():
|
|
300
|
-
console.print("[green]🎉 Successfully connected![/green]")
|
|
301
|
-
else:
|
|
302
|
-
console.print("[red]❌ Failed to connect[/red]")
|
|
303
|
-
else:
|
|
304
|
-
console.print("[blue]👋 Goodbye![/blue]")
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
def arg_parser() -> None:
|
|
308
|
-
typer.run(main)
|
|
309
|
-
|
|
310
|
-
|
|
311
263
|
def get_current_wifi_name() -> str:
|
|
312
264
|
"""Get the name of the currently connected WiFi network"""
|
|
313
265
|
console.print("\n[blue]🔍 Checking current WiFi connection...[/blue]")
|
|
@@ -412,7 +364,3 @@ def create_new_connection(name: str, ssid: str, password: str):
|
|
|
412
364
|
except Exception as e:
|
|
413
365
|
console.print(f"[red]❌ Unexpected error: {e}[/red]")
|
|
414
366
|
raise
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
if __name__ == "__main__":
|
|
418
|
-
arg_parser()
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
from machineconfig.scripts.python.helpers_repos.action_helper import GitAction, GitOperationResult, GitOperationSummary, print_git_operations_summary
|
|
1
|
+
from machineconfig.scripts.python.helpers.helpers_repos.action_helper import GitAction, GitOperationResult, GitOperationSummary, print_git_operations_summary
|
|
2
2
|
from machineconfig.utils.path_extended import PathExtended
|
|
3
3
|
from machineconfig.utils.accessories import randstr
|
|
4
|
-
from machineconfig.scripts.python.helpers_repos.update import update_repository
|
|
4
|
+
from machineconfig.scripts.python.helpers.helpers_repos.update import update_repository
|
|
5
5
|
|
|
6
6
|
from typing import Optional, Dict, Any, List, cast
|
|
7
7
|
import concurrent.futures
|
|
@@ -117,7 +117,7 @@ def perform_git_operations(repos_root: PathExtended, pull: bool, commit: bool, p
|
|
|
117
117
|
operations_performed.append("push")
|
|
118
118
|
|
|
119
119
|
# Collect all candidate paths first
|
|
120
|
-
paths = list(repos_root.
|
|
120
|
+
paths = list(repos_root.glob("*"))
|
|
121
121
|
|
|
122
122
|
def _process_path(a_path: PathExtended) -> Dict[str, Any]:
|
|
123
123
|
"""Worker that processes a single path and returns metadata and results."""
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
from enum import Enum
|
|
2
|
-
from
|
|
2
|
+
from pathlib import Path
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
from dataclasses import dataclass
|
|
@@ -12,7 +12,7 @@ from rich.table import Table
|
|
|
12
12
|
@dataclass
|
|
13
13
|
class GitOperationResult:
|
|
14
14
|
"""Result of a git operation on a single repository."""
|
|
15
|
-
repo_path:
|
|
15
|
+
repo_path: Path
|
|
16
16
|
action: str
|
|
17
17
|
success: bool
|
|
18
18
|
message: str
|
|
@@ -52,7 +52,7 @@ class GitOperationSummary:
|
|
|
52
52
|
|
|
53
53
|
def __post_init__(self):
|
|
54
54
|
self.failed_operations: list[GitOperationResult] = []
|
|
55
|
-
self.repos_without_remotes: list[
|
|
55
|
+
self.repos_without_remotes: list[Path] = []
|
|
56
56
|
|
|
57
57
|
|
|
58
58
|
def print_git_operations_summary(summary: GitOperationSummary, operations_performed: list[str]) -> None:
|