Skip to main content

Client library and command line tool for the Near Line Data Store (NLDS).

Project description

CEDA Near-Line Data Store Client

For more information please see the documentation.

This is the client used for interacting with the CEDA Near-Line Data Store (NLDS).

It consists of a library part (clientlib) and a command line client (nlds_client.py)

NLDS client is built upon Requests and Click

NLDS client requires Python 3.10 or greater. It has been tested with Python 3.10, 3.11 and 3.12.

Installation

To install directly from the GitHub repository.

  1. Create a python virtual environment:

    python3 -m venv ~/nlds-client
    
  2. Activate your new virtual environment:

    source ~/nlds-client/bin/activate
    
  3. Install the nlds-client package directly from this github repo:

    pip install git+https://github.com/cedadev/nlds-client.git
    

To install from PyPi (v1.0.13 and newer).

  1. Create a python virtual environment:

    python3 -m venv ~/nlds-client
    
  2. Activate your new virtual environment:

    source ~/nlds-client/bin/activate
    
  3. Install the nlds-client package from PyPi:

    pip install nlds-client
    

If installing this repository for development we recommend you install with the editable flag (-e).

Config

NLDS client requires a config file in the user's home directory: ~/.nlds-config. This file contains information about the JASMIN infrastructure and so is not included in the GitHub repository. A Jinja-2 template is included in the nlds_client/templates/nlds-config.j2 file.

This config file requires information about the JASMIN OAuth2 authentication server, including the oauth_client_id, oauth_client_secret and various URLs. These can be populated by using the command

nlds init

This will need to be pointed at an appropriate NLDS server url but will default to the one hosted on JASMIN - see the relevant section of the docs for more details.

When the NLDS client is first used, the user will be prompted to enter their username and password. This is the username and password for the JASMIN accounts portal. The token is stored at a location defined in the ~/.nlds-config file with the key oauth_token_file_location.

To use the NLDS you will also need to provide a token and secret_key to access the object store you would like to use as an NLDS cache. Details for how to do this are in the documentation.

Usage

Upon installation, an alias for the NLDS client is created: nlds. This can be used to PUT and GET files and filelists to and from an NLDS server, as well as a whole host of other commands. See the documentation for an extensive tutorial. A reference of all available commands is also available.

Tests

Automatic unit-testing is run with pytest, to manually run the tests for a local development environment, first ensure the appropriate version of pytest is installed in your venv. From the root of the repository, run:

pip install -r tests/requirements.txt

and then, similarly from the root of the repo, run the tests with:

pytest

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

nlds_client-1.0.17rc2.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

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

nlds_client-1.0.17rc2-py3-none-any.whl (29.2 kB view details)

Uploaded Python 3

File details

Details for the file nlds_client-1.0.17rc2.tar.gz.

File metadata

  • Download URL: nlds_client-1.0.17rc2.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.6

File hashes

Hashes for nlds_client-1.0.17rc2.tar.gz
Algorithm Hash digest
SHA256 d82dbfda31d95cddc60d5ea719eb86317fae7c7d36656470eb58625e576b4507
MD5 8694d34058e32f795c07c5c204ce7b72
BLAKE2b-256 12156a859e718d2d1ee3554c44018f79e4293d4903734cfcf020de17e415908c

See more details on using hashes here.

File details

Details for the file nlds_client-1.0.17rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for nlds_client-1.0.17rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 297a662949e1b40a4a3fdae12df185d0463bd512cc0daa90de8ae26df036b54d
MD5 14f979b4f22dcaf1d842dd5cdce6c8c4
BLAKE2b-256 48fbc1a47c8641f72b5e5bee7af5dceb148230b12c74b45cb15260ba0081eff7

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