machineconfig 6.64__tar.gz → 6.66__tar.gz
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.
Potentially problematic release.
This version of machineconfig might be problematic. Click here for more details.
- {machineconfig-6.64/src/machineconfig.egg-info → machineconfig-6.66}/PKG-INFO +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/pyproject.toml +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/helpers/enhanced_command_runner.py +4 -6
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/utils/maker.py +4 -4
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/croshell.py +2 -2
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/env_manager/path_manager_tui.py +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_config.py +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_self.py +3 -3
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_utils.py +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/cloud_repo_sync.py +3 -3
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_nfs +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/mount_ssh.ps1 +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/web_shortcuts/interactive.sh +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/web_shortcuts/interactive.ps1 +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/accessories.py +0 -1
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/code.py +2 -2
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/meta.py +2 -4
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/ssh.py +63 -19
- {machineconfig-6.64 → machineconfig-6.66/src/machineconfig.egg-info}/PKG-INFO +1 -1
- {machineconfig-6.64 → machineconfig-6.66}/MANIFEST.in +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/README.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/setup.cfg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/cloud_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/data_transfer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/distribute.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/file_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/job_params.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/loader_runner.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/remote_machine.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/run_cloud.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/run_cluster.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/run_remote.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/script_execution.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/script_notify_upon_completion.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/helpers/load_balancer_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/utils/load_balancer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_local.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_local_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_remote.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_remote_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_utils/layout_generator.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_utils/process_monitor.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_utils/remote_executor.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_utils/session_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_utils/status_reporter.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_local.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_local_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_remote.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_remote_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/example_usage.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/layout_generator.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/monitoring_types.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/process_monitor.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/remote_executor.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/session_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/status_reporter.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/zellij_local_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/zellij_local_helper_restart.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/zellij_local_helper_with_panes.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/zellij_utils/zellij_local_manager_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/templates/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/templates/cli_trogon.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/check_installations.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom/gh.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom/hx.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/alacritty.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/brave.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/bypass_paywall.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/code.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/cursor.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/dubdb_adbc.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/espanso.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/goes.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/lvim.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/nerdfont.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/nerfont_windows_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/redis.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/wezterm.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/winget.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/installer_data.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/brave.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/docker.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/docker_start.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/edge.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/nerdfont.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/ngrok.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/pgsql.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/q.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/redis.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/timescaledb.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/vscode.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/warp-cli.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/linux_scripts/wezterm.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/package_groups.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/powershell_scripts/install_fonts.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/linux/msc/cli_agents.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/linux/msc/lid.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/linux/msc/network.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/python/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/python/python_ve_symlink.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/python/vscode/api.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/windows/archive/archive_pygraphviz.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/windows/archive/openssh-server_add_key.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/windows/archive/openssh-server_copy-ssh-id.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/windows/msc/cli_agents.bat +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/windows/msc/cli_agents.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/logger.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/backup.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/bash_shell_profiles.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/create_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/create_links.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/create_links_export.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/create_shell_profile.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/mapper.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/records/generic/shares.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/records/linux/apps_summary_report.csv +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/records/linux/apps_summary_report.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/records/windows/apps_summary_report.csv +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/profile/records/windows/apps_summary_report.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/Restore-ThunderbirdProfile.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/fzf2g +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/fzfag +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/fzffg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/fzfg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/fzfrga +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/other/share_cloud.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/other/share_nfs +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/other/share_smb +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/other/start_docker +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/other/switch_ip +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/skrg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/warp-cli.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/linux/z_ls +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/agents.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/command_runner/command_runner.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/command_runner/prompt.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/generate_files.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/initai.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/scripts/lint_and_type_check.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/scripts/lint_and_type_check.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/_shared.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/claude/claude.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/cline/cline.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/chatmodes/Thinking-Beast-Mode.chatmode.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/chatmodes/Ultimate-Transparent-Thinking-Beast-Mode.chatmode.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/chatmodes/deepResearch.chatmode.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/github_copilot.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/instructions/python/dev.instructions.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/privacy.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/prompts/pyright_fix.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/copilot/prompts/research-report-skeleton.prompt.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/crush/crush.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/crush/crush.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/crush/privacy.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/cursor/cursors.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/gemini/gemini.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/gemini/settings.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/generic.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/kilocode/privacy.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/opencode/opencode.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/solutions/opencode/opencode.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ai/vscode_tasks.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/cloud.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/devops.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/devops_navigator.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/entry.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/env_manager/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/env_manager/path_manager_backend.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/fire_jobs.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/ftpx.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/cloud_copy.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/cloud_helpers.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/cloud_mount.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/cloud_sync.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/helpers2.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_cloud/helpers5.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/crosh.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/pomodoro.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/scheduler.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/start_slidev.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/viewer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_croshell/viewer_template.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_config_dotfile.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_data.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_nw.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_repos.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_share_server.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/cli_terminal.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/devops_backup_retrieve.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/devops_status.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/devops_update_repos.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/themes/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/themes/choose_pwsh_theme.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/themes/choose_starship_theme.bash +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/themes/choose_starship_theme.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_devops/themes/choose_wezterm_theme.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_crush.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_crush.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_cursor_agents.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_gemini.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/agentic_frameworks/fire_qwen.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/fire_agents_help_launch.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/fire_agents_help_search.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/fire_agents_helper_types.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/fire_agents_load_balancer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/helpers4.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/prompt.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/template.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire/template.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire_command/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire_command/cloud_manager.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire_command/fire_jobs_args_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire_command/fire_jobs_route_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_fire_command/fire_jobs_streamlit_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/command_builder.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/command_detail.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/command_tree.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/data_models.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/main_app.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_navigator/search_bar.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/action.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/clone.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/count_lines.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/count_lines_frontend.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/entrypoint.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/grource.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/record.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/secure_repo.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/sync.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_repos/update.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_sessions/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/helpers_sessions/sessions_multiprocess.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/interactive.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/add_ssh_key.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/devops_add_identity.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/devops_add_ssh_key.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_drive +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_nfs.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_nw_drive +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_nw_drive.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_smb +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/mount_ssh.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/onetimeshare.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/ssh_debug_linux.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/ssh_debug_windows.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/wifi_conn.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/nw/wsl_windows_transfer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/sessions.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/python/utils.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/fzfb.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/fzfg.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/fzfrga.bat +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/mount_nfs.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/mount_nw.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/mount_smb.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/share_cloud.cmd +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/share_smb.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/unlock_bitlocker.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/broot/br.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/broot/brootcd.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/broot/conf.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/glow/glow.yml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/gromit-mpx/gromit-mpx.cfg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/helix/config.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/helix/languages.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/keras/keras.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/keyboard/espanso/config/default.yml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/keyboard/espanso/match/base.yml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/keyboard/kanata/kanata.kbd +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/delete.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/on-cd.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/on-quit.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/open.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/paste.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/pre-cd.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/autocall/rename.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/colors +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/cleaner.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/fzf_nano.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/leftpane_previewer.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/lfcd.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/previewer.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/exe/previewer_archive.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/icons +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/linux/lfrc +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/delete.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/on-cd.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/on-quit.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/open.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/paste.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/pre-cd.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/autocall/rename.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/cd_tere.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/cd_zoxide.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/cd_zoxide2.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/colors +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/fzf_edit.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/icons +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/leftpane_previewer.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/lfcd.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/lfrc +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/mkdir.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/mkfile.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/previewer.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lf/windows/tst.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/linters/.flake8 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/linters/.mypy.ini +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/linters/.pylintrc +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/linters/.ruff.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lvim/linux/config.lua +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lvim/windows/archive/config_additional.lua +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lvim/windows/config.lua +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/lvim/windows/lua/user/custom_config.lua +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/marimo/marimo.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/mprocs/windows/mprocs.yaml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/mprocs/windows/other +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/pistol/pistol.conf +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/presenterm/config.yaml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/procs/.procs.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/pudb/pudb.cfg +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/rofi/config.rasi +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/rofi/config_default.rasi +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/alacritty/alacritty.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/alacritty/alacritty.yml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/bash/init.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/hyper/.hyper.js +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/ipy/profiles/default/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/ipy/profiles/default/startup/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/ipy/profiles/default/startup/playext.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/kitty/kitty.conf +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/nushell/config.nu +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/nushell/env.nu +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/pwsh/init.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/pwsh/profile.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/starship/starship.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/vtm/settings.xml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/wezterm/wezterm.lua +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/wt/settings.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/shells/zsh/init.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/streamlit/config.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/svim/linux/init.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/svim/windows/init.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/tere/terecd.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/tere/terecd.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/tmux/.tmate.conf +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/tmux/.tmux.conf +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/wsl/.wslconfig +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/yazi/keymap.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/yazi/theme.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/yazi/yazi.toml +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zed/settings.json +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/commands/monitor +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/commands/standard_panes +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/config.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/config.orig.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/layouts/hist +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/layouts/panes.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/layouts/st.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/layouts/st2.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/settings/zellij/layouts/stacked_panes.kdl +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/apps.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/apps_desktop.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/apps_gui.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/nix/cli_installation.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/others/mint_keyboard_shortcuts.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/ssh/openssh_all.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/ssh/openssh_wsl.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/uv.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/web_shortcuts/android.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_mac/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_mac/apps.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_mac/ssh/openssh_setup.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_mac/uv.sh +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/apps.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/others/docker.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/others/obs.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/others/power_options.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/ssh/add-sshkey.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/ssh/add_identity.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/ssh/openssh-server.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/uv.ps1 +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/wt_and_pwsh/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_windows/wt_and_pwsh/set_wt_settings.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/ai/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/cloud/onedrive/README.md +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/cloud/onedrive/setup_oauth.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/cloud/onedrive/transaction.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/art/fat_croco.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/art/halfwit_croco.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/art/happy_croco.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/art/water_croco.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/ascii_art.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/dbms.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/headers.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/ouch/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/ouch/decompress.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/files/read.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer_utils/__init__.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer_utils/github_release_bulk.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer_utils/installer.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer_utils/installer_abc.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/installer_utils/installer_class.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/io.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/links.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/notifications.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/options.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/path_extended.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/path_helper.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/procs.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/scheduler.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/scheduling.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/schemas/fire_agents/fire_agents_input.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/schemas/installer/installer_types.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/schemas/layouts/layout_types.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/schemas/repos/repos_types.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/source_of_truth.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/ssh_utils/utils.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/terminal.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/tst.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/upgrade_packages.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/utils/ve.py +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig.egg-info/SOURCES.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig.egg-info/dependency_links.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig.egg-info/entry_points.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig.egg-info/requires.txt +0 -0
- {machineconfig-6.64 → machineconfig-6.66}/src/machineconfig.egg-info/top_level.txt +0 -0
|
@@ -95,17 +95,15 @@ def enhanced_zellij_session_start(session_name: str, layout_path: str) -> Dict[s
|
|
|
95
95
|
# Start new session (use -b for background to avoid hanging)
|
|
96
96
|
start_cmd = f"zellij --layout {layout_path} a -b {session_name}"
|
|
97
97
|
start_result = run_enhanced_command(
|
|
98
|
-
start_cmd,
|
|
99
|
-
|
|
100
|
-
False,
|
|
101
|
-
10, # Add timeout to prevent hanging
|
|
98
|
+
command=start_cmd, description=f"Starting session '{session_name}' with layout", show_progress=False,
|
|
99
|
+
timeout=10, # Add timeout to prevent hanging
|
|
102
100
|
)
|
|
103
|
-
|
|
104
101
|
if start_result["success"]:
|
|
105
102
|
console.print(Panel(f"[bold green]✅ Session '{session_name}' is now running![/bold green]\n[dim]Layout: {layout_path}[/dim]", style="green", title="🎉 Success"))
|
|
106
103
|
else:
|
|
107
104
|
console.print(Panel(f"[bold red]❌ Failed to start session '{session_name}'[/bold red]\n[red]{start_result.get('stderr', 'Unknown error')}[/red]", style="red", title="💥 Error"))
|
|
108
|
-
|
|
105
|
+
# print("Sleeping for 3 seconds to allow zellij to initialize...")
|
|
106
|
+
# time.sleep(3) # Brief pause for readability
|
|
109
107
|
return start_result
|
|
110
108
|
|
|
111
109
|
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/utils/maker.py
RENAMED
|
@@ -4,9 +4,9 @@ from typing import Optional, Literal
|
|
|
4
4
|
from machineconfig.utils.schemas.layouts.layout_types import TabConfig, LayoutConfig
|
|
5
5
|
from pathlib import Path
|
|
6
6
|
|
|
7
|
-
def get_fire_tab_using_uv(func: FunctionType, uv_with: Optional[list[str]], uv_project_dir: Optional[str]) -> tuple[TabConfig, Path]:
|
|
7
|
+
def get_fire_tab_using_uv(func: FunctionType, import_module: bool, uv_with: Optional[list[str]], uv_project_dir: Optional[str]) -> tuple[TabConfig, Path]:
|
|
8
8
|
from machineconfig.utils.meta import lambda_to_python_script
|
|
9
|
-
py_script = lambda_to_python_script(lmb=lambda: func, in_global=True)
|
|
9
|
+
py_script = lambda_to_python_script(lmb=lambda: func, in_global=True, import_module=import_module)
|
|
10
10
|
from machineconfig.utils.code import get_uv_command_executing_python_script
|
|
11
11
|
command_to_run, py_script_path = get_uv_command_executing_python_script(python_script=py_script, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
12
12
|
tab_config: TabConfig = {
|
|
@@ -28,12 +28,12 @@ def get_fire_tab_using_fire(func: FunctionType):
|
|
|
28
28
|
return tab_config
|
|
29
29
|
|
|
30
30
|
|
|
31
|
-
def make_layout_from_functions(functions: list[FunctionType], tab_configs: list[TabConfig], layout_name: str, method: Literal["script", "fire"]="fire") -> LayoutConfig:
|
|
31
|
+
def make_layout_from_functions(functions: list[FunctionType], import_module: bool, tab_configs: list[TabConfig], layout_name: str, method: Literal["script", "fire"]="fire") -> LayoutConfig:
|
|
32
32
|
tabs2artifacts: list[tuple[TabConfig, list[Path]]] = []
|
|
33
33
|
for a_func in functions:
|
|
34
34
|
match method:
|
|
35
35
|
case "script":
|
|
36
|
-
tab_config, artifact_files_1 = get_fire_tab_using_uv(a_func, uv_with=None, uv_project_dir=None)
|
|
36
|
+
tab_config, artifact_files_1 = get_fire_tab_using_uv(a_func, import_module=import_module, uv_with=None, uv_project_dir=None)
|
|
37
37
|
artifact_files = [artifact_files_1]
|
|
38
38
|
case "fire":
|
|
39
39
|
tab_config = get_fire_tab_using_fire(a_func)
|
|
@@ -61,7 +61,7 @@ def croshell(
|
|
|
61
61
|
print("Streamlit viewer is not yet implemented in this version.")
|
|
62
62
|
return None
|
|
63
63
|
file_obj = PathExtended(str(path).lstrip()).expanduser().absolute()
|
|
64
|
-
program = lambda_to_python_script(lambda: get_read_data_pycode(path=str(file_obj)), in_global=True)
|
|
64
|
+
program = lambda_to_python_script(lambda: get_read_data_pycode(path=str(file_obj)), in_global=True, import_module=False)
|
|
65
65
|
text = f"📄 Reading data from: {file_obj.name}"
|
|
66
66
|
console.print(Panel(text, title="[bold blue]Info[/bold blue]"))
|
|
67
67
|
else: # if nothing is specified, then run in interactive mode.
|
|
@@ -91,7 +91,7 @@ def croshell(
|
|
|
91
91
|
pyfile.parent.mkdir(parents=True, exist_ok=True)
|
|
92
92
|
|
|
93
93
|
title = "Reading Data"
|
|
94
|
-
def_code = lambda_to_python_script(lambda: code(path=str(pyfile), title=title), in_global=False)
|
|
94
|
+
def_code = lambda_to_python_script(lambda: code(path=str(pyfile), title=title), in_global=False, import_module=False)
|
|
95
95
|
# print(def_code)
|
|
96
96
|
python_program = preprogram + "\n\n" + def_code + program
|
|
97
97
|
pyfile.write_text(python_program, encoding="utf-8")
|
|
@@ -46,7 +46,7 @@ def path():
|
|
|
46
46
|
uv_with = ["textual"]
|
|
47
47
|
uv_project_dir = None
|
|
48
48
|
if not Path.home().joinpath("code/machineconfig").exists():
|
|
49
|
-
uv_with.append("machineconfig>=6.
|
|
49
|
+
uv_with.append("machineconfig>=6.66")
|
|
50
50
|
else:
|
|
51
51
|
uv_project_dir = str(Path.home().joinpath("code/machineconfig"))
|
|
52
52
|
run_shell_script(get_uv_command_executing_python_script(python_script=path.read_text(encoding="utf-8"), uv_with=uv_with, uv_project_dir=uv_project_dir)[0])
|
|
@@ -41,9 +41,9 @@ def install(no_copy_assets: Annotated[bool, typer.Option("--no-assets-copy", "-n
|
|
|
41
41
|
else:
|
|
42
42
|
import platform
|
|
43
43
|
if platform.system() == "Windows":
|
|
44
|
-
run_shell_script(r"""& "$HOME\.local\bin\uv.exe" tool install --upgrade "machineconfig>=6.
|
|
44
|
+
run_shell_script(r"""& "$HOME\.local\bin\uv.exe" tool install --upgrade "machineconfig>=6.66" """)
|
|
45
45
|
else:
|
|
46
|
-
run_shell_script("""$HOME/.local/bin/uv tool install --upgrade "machineconfig>=6.
|
|
46
|
+
run_shell_script("""$HOME/.local/bin/uv tool install --upgrade "machineconfig>=6.66" """)
|
|
47
47
|
from machineconfig.profile.create_shell_profile import create_default_shell_profile
|
|
48
48
|
if not no_copy_assets:
|
|
49
49
|
create_default_shell_profile() # involves copying assets too
|
|
@@ -68,7 +68,7 @@ def navigate():
|
|
|
68
68
|
path = Path(navigator.__file__).resolve().parent.joinpath("devops_navigator.py")
|
|
69
69
|
from machineconfig.utils.code import run_shell_script
|
|
70
70
|
if Path.home().joinpath("code/machineconfig").exists(): executable = f"""--project "{str(Path.home().joinpath("code/machineconfig"))}" --with textual"""
|
|
71
|
-
else: executable = """--with "machineconfig>=6.
|
|
71
|
+
else: executable = """--with "machineconfig>=6.66,textual" """
|
|
72
72
|
run_shell_script(f"""uv run {executable} {path}""")
|
|
73
73
|
|
|
74
74
|
|
|
@@ -111,7 +111,7 @@ def merge_pdfs(
|
|
|
111
111
|
writer.write(output_path)
|
|
112
112
|
print(f"✅ Merged PDF saved to: {output_path}")
|
|
113
113
|
from machineconfig.utils.meta import lambda_to_python_script
|
|
114
|
-
code = lambda_to_python_script(lambda : merge_pdfs_internal(pdf1=pdf1, pdf2=pdf2, output=output, compress=compress), in_global=True)
|
|
114
|
+
code = lambda_to_python_script(lambda : merge_pdfs_internal(pdf1=pdf1, pdf2=pdf2, output=output, compress=compress), in_global=True, import_module=False)
|
|
115
115
|
from machineconfig.utils.code import run_shell_script, get_uv_command_executing_python_script
|
|
116
116
|
uv_command, _py_file = get_uv_command_executing_python_script(python_script=code, uv_with=["pypdf"], uv_project_dir=None)
|
|
117
117
|
run_shell_script(uv_command)
|
|
@@ -80,7 +80,7 @@ git pull originEnc master
|
|
|
80
80
|
uv_project_dir = f"""{str(Path.home().joinpath("code/machineconfig"))}"""
|
|
81
81
|
uv_with = None
|
|
82
82
|
else:
|
|
83
|
-
uv_with = ["machineconfig>=6.
|
|
83
|
+
uv_with = ["machineconfig>=6.66"]
|
|
84
84
|
uv_project_dir = None
|
|
85
85
|
|
|
86
86
|
import tempfile
|
|
@@ -111,7 +111,7 @@ git pull originEnc master
|
|
|
111
111
|
def func2(remote_repo: str, local_repo: str, cloud: str):
|
|
112
112
|
from machineconfig.scripts.python.helpers_repos.sync import delete_remote_repo_copy_and_push_local
|
|
113
113
|
delete_remote_repo_copy_and_push_local(remote_repo=remote_repo, local_repo=local_repo, cloud=cloud)
|
|
114
|
-
program_1_py = lambda_to_python_script(lambda: func2(remote_repo=str(repo_remote_root), local_repo=str(repo_local_root), cloud=str(cloud_resolved)), in_global=True)
|
|
114
|
+
program_1_py = lambda_to_python_script(lambda: func2(remote_repo=str(repo_remote_root), local_repo=str(repo_local_root), cloud=str(cloud_resolved)), in_global=True, import_module=False)
|
|
115
115
|
program1, _pyfile1 = get_uv_command_executing_python_script(python_script=program_1_py, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
116
116
|
# ================================================================================
|
|
117
117
|
option2 = "Delete local repo and replace it with remote copy:"
|
|
@@ -136,7 +136,7 @@ sudo chmod +x $HOME/dotfiles/scripts/linux -R
|
|
|
136
136
|
inspect_repos(repo_local_root=repo_local_root, repo_remote_root=repo_remote_root)
|
|
137
137
|
# program_3_py = function_to_script(func=func, call_with_kwargs={"repo_local_root": str(repo_local_root), "repo_remote_root": str(repo_remote_root)})
|
|
138
138
|
# shell_file_3 = get_shell_file_executing_python_script(python_script=program_3_py, ve_path=None, executable=executable)
|
|
139
|
-
program_3_py = lambda_to_python_script(lambda: func(repo_local_root=str(repo_local_root), repo_remote_root=str(repo_remote_root)), in_global=True)
|
|
139
|
+
program_3_py = lambda_to_python_script(lambda: func(repo_local_root=str(repo_local_root), repo_remote_root=str(repo_remote_root)), in_global=True, import_module=False)
|
|
140
140
|
program3, _pyfile3 = get_uv_command_executing_python_script(python_script=program_3_py, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
141
141
|
# ================================================================================
|
|
142
142
|
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
# mkdir ~/data/local
|
|
6
6
|
# sudo mount -o nolock,noatime,nodiratime,proto=tcp,timeo=600,retrans=2,noac alex-p51s-5:/home/alex/data/local ./data/local
|
|
7
7
|
|
|
8
|
-
uv run --python 3.14 --with "machineconfig>=6.
|
|
8
|
+
uv run --python 3.14 --with "machineconfig>=6.66" python -m machineconfig.scripts.python.mount_nfs
|
|
9
9
|
# Check if remote server is reachable and share folder exists
|
|
10
10
|
if ! ping -c 1 "$remote_server" &> /dev/null; then
|
|
11
11
|
echo "💥 Error: Remote server $remote_server is not reachable."
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/scripts/windows/mounts/mount_ssh.ps1
RENAMED
|
@@ -7,7 +7,7 @@ $user = ''
|
|
|
7
7
|
$sharePath = ''
|
|
8
8
|
$driveLetter = ''
|
|
9
9
|
|
|
10
|
-
uv run --python 3.14 --with "machineconfig>=6.
|
|
10
|
+
uv run --python 3.14 --with "machineconfig>=6.66" python -m machineconfig.scripts.python.mount_ssh
|
|
11
11
|
|
|
12
12
|
net use T: \\sshfs.kr\$user@$host.local
|
|
13
13
|
# this worked: net use T: \\sshfs\alex@alex-p51s-5.local
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/setup_linux/web_shortcuts/interactive.sh
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/bin/bash
|
|
2
2
|
. <( curl -sSL "https://raw.githubusercontent.com/thisismygitrepo/machineconfig/main/src/machineconfig/setup_linux/uv.sh")
|
|
3
3
|
mcfg() {
|
|
4
|
-
"$HOME/.local/bin/uv" run --python 3.14 --with "machineconfig>=6.
|
|
4
|
+
"$HOME/.local/bin/uv" run --python 3.14 --with "machineconfig>=6.66" mcfg "$@"
|
|
5
5
|
}
|
|
6
6
|
alias d="mcfg devops"
|
|
7
7
|
alias c="mcfg cloud"
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
iex (iwr "https://raw.githubusercontent.com/thisismygitrepo/machineconfig/main/src/machineconfig/setup_windows/uv.ps1").Content
|
|
4
4
|
function mcfg {
|
|
5
|
-
& "$HOME\.local\bin\uv.exe" run --python 3.14 --with "machineconfig>=6.
|
|
5
|
+
& "$HOME\.local\bin\uv.exe" run --python 3.14 --with "machineconfig>=6.66" mcfg $args
|
|
6
6
|
}
|
|
7
7
|
function d { mcfg devops @args }
|
|
8
8
|
function c { mcfg cloud @args }
|
|
@@ -72,7 +72,6 @@ def split_list[T](sequence: list[T], every: Optional[int]=None, to: Optional[int
|
|
|
72
72
|
|
|
73
73
|
def pprint(obj: dict[Any, Any], title: str) -> None:
|
|
74
74
|
from rich import inspect
|
|
75
|
-
|
|
76
75
|
inspect(type("TempStruct", (object,), obj)(), value=False, title=title, docs=False, dunder=False, sort=False)
|
|
77
76
|
|
|
78
77
|
|
|
@@ -37,7 +37,7 @@ def get_uv_command_executing_python_script(python_script: str, uv_with: Optional
|
|
|
37
37
|
else:
|
|
38
38
|
uv_project_dir_arg = ""
|
|
39
39
|
from machineconfig.utils.meta import lambda_to_python_script
|
|
40
|
-
print_code_string = lambda_to_python_script(lambda: print_code(code=python_script, lexer="python", desc="Temporary Python Script", subtitle="Executing via shell script"), in_global=True)
|
|
40
|
+
print_code_string = lambda_to_python_script(lambda: print_code(code=python_script, lexer="python", desc="Temporary Python Script", subtitle="Executing via shell script"), in_global=True, import_module=False)
|
|
41
41
|
python_file.write_text(print_code_string + "\n" + python_script, encoding="utf-8")
|
|
42
42
|
shell_script = f"""uv run {uv_with_arg} {uv_project_dir_arg} {str(python_file)} """
|
|
43
43
|
return shell_script, python_file
|
|
@@ -45,7 +45,7 @@ def get_uv_command_executing_python_script(python_script: str, uv_with: Optional
|
|
|
45
45
|
|
|
46
46
|
def run_lambda_function(lmb: Callable[[], Any], uv_with: Optional[list[str]], uv_project_dir: Optional[str]) -> None:
|
|
47
47
|
from machineconfig.utils.meta import lambda_to_python_script
|
|
48
|
-
code = lambda_to_python_script(lmb, in_global=True)
|
|
48
|
+
code = lambda_to_python_script(lmb, in_global=True, import_module=False)
|
|
49
49
|
uv_command, _py_file = get_uv_command_executing_python_script(python_script=code, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
50
50
|
run_shell_script(uv_command)
|
|
51
51
|
|
|
@@ -29,7 +29,7 @@ except (ImportError, ModuleNotFoundError) as ex:
|
|
|
29
29
|
return txt
|
|
30
30
|
|
|
31
31
|
|
|
32
|
-
def lambda_to_python_script(lmb: Callable[[], Any], in_global: bool, import_module: bool
|
|
32
|
+
def lambda_to_python_script(lmb: Callable[[], Any], in_global: bool, import_module: bool) -> str:
|
|
33
33
|
"""
|
|
34
34
|
caveats: always use keyword arguments in the lambda call for best results.
|
|
35
35
|
return statement not allowed in the wrapped function (otherwise it can be put in the global space)
|
|
@@ -107,9 +107,7 @@ def lambda_to_python_script(lmb: Callable[[], Any], in_global: bool, import_modu
|
|
|
107
107
|
import_prefix: str = ""
|
|
108
108
|
if import_module:
|
|
109
109
|
module_file = _inspect.getsourcefile(func_obj)
|
|
110
|
-
module_path_candidate: str
|
|
111
|
-
if module_path_candidate is None:
|
|
112
|
-
raise RuntimeError("Could not determine source file for function module inspection.")
|
|
110
|
+
module_path_candidate: str = module_file if module_file is not None else _inspect.getfile(func_obj)
|
|
113
111
|
import_prefix = get_import_module_string(str(_Path(module_path_candidate)))
|
|
114
112
|
|
|
115
113
|
# Evaluate each keyword argument value in the lambda's globals to get real Python objects
|
|
@@ -8,10 +8,14 @@ from machineconfig.utils.terminal import Response
|
|
|
8
8
|
from machineconfig.utils.accessories import pprint, randstr
|
|
9
9
|
from machineconfig.utils.meta import lambda_to_python_script
|
|
10
10
|
UV_RUN_CMD = "$HOME/.local/bin/uv run" if platform.system() != "Windows" else """& "$env:USERPROFILE/.local/bin/uv" run"""
|
|
11
|
-
MACHINECONFIG_VERSION = "machineconfig>=6.
|
|
11
|
+
MACHINECONFIG_VERSION = "machineconfig>=6.66"
|
|
12
12
|
DEFAULT_PICKLE_SUBDIR = "tmp_results/tmp_scripts/ssh"
|
|
13
13
|
|
|
14
14
|
class SSH:
|
|
15
|
+
@staticmethod
|
|
16
|
+
def from_config_file(host: str) -> "SSH":
|
|
17
|
+
"""Create SSH instance from SSH config file entry."""
|
|
18
|
+
return SSH(host=host, username=None, hostname=None, ssh_key_path=None, password=None, port=22, enable_compression=False)
|
|
15
19
|
def __init__(
|
|
16
20
|
self, host: Optional[str], username: Optional[str], hostname: Optional[str], ssh_key_path: Optional[str], password: Optional[str], port: int, enable_compression: bool):
|
|
17
21
|
self.password = password
|
|
@@ -112,12 +116,36 @@ class SSH:
|
|
|
112
116
|
from machineconfig.scripts.python.helpers_devops.cli_utils import get_machine_specs
|
|
113
117
|
self.local_specs: MachineSpecs = get_machine_specs()
|
|
114
118
|
resp = self.run_shell(command=f"""~/.local/bin/utils get-machine-specs """, verbose_output=False, description="Getting remote machine specs", strict_stderr=False, strict_return_code=False)
|
|
115
|
-
# import json
|
|
116
119
|
json_str = resp.op
|
|
117
|
-
print(f"Remote machine specs JSON: {resp.op}")
|
|
118
120
|
import ast
|
|
119
121
|
self.remote_specs: MachineSpecs = cast(MachineSpecs, ast.literal_eval(json_str))
|
|
120
122
|
self.terminal_responses: list[Response] = []
|
|
123
|
+
|
|
124
|
+
from rich import inspect
|
|
125
|
+
|
|
126
|
+
local_info = dict(distro=self.local_specs.get("distro"), system=self.local_specs.get("system"), home_dir=self.local_specs.get("home_dir"))
|
|
127
|
+
remote_info = dict(distro=self.remote_specs.get("distro"), system=self.remote_specs.get("system"), home_dir=self.remote_specs.get("home_dir"))
|
|
128
|
+
|
|
129
|
+
console = rich.console.Console()
|
|
130
|
+
|
|
131
|
+
from io import StringIO
|
|
132
|
+
local_buffer = StringIO()
|
|
133
|
+
remote_buffer = StringIO()
|
|
134
|
+
|
|
135
|
+
local_console = rich.console.Console(file=local_buffer, width=40)
|
|
136
|
+
remote_console = rich.console.Console(file=remote_buffer, width=40)
|
|
137
|
+
|
|
138
|
+
inspect(type("LocalInfo", (object,), local_info)(), value=False, title="SSHing From", docs=False, dunder=False, sort=False, console=local_console)
|
|
139
|
+
inspect(type("RemoteInfo", (object,), remote_info)(), value=False, title="SSHing To", docs=False, dunder=False, sort=False, console=remote_console)
|
|
140
|
+
|
|
141
|
+
local_lines = local_buffer.getvalue().split("\n")
|
|
142
|
+
remote_lines = remote_buffer.getvalue().split("\n")
|
|
143
|
+
|
|
144
|
+
max_lines = max(len(local_lines), len(remote_lines))
|
|
145
|
+
for i in range(max_lines):
|
|
146
|
+
left = local_lines[i] if i < len(local_lines) else ""
|
|
147
|
+
right = remote_lines[i] if i < len(remote_lines) else ""
|
|
148
|
+
console.print(f"{left:<42} {right}")
|
|
121
149
|
|
|
122
150
|
def __enter__(self) -> "SSH":
|
|
123
151
|
return self
|
|
@@ -165,8 +193,8 @@ class SSH:
|
|
|
165
193
|
res.capture().print_if_unsuccessful(desc=description, strict_err=strict_stderr, strict_returncode=strict_return_code, assert_success=False)
|
|
166
194
|
# self.terminal_responses.append(res)
|
|
167
195
|
return res
|
|
168
|
-
|
|
169
|
-
|
|
196
|
+
|
|
197
|
+
def _run_py_prep(self, python_code: str, uv_with: Optional[list[str]], uv_project_dir: Optional[str],) -> str:
|
|
170
198
|
py_path = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/runpy_{randstr()}.py")
|
|
171
199
|
py_path.parent.mkdir(parents=True, exist_ok=True)
|
|
172
200
|
py_path.write_text(python_code, encoding="utf-8")
|
|
@@ -180,13 +208,29 @@ class SSH:
|
|
|
180
208
|
else:
|
|
181
209
|
with_clause += ""
|
|
182
210
|
uv_cmd = f"""{UV_RUN_CMD} {with_clause} python {py_path.relative_to(Path.home())}"""
|
|
211
|
+
return uv_cmd
|
|
212
|
+
|
|
213
|
+
def run_py(self, python_code: str, uv_with: Optional[list[str]], uv_project_dir: Optional[str],
|
|
214
|
+
description: str, verbose_output: bool, strict_stderr: bool, strict_return_code: bool) -> Response:
|
|
215
|
+
uv_cmd = self._run_py_prep(python_code=python_code, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
183
216
|
return self.run_shell(command=uv_cmd, verbose_output=verbose_output, description=description or f"run_py on {self.get_remote_repr(add_machine=False)}", strict_stderr=strict_stderr, strict_return_code=strict_return_code)
|
|
184
217
|
|
|
185
|
-
def run_lambda_function(self, func: Callable[..., Any], uv_with: Optional[list[str]], uv_project_dir: Optional[str])
|
|
186
|
-
command = lambda_to_python_script(lmb=func, in_global=True)
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
218
|
+
def run_lambda_function(self, func: Callable[..., Any], import_module: bool, uv_with: Optional[list[str]], uv_project_dir: Optional[str]):
|
|
219
|
+
command = lambda_to_python_script(lmb=func, in_global=True, import_module=import_module)
|
|
220
|
+
# turns ou that the code below for some reason runs but zellij doesn't start, looks like things are assigned to different user.
|
|
221
|
+
# return self.run_py(python_code=command, uv_with=uv_with, uv_project_dir=uv_project_dir,
|
|
222
|
+
# description=f"run_py_func {func.__name__} on {self.get_remote_repr(add_machine=False)}",
|
|
223
|
+
# verbose_output=True, strict_stderr=True, strict_return_code=True)
|
|
224
|
+
uv_cmd = self._run_py_prep(python_code=command, uv_with=uv_with, uv_project_dir=uv_project_dir)
|
|
225
|
+
if self.remote_specs["system"] == "Linux":
|
|
226
|
+
uv_cmd_modified = f'bash -l -c "{uv_cmd}"'
|
|
227
|
+
else: uv_cmd_modified = uv_cmd
|
|
228
|
+
# This works even withou the modified uv cmd:
|
|
229
|
+
# from machineconfig.utils.code import run_shell_script
|
|
230
|
+
# assert self.host is not None, "SSH host must be specified to run remote commands"
|
|
231
|
+
# process = run_shell_script(f"ssh {self.host} -n '. ~/.profile; . ~/.bashrc; {uv_cmd}'")
|
|
232
|
+
# return process
|
|
233
|
+
return self.run_shell(command=uv_cmd_modified, verbose_output=True, description=f"run_py_func {func.__name__} on {self.get_remote_repr(add_machine=False)}", strict_stderr=True, strict_return_code=True)
|
|
190
234
|
|
|
191
235
|
def _simple_sftp_get(self, remote_path: str, local_path: Path) -> None:
|
|
192
236
|
"""Simple SFTP get without any recursion or path expansion - for internal use only."""
|
|
@@ -207,7 +251,7 @@ class SSH:
|
|
|
207
251
|
else:
|
|
208
252
|
directory_path.unlink()
|
|
209
253
|
directory_path.parent.mkdir(parents=True, exist_ok=True)
|
|
210
|
-
command = lambda_to_python_script(lmb=lambda: create_target_dir(target_rel2home=path_rel2home, overwrite=overwrite_existing), in_global=True)
|
|
254
|
+
command = lambda_to_python_script(lmb=lambda: create_target_dir(target_rel2home=path_rel2home, overwrite=overwrite_existing), in_global=True, import_module=False)
|
|
211
255
|
tmp_py_file = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/create_target_dir_{randstr()}.py")
|
|
212
256
|
tmp_py_file.parent.mkdir(parents=True, exist_ok=True)
|
|
213
257
|
tmp_py_file.write_text(command, encoding="utf-8")
|
|
@@ -270,7 +314,7 @@ class SSH:
|
|
|
270
314
|
with zipfile.ZipFile(archive_path, "r") as archive_handle:
|
|
271
315
|
archive_handle.extractall(extraction_directory)
|
|
272
316
|
archive_path.unlink()
|
|
273
|
-
command = lambda_to_python_script(lmb=lambda: unzip_archive(zip_file_path=str(Path(self.remote_specs["home_dir"]).joinpath(target_rel2home)), overwrite_flag=overwrite_existing), in_global=True)
|
|
317
|
+
command = lambda_to_python_script(lmb=lambda: unzip_archive(zip_file_path=str(Path(self.remote_specs["home_dir"]).joinpath(target_rel2home)), overwrite_flag=overwrite_existing), in_global=True, import_module=False)
|
|
274
318
|
tmp_py_file = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/create_target_dir_{randstr()}.py")
|
|
275
319
|
tmp_py_file.parent.mkdir(parents=True, exist_ok=True)
|
|
276
320
|
tmp_py_file.write_text(command, encoding="utf-8")
|
|
@@ -291,7 +335,7 @@ class SSH:
|
|
|
291
335
|
print(json_result_path.as_posix())
|
|
292
336
|
return is_directory
|
|
293
337
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
294
|
-
command = lambda_to_python_script(lmb=lambda: check_is_dir(path_to_check=str(source_path), json_output_path=remote_json_output), in_global=True)
|
|
338
|
+
command = lambda_to_python_script(lmb=lambda: check_is_dir(path_to_check=str(source_path), json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
295
339
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description=f"Check if source `{source_path}` is a dir", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
296
340
|
remote_json_path = response.op.strip()
|
|
297
341
|
if not remote_json_path:
|
|
@@ -325,7 +369,7 @@ class SSH:
|
|
|
325
369
|
|
|
326
370
|
|
|
327
371
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
328
|
-
command = lambda_to_python_script(lmb=lambda: expand_source(path_to_expand=str(source_path), json_output_path=remote_json_output), in_global=True)
|
|
372
|
+
command = lambda_to_python_script(lmb=lambda: expand_source(path_to_expand=str(source_path), json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
329
373
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description="Resolving source path by expanding user", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
330
374
|
remote_json_path = response.op.strip()
|
|
331
375
|
if not remote_json_path:
|
|
@@ -374,7 +418,7 @@ class SSH:
|
|
|
374
418
|
|
|
375
419
|
|
|
376
420
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
377
|
-
command = lambda_to_python_script(lmb=lambda: search_files(directory_path=expanded_source, json_output_path=remote_json_output), in_global=True)
|
|
421
|
+
command = lambda_to_python_script(lmb=lambda: search_files(directory_path=expanded_source, json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
378
422
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description="Searching for files in source", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
379
423
|
remote_json_path = response.op.strip()
|
|
380
424
|
if not remote_json_path:
|
|
@@ -412,7 +456,7 @@ class SSH:
|
|
|
412
456
|
|
|
413
457
|
|
|
414
458
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
415
|
-
command = lambda_to_python_script(lmb=lambda: collapse_to_home_dir(absolute_path=expanded_source, json_output_path=remote_json_output), in_global=True)
|
|
459
|
+
command = lambda_to_python_script(lmb=lambda: collapse_to_home_dir(absolute_path=expanded_source, json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
416
460
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description="Finding default target via relative source path", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
417
461
|
remote_json_path_dir = response.op.strip()
|
|
418
462
|
if not remote_json_path_dir:
|
|
@@ -464,7 +508,7 @@ class SSH:
|
|
|
464
508
|
|
|
465
509
|
|
|
466
510
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
467
|
-
command = lambda_to_python_script(lmb=lambda: zip_source(path_to_zip=expanded_source, json_output_path=remote_json_output), in_global=True)
|
|
511
|
+
command = lambda_to_python_script(lmb=lambda: zip_source(path_to_zip=expanded_source, json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
468
512
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description=f"Zipping source file {source}", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
469
513
|
remote_json_path = response.op.strip()
|
|
470
514
|
if not remote_json_path:
|
|
@@ -503,7 +547,7 @@ class SSH:
|
|
|
503
547
|
|
|
504
548
|
|
|
505
549
|
remote_json_output = Path.home().joinpath(f"{DEFAULT_PICKLE_SUBDIR}/return_{randstr()}.json").as_posix()
|
|
506
|
-
command = lambda_to_python_script(lmb=lambda: collapse_to_home(absolute_path=expanded_source, json_output_path=remote_json_output), in_global=True)
|
|
550
|
+
command = lambda_to_python_script(lmb=lambda: collapse_to_home(absolute_path=expanded_source, json_output_path=remote_json_output), in_global=True, import_module=False)
|
|
507
551
|
response = self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description="Finding default target via relative source path", verbose_output=False, strict_stderr=False, strict_return_code=False)
|
|
508
552
|
remote_json_path = response.op.strip()
|
|
509
553
|
if not remote_json_path:
|
|
@@ -559,7 +603,7 @@ class SSH:
|
|
|
559
603
|
file_or_dir_path.unlink()
|
|
560
604
|
|
|
561
605
|
|
|
562
|
-
command = lambda_to_python_script(lmb=lambda: delete_temp_zip(path_to_delete=expanded_source), in_global=True)
|
|
606
|
+
command = lambda_to_python_script(lmb=lambda: delete_temp_zip(path_to_delete=expanded_source), in_global=True, import_module=False)
|
|
563
607
|
self.run_py(python_code=command, uv_with=[MACHINECONFIG_VERSION], uv_project_dir=None, description="Cleaning temp zip files @ remote.", verbose_output=False, strict_stderr=True, strict_return_code=True)
|
|
564
608
|
|
|
565
609
|
print("\n")
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/remote_machine.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/remote/script_execution.py
RENAMED
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_local.py
RENAMED
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/cluster/sessions_managers/wt_remote.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/check_installations.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/__init__.py
RENAMED
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/alacritty.py
RENAMED
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/brave.py
RENAMED
|
File without changes
|
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/code.py
RENAMED
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/cursor.py
RENAMED
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/dubdb_adbc.py
RENAMED
|
File without changes
|
{machineconfig-6.64 → machineconfig-6.66}/src/machineconfig/jobs/installer/custom_dev/espanso.py
RENAMED
|
File without changes
|