Skip to main content

A set of useful APIs for cloudmesh

Project description

Cloudmesh Common

image Python License Format Status Travis

Installation and Documentation

Please note that several packages are available which are pointed to in the installation documentation.

Links
Documentation https://cloudmesh.github.io/cloudmesh-manual/autoapi/cloudmeshcommon/cloudmesh/index.html#module-cloudmesh-common.cloudmesh
Code https://github.com/cloudmesh/cloudmesh-common
Installation Instructions https://github.com/cloudmesh/get

Highlighted features

This library contains a number of useful functions and APIs that we highlight here. They are used to interact with the system and provide a number of functions to implement command line programs and shells.

The intention of cloudmesh-common is to provide convenience to the user with even simpler Python functions than those built-in, giving richer output messages, more concise file operations, and other goodies.

Console

The console provides convenient way to print colored messages types in the terminal, such as errors, info, and regular messages

from cloudmesh.common.console import Console

Console.error("this is an error printed in red with prefix ERROR:")
Console.msg("this is a msg printed in black")
Console.ok("this is an ok message printed in green")

Shell

We have lots of shell commands that call linux commands, but also have a convenient execution command that returns the results in a string.

Shell functions such as run tend to work cross-platform (including Windows), but it is up to the user to ensure that commands and software are available on the system beforehand.

For more information we like you to inspect the source code:

from cloudmesh.common.Shell import Shell

shell = Shell()

print(shell.terminal_type())

# prints after the command is finished
r = shell.execute('pwd') 
print(r)

# prints while the command is executed
r = shell.live('pwd') 
print(r)

# open a new terminal and start the command ls in it (for OSX and Gnome)
shell.terminal("ls")

# an example of a build in command
shell.pip("install cloudmesh-common")

We have many such build in commands, please see the source

Printer

A convenient way to print dictionaries and lists with repeated entries as tables, csv, json, yaml. The dictionaries can even be hierarchical.

Let us assume we have

from cloudmesh.common.Printer import Printer

data = [
    {
        "name": "Gregor",
        "address": {
            "street": "Funny Lane 11",
            "city": "Cloudville"
        }
    },
    {
        "name": "Albert",
        "address": {
            "street": "Memory Lane 1901",
            "city": "Cloudnine"
        }
    }
]

Then we can print it nicely with

print(Printer.flatwrite(data,
                    sort_keys=["name"],
                    order=["name", "address.street", "address.city"],
                    header=["Name", "Street", "City"],
                    output="table")
          )

Output:

+--------+------------------+------------+
| Name   | Street           | City       |
+--------+------------------+------------+
| Gregor | Funny Lane 11    | Cloudville |
| Albert | Memory Lane 1901 | Cloudnine  |
+--------+------------------+------------+

Other formats such as csv, json, dict are also supported.

In addition we have also printers for printing attribute lists. Please consult the source code.

StopWatch

StopWatch is meant for benchmarking program runtimes, including custom user-set sections of such programs.

See: https://colab.research.google.com/drive/1tG7IcP-XMQiNVxU05yazKQYciQ9GpMat#scrollTo=TZAjATZiQh4q&uniqifier=1 for an example

Using Cloudmesh StopWatch Inline

from cloudmesh.common.StopWatch import StopWatch
import time

StopWatch.start("a")
time.sleep(3)
StopWatch.stop("a")
StopWatch.status("a", True)
StopWatch.benchmark()

Using Cloudmesh Benchmark wrapped in Functions

If it is not wrapped in functions, do not use it this way.

from cloudmesh.common.Benchmark import Benchmark
import time
  
def b():
  Benchmark.Start()
  time.sleep(3)
  Benchmark.Stop()

def c():
  Benchmark.Start()
  time.sleep(1)
  Benchmark.Stop()

 b()
 c()

Benchmark.print()

dotdict

One dimensional Dictionaries in dot format.

from cloudmesh.common.dotdict import dotdict

# convert a simple dict to a dotdict
d = dotdict({"name": "Gregor"})
# Now you can say
print(d["name"])
print(d.name)

ssh

Allows for a robust configuration of secure-shell (remote access to hosts)

util

Very useful functions are included in util

Especially useful are

  • generate_password
    • generates a random password from letters and numbers
  • banner and str_banner
    • outputs a prominent message in the console for debugging and cohesiveness
  • yn_choice
    • to ask the user "yes" or "no" and account for various answers like "Y"
  • path_expand
    • to automatically replace path symbols such as ~ with the home dir
    • works cross-platform across OS's
  • grep
    • simple line matching but as a python method
  • HEADING
    • which, without parameter, identifies the name of the function and prints its name within a banner

Changes

  • added support for terminals with dark background

Acknowledgments

Continued work was in part funded by the NSF CyberTraining: CIC: CyberTraining for Students and Technologies from Generation Z with the award numbers 1829704 and 2200409.

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

cloudmesh_common-5.0.64.tar.gz (115.0 kB view details)

Uploaded Source

Built Distribution

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

cloudmesh_common-5.0.64-py2.py3-none-any.whl (113.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file cloudmesh_common-5.0.64.tar.gz.

File metadata

  • Download URL: cloudmesh_common-5.0.64.tar.gz
  • Upload date:
  • Size: 115.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for cloudmesh_common-5.0.64.tar.gz
Algorithm Hash digest
SHA256 7f0e551843f4d6b25b5c30e5706fdca4403384e1bb51b30065242dc5b2f673f3
MD5 b79531aa110b99beea9041437d91a44a
BLAKE2b-256 8ebdf5906ffcab049affb99616e9f5e87b44741492cc99fa8bde553bf1bf112a

See more details on using hashes here.

File details

Details for the file cloudmesh_common-5.0.64-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for cloudmesh_common-5.0.64-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 eef061d81a202f2a76f6e0ade200f1cbff6fd51a05269f2b5b9c699cf67b3230
MD5 0a654ff1bae3d88c2d2ce161c2b9e666
BLAKE2b-256 ac8c2f017e5e1ea7afbc5db33b05047c106c426dda3c6f4fb87e9d6a2017c483

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