Skip to main content

Library and CLI interface for accessing resto servers

Project description

Resto_client: a client to access resto servers

PyPI license Python versions PyPI version shields.io PyPI - Format PyPI - Downloads GitHub contributors

resto_client is a python package which gives you access to several remote sensing image servers which are based on the resto open source server.

Once you have installed it, resto_client offers the possibility to interact with these servers by issuing commands from a simple terminal. Currently implemented commands allow to:

  • define and manage a list of well known servers,
  • select one of them and browse its collection and their characteristics,
  • search a collection by criteria for retrieving features (images for instance) and display their characteristics,
  • show : retrieve and display feature metadata when you know its identifier,
  • download files composing the feature: the product itself, but also its quicklook, thumbnail or annexes,
  • authentication is supported to provide access to restricted features or sign product licenses when necessary.

Well known resto servers

resto_client comes with a list of well known servers already configured, which can be accessed out of the box:

This list is augmented regularly, but you can of course add your own server by providing its configuration through resto_client.

Supported environment

resto_client runs on the following configurations:

  • Python 3.6, 3.7 or 3.8
  • Any Operating System supporting the above versions of Python (Windows, Linux, MacOS, etc.)

resto_client tests are done on Windows and Linux using the supported python versions.

Resto_client installation

The recommended way to intall resto_client is to simply use pip which will install the package available from Python Package Index in your python environment:

$ pip install resto_client

Once resto_client package is installed you can test it by issuing the following command in a terminal:

$ resto_client --help

How to use resto_client?

Firstly you can select the server to be used for all subsequent commands. This selection is not mandatory and you may prefer to specify the server to use in each subsequent commands. But it is more convenient if you are using the same server for a long time.

You can use a well known server:

$ resto_client set server kalideos

Or configure a new one and set it:

$ resto_client configure_server create new_kalideos https://www.kalideos.fr/resto2 dotcloud https://www.kalideos.fr/resto2 default
$ resto_client set server new_kalideos

You can then show the server synthetic characteristics:

$ resto_client show server
Server URL: https://www.kalideos.fr/resto2/
+-----------------+--------+---------------------+------------+--------------+
| Collection name | Status |        Model        | License Id | License name |
+-----------------+--------+---------------------+------------+--------------+
|     KALCNES     | public | RestoModel_dotcloud | unlicensed |  No license  |
|     KALHAITI    | public | RestoModel_dotcloud | unlicensed |  No license  |
+-----------------+--------+---------------------+------------+--------------+

This shows you the server URL as well as its collection and their main characteristics. If you want the details of a collection, you can type in:

$ resto_client show collection KALCNES
+----------------------------------------------------------------------------+
|                        Collection's Characteristics                        |
+-----------------+--------+---------------------+------------+--------------+
| Collection name | Status |        Model        | License Id | License name |
+-----------------+--------+---------------------+------------+--------------+
|     KALCNES     | public | RestoModel_dotcloud | unlicensed |  No license  |
+-----------------+--------+---------------------+------------+--------------+

STATISTICS for KALCNES
+------------+-------------+
| collection | Nb products |
+------------+-------------+
| KALCNES    |        2599 |
| Total      |        2599 |
+------------+-------------+
+---------------+-------------+
| continent     | Nb products |
+---------------+-------------+
| Europe        |        2594 |
| North America |           1 |
| Total         |        2595 |
+---------------+-------------+
.

In fact the collection description contains much more statistics, but we have truncated the result for brevity.

You can search the collection for the features it contains, either by identifiers or by criteria. For instance:

$ resto_client search --criteria platform:"PLEIADES 1A" resolution:[0,1.5] startDate:2018-01-01 completionDate:2018-01-31 --collection=KALCNES
['1926127184714545', '6589984032241814', '1926091543104317', '1926059176484529']
4 results shown on a total of  4 results beginning at index 1

And you can get the details of some feature by specifying its identifier:

$ resto_client show feature 1926127184714545
Metadata available for product 1926127184714545
+--------------------+-------------------------------------------------------------------------------------------+
| Property           | Value                                                                                     |
+--------------------+-------------------------------------------------------------------------------------------+
| collection         | KALCNES                                                                                   |
| productIdentifier  | 1926127184714545                                                                          |
| parentIdentifier   | None                                                                                      |
| title              | PLEIADES 1A PAN L1A 2018-01-23 10:37:39Z                                                  |
| description        | L1A PAN image acquired by PLEIADES 1A on[...]                                             |
.

Here we have also truncated the result but there are much more metadata available for each feature.

Finally you may want to download some file associated to that feature : product, quicklook, thumbnail, annexes. The following example is for its quicklook:

$ resto_client download quicklook 1926127184714545
downloading file: c:\Users\xxxxxxx\Downloads\1926127184714545_ql.jpg
Downloading: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 128k/128k [00:09<00:00, 13.3kB/s]

Obviously you can also download the product, provided that you have the right credentials to access it if it is protected

$ resto_client download product 1926127184714545 --username=known_user
Please enter your password:***********
...

Every command has several options and there are also more commands to set different resto_client parameters or to define servers. You can discover their function and syntax by exploring the help on resto_client and on its subcommands :

$ resto_client --help
usage: resto_client [-h] {set,unset,show,download,search,configure_server} ...

A commmand line client to interact with resto servers.

optional arguments:
  -h, --help            show this help message and exit

subcommands:
  For more help: resto_client <sub_command> -h

  {set,unset,show,download,search,configure_server}
    set                 set application parameters: server, account,
                        collection, download_dir, region, verbosity
    unset               unset application parameters: server, account,
                        collection, download_dir, region, verbosity
    show                show resto_client entities: settings, server,
                        collection, feature
    download            download features files: product, quicklook, thumbnail
                        or annexes
    search              search feature(s) in collection
    configure_server    configure servers known by resto_client: create, edit,
                        delete.
$ resto_client show --help
usage: resto_client show [-h] {settings,server,collection,feature} ...

Show different resto_client entities.

optional arguments:
  -h, --help            show this help message and exit

subcommands:
  For more help: resto_client show show <entity> -h

  {settings,server,collection,feature}
    settings            Show application settings
    server              Show the server details
    collection          Show the details of a collection
    feature             Show feature details

Documentation

More documentation available soon.

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

resto_client-0.3.0.tar.gz (125.8 kB view details)

Uploaded Source

Built Distribution

resto_client-0.3.0-py3-none-any.whl (175.5 kB view details)

Uploaded Python 3

File details

Details for the file resto_client-0.3.0.tar.gz.

File metadata

  • Download URL: resto_client-0.3.0.tar.gz
  • Upload date:
  • Size: 125.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.0

File hashes

Hashes for resto_client-0.3.0.tar.gz
Algorithm Hash digest
SHA256 7551a3c82a11f1365dfb6d0cce7311b97e70d37c305781abde3a9ab71df43588
MD5 d8e60c867c711cf87db9659af1dcde15
BLAKE2b-256 5df16b6d0c881617b63d2b6fa3199c178b96183ae447ee97c8246de7861c87c5

See more details on using hashes here.

File details

Details for the file resto_client-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: resto_client-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 175.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.0

File hashes

Hashes for resto_client-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7132863faac5342101c38be4697ca9c15cb2671330582ae1e7c717c964c696d3
MD5 c3df032189d9a76a1ce1d0177831af36
BLAKE2b-256 2b735fc7c18909e05d3ab647f589605bfdb04aac4825a4fcfb40df896084d6cf

See more details on using hashes here.

Supported by

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