Skip to main content

EGI FedCloud client

Reason this release was yanked:

Outdated

Project description

FedCloud client: Command-line client and library for EGI Federated Cloud

fedcloud command-line client is based on egicli, a simple command-line interface and library for interacting with some of the services of EGI. The fedcloud command-line client extends the functionalities for interaction directly with Openstack sites in EGI Federated Cloud and perform commands on sites in the same way as the local in-site openstack client.

fedcloud client uses the same Openstack commands and options as openstack client. It uses site IDs and VOs for setting site/project that greatly improve user experiences and virtually makes EGI Federated Cloud look like single unified Cloud.

Example of using openstack client for listing VMs in a project in a site:

openstack server list -os-auth-url SITE_ENDPOINT --os-project-id PROJECT_ID -os-access-toke ACCESS_TOKEN
--os-auth-type v3oidcaccesstoken --os-protocol openid --os-identity-provider egi.eu

With fedcloud client:

fedcloud openstack server list --site SITE_ID --vo VO --checkin-access-token ACCESS_TOKEN

The full set of openstack client commands is described here.

Beside using as command-line client, fedcloud client can be used as development library for developers of tools and services for EGI Federated Cloud. See the demo code demo.py in /examples to see how the library is used.

Quick start

  • Install FedCloud client is via pip:
$ pip install fedcloudclient
  • Get a new access token from Check-in according to instructions from FedCloud Check-in client.
  • Check the expiration time of the access token using fedcloud command:
$ fedcloud token check --checkin-access-token ACCESS_TOKEN
  • List the VO memberships of the access token:
$ fedcloud token list-vos --checkin-access-token ACCESS_TOKEN
  • List the Openstack sites available in EGI Federated Cloud. That may take few seconds because all site configurations are retrieved from GitHub.
$ fedcloud site list
  • Save the site configuration to local machine at ~/.fedcloud-site-config/ to speed up the client's start in the next time:
$ fedcloud site save-config
  • List VMs in fedcloud.egi.eu VO on CYFRONET-CLOUD site (or other combination of site and VO you have access):
$ fedcloud openstack server list --site CYFRONET-CLOUD --vo fedcloud.egi.eu --checkin-access-token ACCESS_TOKEN
  • Learn more commands of fedcloud client and experiment with them:
$ fedcloud --help
$ fedcloud openstack --help
$ fedcloud site --help
  • Experiment with more Openstack commands, e.g. "fedcloud openstack image list". The full list of Openstack commands are available here.

Using fedcloudclient as development library

All functionalities offered by the fedcloud client can be used as a library for development of other tools and services for EGI Federated Cloud. For example, performing openstack command as a function in Python:

from fedcloudclient.openstack import fedcloud_openstack
....
json_object = fedcloud_openstack(
    checkin_access_token,
    site,
    vo,
    openstack_command)

See a working example "demo.py" in /examples. More documentations will be available soon.

FAQ

  1. The fedcloud client is slow.

Execute command "fedcloud site save-config" to download site configurations from GitHub and save them on local machine. That will significantly speedup site configurations loading.

  1. The fedcloud client fails with error message "SSL exception connecting to https:// ..." when attempts to interact with some sites.

Some sites use certificates issued by national grid CAs that are not included in default distribution, so fedcloud client cannot verify them. Follow instructions in documentation to install EGI Core Trust Anchor and add certificates to Python request certificate bundle.

  1. The fedcloud client fails with error message "Site XX or VO YY not found" but they do exist.

Site configurations at GitHub may be incomplete. Check the site configurations stored in ~/.fedcloud-site-config/ if the VOs are included. If not, you can ask site admins to fix site configuration. You can also execute "fedcloud endpoint projects --site SITE --checkin-access-token ACCESS_TOKEN" to find project IDs in the site and add the VOs to local site configuration on your machine manually.

  1. I would like to add supports for additional sites/VOs/identity providers that are not parts of EGI Federated Cloud.

Other identity providers may be specified via option "--checkin-url" or environment variable "CHECKIN_OIDC_URL". Additional sites and VOs may be added to local site configuration files.

  1. Why there are options for both access token and refresh token? Which one should be used?

Cloud operations need only access tokens, not refresh tokens. If a refresh token is given as parameter to fedcloud client (together with client ID and client secret), an access token will be generated on the fly from the refresh token and client ID/secret.

Refresh tokens have long lifetime (one year in EGI CheckIn), so they should be securely protected. In secured environment, e.g. private computers, refresh tokens may be permanently specified via environment variables CHECKIN_REFRESH_TOKEN, CHECKIN_CLIENT_ID, CHECKIN_CLIENT_SECRET; so users don't have to set token for fecloud client via command-line parameters.

Access tokens have short lifetime (one hour in EGI CheckIn), so they have lower security constraints. However, they have to be refreshed frequently, that may be inconvenient for some users. In shared environment, e.g. VMs in Cloud, access tokens should be used instead of refreshed tokens.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

fedcloudclient-0.0.2.dev10.tar.gz (24.8 kB view hashes)

Uploaded Source

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