Skip to main content

An intuitive command line interface that wraps boto3 to search and manage media assets

Project description

Media Management Command Line Interface

PyPI Downloads Supported Versions Contributors Tests

Summary

An intuitive command line interface that wraps boto3 to search and manage media assets

Installing mgmt & Supported Versions

mgmt is available on PyPI:

uv tool install mgmt

Media Management Command Line Interface officially supports Python 3.9, 3.10, 3.11, 3.12, 3.13, and 3.14.

Quick Start

  • setup global config file ~/.config/mgmt/config
mgmt config

fill out prompts

mgmt config

check configs are correct

mgmt ls

Supported Features & Usage

For help, run:

 mgmt --help

 Usage: mgmt [OPTIONS] COMMAND [ARGS]...

╭─ Options ───────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ --version          Show the version and exit.                                                                   │
│ --help             Show this message and exit.                                                                  │
╰─────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
╭─ Commands ──────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ config        Configures the application                                                                        │
│ delete        Deletes the specified file from S3; requires confirmation                                         │
│ download      Downloads the specified file from S3                                                              │
│ ls            Lists the files in the specified location                                                         │
│ search        Searches for files that contain the specified keyword in their names                              │
│ status        Retrieves and prints the metadata of the specified file                                           │
│ upload        Uploads the specified file to S3                                                                  │
╰─────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯

Why not use awscli?

You can, and I do, in tandem with mgmt -- the purpose is to create an additional interface that minimized the lookup/copy/paste process I found myself frequently going through

Development

To contribute to this tool, first checkout the code:

git clone https://github.com/will-wright-eng/media-mgmt-cli.git
cd media-mgmt-cli

Prerequisites

This project uses uv for fast and reliable dependency management. Install uv if you haven't already:

# Install uv (recommended)
curl -LsSf https://astral.sh/uv/install.sh | sh

# Or via pip
pip install uv

Development Setup

The project includes a comprehensive Makefile for development tasks:

# Complete project setup (installs dependencies and pre-commit hooks)
make setup

# Or manually:
uv sync --extra test --extra dev
uv run pre-commit install

Available Development Commands

# Run tests
make test

# Run linting and formatting
make lint

# Fix linting issues
make lint-fix

# Show CLI help
make cli

# Clean up build artifacts
make clean

# Show project status
make status

Code Quality

The project uses modern Python tooling for code quality:

  • Ruff: Fast linting and formatting
  • ty: Type checking
  • Pre-commit: Automated quality checks
  • Codespell: Spelling checks

All quality checks run automatically on commit via pre-commit hooks.

Why uv?

This project uses uv for dependency management because it offers:

  • 🚀 Speed: 10-100x faster than pip for dependency resolution
  • 🔒 Reliability: Deterministic builds with lock files
  • 🛠️ Modern tooling: Built-in support for virtual environments, project management, and publishing
  • 📦 Better dependency resolution: More reliable conflict resolution than traditional tools
  • 🔄 Drop-in replacement: Compatible with existing pip workflows

Project Status

This project follows modern Python development practices:

  • Modern dependency management with uv
  • Comprehensive CI/CD with GitHub Actions
  • Automated code quality with Ruff, ty, and pre-commit
  • Type safety with comprehensive type hints
  • Testing with pytest and coverage reporting
  • Documentation with automated quality checks

Modern Python Development

This project showcases modern Python development practices:

  • uv for fast dependency management and project tooling
  • Ruff for lightning-fast linting and formatting
  • ty for static type checking
  • Pre-commit for automated quality gates
  • GitHub Actions for CI/CD automation
  • Hatchling for modern Python packaging

References

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

mgmt-0.10.0.tar.gz (75.7 kB view details)

Uploaded Source

Built Distribution

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

mgmt-0.10.0-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file mgmt-0.10.0.tar.gz.

File metadata

  • Download URL: mgmt-0.10.0.tar.gz
  • Upload date:
  • Size: 75.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mgmt-0.10.0.tar.gz
Algorithm Hash digest
SHA256 793d38ba22d1da4bdb9fc9ecb593d6d64b77f7585ef6ca66b182fa9f977b1ba8
MD5 24770bec3d218bf19ff455eea425394b
BLAKE2b-256 1a9124af1257e5c014318e8a0f46f917bc3eb8609dfca7e9cd8904afb727ef3f

See more details on using hashes here.

File details

Details for the file mgmt-0.10.0-py3-none-any.whl.

File metadata

  • Download URL: mgmt-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 27.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mgmt-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 31f6b31025cd797592994e7351111cedb55b6b05362374b9c267ef1ab9224845
MD5 b991d951b875b3aa9d8f62fb520fd2d5
BLAKE2b-256 958e87a658ccbd7761bcd4f0199f4f8637bddc37a03eec0b9c1b41171e7371aa

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