Skip to main content

Python Boilerplate contains all the boilerplate you need to create a Python package.

Project description

steampipe-alchemy

https://img.shields.io/pypi/v/steampipe_alchemy.svg https://github.com/RyanJarv/steampipe_alchemy/actions/workflows/main_tests.yml/badge.svg https://github.com/RyanJarv/steampipe_alchemy/actions/workflows/publish.yml/badge.svg Documentation Status

A simple SQLAlchemy wrapper around Steampipe.

Currently this is a work in progress. Models exist for the AWS plugin, others will be added in the future.

Features

Install, setup, and start steampipe with the aws plugin.

# We're assuming the the AWS credentials are set in the environment here.
from steampipe_alchemy as sa

sa.install(['aws'])  # Downloads and installs steampipe with the aws plugin.
sa.update_config(aws={ #  Modifies ~/.local/share/steampipe_alchemy/config/aws.spc
    "plugin": "aws",
    "regions": ['us-east-1', 'us-west-1', 'us-west-2']
})
sa.start()  # Steampipe will be stopped when the script exits or when stop() is called.

We can then use the SQLAlchemy models to query AWS.

from steampipe_alchemy import query
from steampipe_alchemy.models import AwsS3Bucket

for b in query(AwsS3Bucket).limit(3):
    print(b.name)
    print("  Region: " + b.region)
    print("  Owner: " + str(b.acl['Owner']['DisplayName']))

Which will produce something like:

example-bucket-1234
  Region: us-east-1
  Owner: example-prod-account
example-bucket-2345
  Region: us-west-1
  Owner: example-prod-account
example-bucket-3456
  Region: us-west-2
  Owner: example-prod-account

The function steampipe_alchemy.query is a small wrapper around sqlalchemy.orm.Query. It is setup to use the steampipe sqlalchemy session and has type annotations which enable IDE completion on both the Model results and the Query class.

https://raw.githubusercontent.com/RyanJarv/steampipe_alchemy/main/docs/images/completion.png

Models are located in steampipe_alchemy.models and are automatically generated with ./scripts/generate_models.py.

Credits

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

History

0.1.0 (2021-04-15)

  • First release on PyPI.

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

steampipe_alchemy-0.1.6.tar.gz (120.0 kB view hashes)

Uploaded Source

Built Distribution

steampipe_alchemy-0.1.6-py2.py3-none-any.whl (104.7 kB view hashes)

Uploaded Python 2 Python 3

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