Skip to main content

A simple API for serving the metadata from the RPM repositories

Project description

mdapi

A simple and fast API for serving the metadata from the RPM repositories

Installation

For development

  1. Install Python 3, Virtualenv and Poetry on your Fedora Linux installation.
    $ sudo dnf install python3 python3-virtualenv poetry
    
  2. Clone the repository to your local storage and make it your present working directory.
    $ git clone git@github.com:fedora-infra/mdapi.git
    $ cd mdapi
    
  3. Set up and activate a virtual environment within the directory of the cloned repository.
    $ virtualenv venv
    $ source venv/bin/activate
    
  4. Check the validity of the project configuration and install the project dependencies from the lockfile.
    $ (venv) poetry check
    $ (venv) poetry install
    

For container image

  1. Install Podman on your Fedora Linux installation.
    $ sudo dnf install podman
    
  2. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
    3. The project configuration is modified according to needs in myconfig.py file, following the instructions provided in the configuration setup section.
  3. Execute the following command to build the container image.
    $ (venv) podman build -t "mdapi:$(poetry version -s)" .
    

Usage

In development

Viewing the help message and version

  1. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
  2. Execute the following command to view the help message.
    $ (venv) mdapi --help
    
    Output
    Usage: mdapi [OPTIONS] COMMAND [ARGS]...
    
      A simple API for serving the metadata from the RPM repositories
    
    Options:
      -c, --conffile PATH  Read configuration from the specified Python file
      --version            Show the version and exit.
      --help               Show this message and exit.
    
    Commands:
      database  Fetch SQLite databases from all active Fedora Linux and EPEL...
      serveapp  Start the API server for querying repository metadata
    
  3. Execute the following command to view the project version.
    $ (venv) mdapi --version
    
    Output
    mdapi, version 3.0.0
    

Testing the project

  1. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
    3. The storage partition on which test database directory is located has at least 1.5 GiB of free space.
  2. Execute the following command to run the code quality checks and testcases.
    $ (venv) tox
    

Setting up the configuration

  1. Ensure that
    1. The project directory is the present working directory.
  2. Make a copy of the default configuration on your local storage.
    $ cp mdapi/confdata/standard.py mdapi/confdata/myconfig.py
    
  3. Make changes to the copied configuration file to suit the requirements.
    $ nano confdata/myconfig.py
    

Fetching the databases

  1. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
    3. The storage partition on which database directory is located has at least 6 GiB of free space.
  2. Execute the following command to start fetching the database, while referencing to the modified configuration file.
    $ (venv) mdapi --conffile myconfig.py database
    
  3. Note that the first run of the database fetching command will take a long time, depending on the internet connection.

Serving the application

  1. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
  2. Execute the following command to start serving the application, while referencing to the modified configuration file.
    $ (venv) mdapi --conffile myconfig.py serveapp
    
  3. When done with serving the application, press Ctrl + C to raise a KeyboardInterrupt and exit out of the program.

In container or pod

Serving the application

  1. Ensure that
    1. The project directory is the present working directory.
    2. The virtual environment with the project is activated, following the instructions provided in the development installation section.
    3. The container image is built and available locally.
    4. The databases are downloaded to the database directory, following the instructions provided in the database fetching section.
  2. Execute the following command to start the serving the application.
    $ (venv) podman run -v /var/tmp:/var/tmp -p 8080:8080 -ti mdapi:$(poetry version -s)
    
    This command assumes that the database directory is /var/tmp (which is the default) and the service port is 8080 (which is the default).

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

mdapi-3.1.6a1.tar.gz (28.9 kB view details)

Uploaded Source

Built Distribution

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

mdapi-3.1.6a1-py3-none-any.whl (37.2 kB view details)

Uploaded Python 3

File details

Details for the file mdapi-3.1.6a1.tar.gz.

File metadata

  • Download URL: mdapi-3.1.6a1.tar.gz
  • Upload date:
  • Size: 28.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.2 Linux/6.9.0-0.rc2.20240403git026e680b0a08.25.fc41.x86_64

File hashes

Hashes for mdapi-3.1.6a1.tar.gz
Algorithm Hash digest
SHA256 1e7beacf7055c53a347c77758ca16db0898d4c9ecaa29443d3fbde0c13982e38
MD5 55c04d63e1a6f7254ca1d29851c86fcb
BLAKE2b-256 4467c9ff33eb22349814727c46c94aaa93c02a0a107f5aea76e5ae30ac80bbba

See more details on using hashes here.

File details

Details for the file mdapi-3.1.6a1-py3-none-any.whl.

File metadata

  • Download URL: mdapi-3.1.6a1-py3-none-any.whl
  • Upload date:
  • Size: 37.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.2 Linux/6.9.0-0.rc2.20240403git026e680b0a08.25.fc41.x86_64

File hashes

Hashes for mdapi-3.1.6a1-py3-none-any.whl
Algorithm Hash digest
SHA256 643fe805d11211384de7a7a5985be378e5c0624ad8ac6299e99b7c42bc9d7fa3
MD5 a08db371a204ffc56b91681e65b16ac6
BLAKE2b-256 a7f3746b466429550a9359cbe6b5e7d4e61f245242e4cef2e0a5541ee57c9e68

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