Skip to main content

Wrapper for uv with artifact storage in airgapped environments

Project description

uvartage

A wrapper around uv for usage with artifact storage in airgapped environments

The uvartage command starts a REPL (read-eval-print loop) using the Python cmd module where environment variables have been set for uv and uvx to use an artifact storage that requires authentication.

Please note: so far, only Artifactory is supported as such an artifact storage backend.

For convenience, the git command is also supported.

Own command implementations include:

  • cd changes directories
  • env prints the available environment variables
  • list partially implements the functionality of the Unix ls command (ie. list files and/or directories)
  • pwd prints the working directory path
  • sh can be used to run arbitrary commands using the shell interpreter

The credentials for the user are asked at start time, and stored in environment variables for each repository.

The REPL features a simple history, and tab completion for a subset of the commands (currently, only list and sh, based on paths in the file system).

The loop can be left in different ways, depending on the operating system:

  • Unix: Ctrl-D
  • Windows: Ctrl-Z followed by the enter key
  • as an anternative, you could enter EOF literally and press the enter key to exit. This method should always work.

Prerequisites

uv has to be installed, but otherwise, only standard library modules are used.

Usage

Built.in usage information

[osuser@workstation workdir]$ uvartage --help
usage: uvartage [-h] [--version] [-v ] [--backend {artifactory}] [--ca-file CA_FILE] [--user USER]
                [USER@]HOSTNAME ...

Wrapper for uv with artifact storage in airgapped environments

positional arguments:
  [USER@]HOSTNAME       the artifact storage hostname, or user and hostname combined by '@'.
  repositories          the package repositories (default first). If not at least one repository name
                        is provided, the value of the environment variable UVARTAGE_DEFAULT_REPOSITORY
                        will be used.

options:
  -h, --help            show this help message and exit
  --version             print version and exit
  -v , --verbose        show more messages
  --backend {artifactory}
                        the artifact storage backend type (default and currently the only supported
                        backend: artifactory)
  --ca-file CA_FILE     a CA cert bundle file to be provided via SSL_CERT_FILE.
  --user USER           username for the artifact storage backend if the hostname is not explicitly
                        specified as USER@HOSTNAME; default is 'osuser'.

[osuser@workstation workdir]$

Example REPL start

... with examiniation of the environment variables set for uv

[osuser@workstation workdir]$ uvartage artuser@artifacts.example.com defaultrepo extrarepo1 extrarepo2
| Neither the environment variable 'SSL_CERT_FILE' has been set, nor a CA file explicitly through --ca-file.
| You might encounter problems if using a non-standard (i.e. organization internal) certificate authority.
Please enter the password for artuser on artifacts.example.com (input is hidden):
Welcome to the uv wrapper shell. Type help or ? to list commands.

«uvartage» [osuser@workstation workdir] env --include uv -- UV*
UV_DEFAULT_INDEX='primary=https://artifacts.example.com/artifactory/api/pypi/defaultrepo/simple'
UV_INDEX='extra1=https://artifacts.example.com/artifactory/api/pypi/extrarepo1/simple extra2=https://artifacts.example.com/artifactory/api/pypi/extrarepo2/simple'
UV_INDEX_EXTRA1_PASSWORD='[MASKED]'
UV_INDEX_EXTRA1_USERNAME='artuser'
UV_INDEX_EXTRA2_PASSWORD='[MASKED]'
UV_INDEX_EXTRA2_USERNAME='artuser'
UV_INDEX_PRIMARY_PASSWORD='[MASKED]'
UV_INDEX_PRIMARY_USERNAME='artuser'
«uvartage» [osuser@workstation workdir]

Supported commands in the REPL

«uvartage» [osuser@workstation workdir] ?

Documented commands (type help <topic>):
========================================
EOF  env  help  pip  python   set  spp    uv
cd   git  list  pwd  recover  sh   unset  uvx

«uvartage» [osuser@workstation workdir] ? EOF
Exit the REPL by EOF (eg. Ctrl-D on Unix)
«uvartage» [osuser@workstation workdir] ? cd
Change directory
«uvartage» [osuser@workstation workdir] ? env
Print the environment variables
«uvartage» [osuser@workstation workdir] ? git
Run git with the provided arguments
«uvartage» [osuser@workstation workdir] ? help
List available commands with "help" or detailed help with "help cmd".
«uvartage» [osuser@workstation workdir] ? list
Print directory contents (emulation)
«uvartage» [osuser@workstation workdir] ? pip
Run pip with the provided arguments
«uvartage» [osuser@workstation workdir] ? pwd
Print working directory
«uvartage» [osuser@workstation workdir] ? python
Run python (see output of python -V for the exact version)
«uvartage» [osuser@workstation workdir] ? recover
Recover one or more previously unset environment variables
«uvartage» [osuser@workstation workdir] ? set
Set an environment variable
«uvartage» [osuser@workstation workdir] ? sh
Run an arbitrary command through the shell
«uvartage» [osuser@workstation workdir] ? spp
Shortcut for set PYTHONPATH=<arg>, eg. spp src → set PYTHONPATH=src
«uvartage» [osuser@workstation workdir] ? unset
Unset (ie. reversibly delete) one or more environment variables
«uvartage» [osuser@workstation workdir] ? uv
Run uv with the provided arguments
«uvartage» [osuser@workstation workdir] ? uvx
Run uvx with the provided arguments
«uvartage» [osuser@workstation workdir]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

uvartage-0.4.0.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

uvartage-0.4.0-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file uvartage-0.4.0.tar.gz.

File metadata

  • Download URL: uvartage-0.4.0.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.15

File hashes

Hashes for uvartage-0.4.0.tar.gz
Algorithm Hash digest
SHA256 c2198b3b92eae244ae85a3227802a0549c580594402d147c43135d84e816ca21
MD5 760f0964dce1301da1b6224301338b6d
BLAKE2b-256 f5cfda457425504f7735533a68b174746c1ef40aab4ba5fa4ebd8c944c7e7583

See more details on using hashes here.

File details

Details for the file uvartage-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: uvartage-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.15

File hashes

Hashes for uvartage-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fa3e46d11fefb0ef62e096595fc9c4cae7a16f3abe9b623c01ca488d512dc076
MD5 d59d46bf5b759b99b5078cc36552cb22
BLAKE2b-256 f568208ab29dad319e8331d32051070e08b5162388b91540529cd3cde74bac11

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page