UnknownSec Bypass
403
:
/
proc
/
thread-self
/
root
/
snap
/
lxd
/
29619
/
etc
/
bash_completion.d
/ [
drwxr-xr-x
]
Menu
Upload
Mass depes
Mass delete
Terminal
Info server
About
name :
snap.lxd.lxc
_have lxc && { _lxd_complete() { _lxd_names() { local state=$1 local keys=$2 local cmd="lxc list --format=csv --columns=ns" [ -n "$state" ] && cmd="$cmd | grep -E '$state$'" COMPREPLY=( $( compgen -W \ "$( eval $cmd | cut -d, -f1 ) $keys" "$cur" ) ) } _lxd_images() { COMPREPLY=( $( compgen -W "$( lxc image list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_remotes() { COMPREPLY=( $( compgen -W "$( lxc remote list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_profiles() { COMPREPLY=( $( compgen -W "$( lxc profile list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_projects() { COMPREPLY=( $( compgen -W "$( lxc project list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_networks() { COMPREPLY=( $( compgen -W "$( lxc network list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_restore_snapshots() { local name=$1 local query="/1.0/instances/$name/snapshots" COMPREPLY=( $( compgen -W "$( lxc query $query | sed -nr "s \s*\"$query/+(\w*)\",* \1 p" )" "$cur" ) ) } _lxd_storage_pools() { COMPREPLY=( $( compgen -W "$( lxc storage list --format=csv | cut -d, -f1 )" "$cur" ) ) } _lxd_storage_volumes() { COMPREPLY=( $( compgen -W "$( lxc storage volume list --format=csv | cut -d, -f1 )" "$cur" ) ) } COMPREPLY=() # ignore special --foo args if [[ ${COMP_WORDS[COMP_CWORD]} == -* ]]; then return 0 fi if [ -n "${SNAP_COMMON:-""}" ]; then export LXD_DIR=${LXD_DIR:-"${SNAP_COMMON}/lxd/"} fi lxc_cmds="alias cluster config console copy delete exec export file \ help image import info init launch list manpage monitor move network \ operation pause profile project publish query remote rename \ restart restore shell snapshot start stop storage version" global_keys="backups.compression_algorithm, core.https_address core.https_allowed_credentials \ core.https_allowed_headers core.https_allowed_methods \ core.https_allowed_origin candid.api.url candid.api.key candid.expiry \ candid.domains cluster.https_address \ core.proxy_https core.proxy_http core.proxy_ignore_hosts \ core.trust_password core.debug_address cluster.offline_threshold \ images.auto_update_cached images.auto_update_interval \ images.compression_algorithm images.remote_cache_expiry \ maas.api.url maas.api.key maas.machine cluster.images_minimal_replica \ rbac.agent.url rbac.agent.username rbac.agent.public_key \ rbac.agent.private_key rbac.api.expiry rbac.api.key rbac.api.url \ storage.backups_volume storage.images_volume" container_keys="boot.autostart boot.autostart.delay \ boot.autostart.priority boot.stop.priority \ boot.host_shutdown_timeout environment. \ limits.cpu limits.cpu.allowance limits.cpu.priority \ limits.disk.priority limits.memory limits.memory.enforce \ limits.memory.hugepages limits.kernel \ limits.memory.swap limits.memory.swap.priority limits.network.priority \ limits.processes linux.kernel_modules migration.incremental.memory \ migration.incremental.memory.goal nvidia.runtime \ nvidia.driver.capabilities nvidia.require.cuda nvidia.require.driver \ migration.incremental.memory.iterations raw.apparmor raw.idmap raw.qemu \ raw.lxc raw.seccomp security.idmap.base security.idmap.isolated \ security.idmap.size security.devlxd security.devlxd.images \ security.nesting security.privileged security.protection.delete \ security.protection.shift security.secureboot \ security.syscalls.allow \ security.syscalls.deny \ security.syscalls.deny_compat security.syscalls.deny_default \ security.syscalls.intercept.mknod security.syscalls.intercept.mount \ security.syscalls.intercept.mount.allowed \ security.syscalls.intercept.mount.fuse \ security.syscalls.intercept.setxattr \ security.syscalls.intercept.mount.shift \ snapshots.schedule snapshots.schedule.stopped snapshots.pattern \ snapshots.expiry \ volatile.apply_quota volatile.apply_template volatile.base_image \ volatile.idmap.base volatile.idmap.current volatile.idmap.next \ volatile.last_state.idmap volatile.last_state.power user.meta-data \ user.network-config user.network_mode user.user-data user.vendor-data" device_keys="limits.ingress limits.egress ipv4.routes ipv6.routes parent \ name mtu hwaddr vlan maas.subnet.ipv4 maas.subnet.ipv6 nictype \ host_name limits.max \ ipv4.address ipv6.address ipv4.host_address ipv6.host_address ipv4.gateway ipv6.gateway \ security.mac_filtering security.ipv4_filtering security.ipv6_filtering vlan limits.read \ limits.write path source optional readonly size recursive pool \ propagation shift major minor uid gid mode required vendorid productid \ pci id listen connect bind nat proxy_protocol security.uid security.gid \ boot.priority" networks_keys="bridge.driver bridge.external_interfaces bridge.mode \ bridge.mtu bridge.hwaddr dns.domain dns.mode fan.overlay_subnet fan.type \ fan.underlay_subnet ipv4.address ipv4.dhcp ipv4.dhcp.expiry ipv4.dhcp.gateway \ ipv4.dhcp.ranges ipv4.firewall ipv4.nat ipv4.nat.address ipv4.nat.order \ ipv4.routes ipv4.routing ipv6.address ipv6.dhcp ipv6.dhcp.expiry ipv6.dhcp.ranges \ ipv6.dhcp.stateful ipv6.firewall ipv6.nat ipv6.nat.address ipv6.nat.order \ ipv6.routes ipv6.routing maas.subnet.ipv4 maas.subnet.ipv6 raw.dnsmasq" project_keys="features.images features.profiles features.storage.volumes \ limits.containers limits.virtual-machines limits.memory limits.processes limits.cpu \ restricted restricted.containers.nesting restricted.containers.lowlevel \ restricted.containers.privilege restricted.virtual-machines.lowlevel restricted.devices.unix-char \ restricted.devices.unix-block restricted.devices.unix-hotplug restricted.devices.infiniband \ restricted.devices.gpu restricted.devices.usb restricted.devices.nic restricted.devices.disk \ restricted.devices.pci restricted.devices.proxy" storage_pool_keys="source size btrfs.mount_options ceph.cluster_name \ ceph.osd.force_reuse ceph.osd.pg_num ceph.osd.pool_name ceph.osd.data_pool_name \ ceph.rbd.clone_copy ceph.rbd.du ceph.rbd.features ceph.user.name cephfs.cluster_name cephfs.path \ cephfs.vg_name lvm.thinpool_name lvm.use_thinpool \ lvm.vg_name rsync.bwlimit volatile.initial_source \ volatile.pool.pristine volume.block.filesystem \ volume.block.mount_options volume.size volume.zfs.remove_snapshots \ volume.zfs.use_refquota zfs.clone_copy zfs.pool_name" storage_volume_keys="size block.filesystem block.mount_options \ security.unmapped security.shifted zfs.remove_snapshots zfs.use_refquota" if [ $COMP_CWORD -eq 1 ]; then COMPREPLY=( $(compgen -W "$lxc_cmds" -- ${COMP_WORDS[COMP_CWORD]}) ) return 0 fi local no_dashargs cur=${COMP_WORDS[COMP_CWORD]} no_dashargs=(${COMP_WORDS[@]// -*}) pos=$((COMP_CWORD - (${#COMP_WORDS[@]} - ${#no_dashargs[@]}))) if [ -z "$cur" ]; then pos=$(($pos + 1)) fi case ${no_dashargs[1]} in "config") case $pos in 2) COMPREPLY=( $(compgen -W "get set unset show edit metadata template device trust" -- $cur) ) ;; 3) case ${no_dashargs[2]} in "trust") COMPREPLY=( $(compgen -W "list add remove" -- $cur) ) ;; "device") COMPREPLY=( $(compgen -W "add get set unset list show remove" -- $cur) ) ;; "metadata") COMPREPLY=( $(compgen -W "show edit" -- $cur) ) ;; "template") COMPREPLY=( $(compgen -W "list show create edit delete" -- $cur) ) ;; "show"|"edit") _lxd_names ;; "get"|"set"|"unset") _lxd_names "" "$global_keys" ;; esac ;; 4) case ${no_dashargs[2]} in "trust") _lxd_remotes ;; "device") _lxd_names ;; "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$container_keys" -- $cur) ) ;; esac ;; 6) case ${no_dashargs[2]} in "device") case ${no_dashargs[3]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$device_keys" -- $cur) ) ;; esac ;; esac ;; esac ;; "copy") if [ $pos -lt 4 ]; then _lxd_names fi ;; "delete"|"info"|"move"|"publish"|"restart"|"snapshot"|"rename") _lxd_names ;; "start") _lxd_names "(STOPPED|FROZEN)" ;; "exec"|"console"|"stop"|"shell") _lxd_names "RUNNING" ;; "file") COMPREPLY=( $(compgen -W "pull push edit delete" -- $cur) ) ;; "help") COMPREPLY=( $(compgen -W "$lxc_cmds" -- $cur) ) ;; "image") COMPREPLY=( $(compgen -W "import copy delete refresh export info list show edit alias" -- $cur) ) ;; "init"|"launch") _lxd_images ;; "network") case $pos in 2) COMPREPLY=( $(compgen -W "list show create get set unset delete edit rename attach attach-profile detach detach-profile info" -- $cur) ) ;; 3) case ${no_dashargs[2]} in "show"|"get"|"set"|"unset"|"delete"|"edit"|"rename"|"attach"|"attach-profile"|"detach"|"detach-profile"|"info") _lxd_networks ;; esac ;; 4) case ${no_dashargs[2]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$networks_keys" -- $cur) ) ;; "attach"|"detach"|"detach-profile") _lxd_names ;; "attach-profile") _lxd_profiles ;; esac esac ;; "profile") case $pos in 2) COMPREPLY=( $(compgen -W "list show create copy get set unset delete edit rename assign add remove device " -- $cur) ) ;; 3) case ${no_dashargs[2]} in "device") COMPREPLY=( $(compgen -W "list show remove get set unset add" -- $cur) ) ;; "add"|"assign"|"remove") _lxd_names ;; *) _lxd_profiles ;; esac ;; 4) case ${no_dashargs[2]} in "device"|"add"|"assign"|"remove") _lxd_profiles ;; *) COMPREPLY=( $(compgen -W "$container_keys" -- $cur) ) ;; esac ;; 6) case ${no_dashargs[2]} in "device") case ${no_dashargs[3]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$device_keys" -- $cur) ) ;; esac ;; esac ;; esac ;; "project") case $pos in 2) COMPREPLY=( $(compgen -W "create delete edit get list rename set show switch unset " -- $cur) ) ;; 3) case ${no_dashargs[2]} in "get"|"set"|"unset"|"create"|"delete"|"edit"|"list"|"show"|"switch"|"rename") _lxd_projects ;; esac ;; 4) case ${no_dashargs[2]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$project_keys" -- $cur) ) ;; esac ;; 5) case ${no_dashargs[2]} in "rename") _lxd_projects ;; esac ;; esac ;; "remote") COMPREPLY=( $(compgen -W \ "add remove list rename set-url set-default get-default" -- $cur) ) ;; "restore") case $pos in 2) _lxd_names ;; 3) _lxd_restore_snapshots ${no_dashargs[2]} ;; esac ;; "storage_pools") case $pos in 2) COMPREPLY=( $(compgen -W "list show create get set unset delete edit" -- $cur) ) ;; 3) case ${no_dashargs[2]} in "show"|"get"|"set"|"unset"|"delete"|"edit") _lxd_storage_pools ;; esac ;; 4) case ${no_dashargs[2]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$storage_pool_keys" -- $cur) ) ;; esac esac ;; "storage_volumes") case $pos in 2) COMPREPLY=( $(compgen -W "list show create rename get set unset delete edit attach attach-profile detach detach-profile" -- $cur) ) ;; 3) case ${no_dashargs[2]} in "show"|"get"|"set"|"unset"|"rename"|"delete"|"edit"|"attach"|"attach-profile"|"detach"|"detach-profile") _lxd_storage_volumes ;; esac ;; 4) case ${no_dashargs[2]} in "get"|"set"|"unset") COMPREPLY=( $(compgen -W "$storage_volume_keys" -- $cur) ) ;; "attach"|"detach"|"detach-profile") _lxd_names ;; "attach-profile") _lxd_profiles ;; esac esac ;; *) ;; esac return 0 } complete -o default -F _lxd_complete lxc lxd.lxc }
Copyright © 2025 - UnknownSec