Standard Components for the Pyvider Framework
Project description
๐งฉ๐ง Pyvider Components
Example components for the Pyvider Terraform provider framework
This repository provides a standard set of example components for the Pyvider framework, demonstrating how to build Terraform providers in Python.
โจ Key Features
- ๐ Learning Resources - Real-world examples of Pyvider components
- ๐ง Reusable Components - Data sources, resources, and functions ready to use
- ๐งช Test Patterns - Reference implementations for provider testing
- ๐๏ธ Build Templates - Fork and customize for your own providers
Quick Start
- Install:
uv add pyvider-components - Read the Documentation
- Explore Examples
Getting Started
To use the pyvider-components provider, configure it in your Terraform project:
terraform {
required_providers {
pyvider = {
source = "local/providers/pyvider"
version = ">= 0.0.0" # For development/learning
# For specific versions: version = "~> 0.1"
}
}
}
provider "pyvider" {
# Provider configuration options go here
}
Documentation
Development
Quick Start
# Set up environment
uv sync
# Run common tasks
we run test # Run tests
we run lint # Check code
we run format # Format code
we tasks # See all available commands
See CLAUDE.md for detailed development instructions and architecture information.
pytest
Contributing
See CONTRIBUTING.md for contribution guidelines.
License
See LICENSE for license details.
What is pyvider-components?
pyvider-components is a learning and reference library that demonstrates how to build Terraform provider components using the Pyvider framework. It contains working examples of resources, data sources, and functions that you can:
- ๐ Learn from - See real-world examples of Pyvider components
- ๐ Reference - Use as templates for your own providers
- ๐งช Test with - Try out Pyvider features without writing code
- ๐๏ธ Build on - Fork and customize for your needs
Note: This is primarily an example/learning library, not a production provider. For production use, the terraform-provider-pyvider packages these components into a deployable provider.
Relationship to terraform-provider-pyvider
โโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ pyvider (framework) โ โ Core framework for building providers
โโโโโโโโโโโโโฌโโโโโโโโโโโโโโ
โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ โ
โโโโโโโโโโโโโผโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโผโโโโโโโโโโโโโโโ
โ pyvider-components โโโโโโถโ terraform-provider-pyvider โ
โ (example library) โ โ (pre-release/testing provider) โ
โ โ โ โ
โ โข Learning resources โ โ โข Uses components from โ โ
โ โข Reference examples โ โ โข Packaged & tested โ
โ โข Component demos โ โ โข Pre-release learning tool โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Key Difference:
- pyvider-components: Learn how to build components (this repo)
- terraform-provider-pyvider: Pre-release provider for testing and learning (terraform-provider-pyvider)
When to use pyvider-components
Use this repository when you want to:
โ Learn how to build Pyvider providers โ See working examples of resources, data sources, and functions โ Experiment with Pyvider features โ Reference implementation patterns โ Build your own custom provider
When to use terraform-provider-pyvider
Use the provider when you want to:
โ Learn and experiment with Pyvider in Terraform โ Test provider functions and resources โ Follow a getting started tutorial โ Build sample configurations
Part of the provide.io Ecosystem
This project is part of a larger ecosystem of tools for Python and Terraform development.
Understand how provide-foundation, pyvider, flavorpack, and other projects work together.
Components
Data Sources
pyvider_env_variables: Provides access to environment variables.pyvider_file_info: Provides metadata about a file or directory.pyvider_http_api: Makes an HTTP request and returns the response.pyvider_lens_jq: Transforms data using a JQ expression.
Resources
pyvider_file_content: Manages the content of a file.pyvider_local_directory: Manages a directory on the local filesystem.pyvider_private_state_verifier: Verifies the private state of a resource (for testing).pyvider_timed_token: Manages a short-lived token (for testing).pyvider_warning_example: Demonstrates how to return warnings (for testing).
Functions
A rich set of utility functions are provided for common data manipulations.
- Numeric:
add,subtract,multiply,divide,sum,min,max,round - String:
upper,lower,split,join,replace,format,truncate,format_size,pluralize,to_snake_case,to_kebab_case,to_camel_case - Collection:
length,contains,lookup - Type Conversion:
tostring - Transformation:
lens_jq
Examples
Read Environment Variables
data "pyvider_env_variables" "shell" {
keys = ["SHELL"]
}
output "shell_path" {
value = data.pyvider_env_variables.shell.values["SHELL"]
}
Manage a File
resource "pyvider_file_content" "example" {
filename = "/tmp/example.txt"
content = "This file is managed by Terraform."
}
output "file_hash" {
value = pyvider_file_content.example.content_hash
}
Use a String Function
output "uppercase_example" {
value = provider::pyvider::upper("hello world")
}
Copyright (c) provide.io LLC.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyvider_components-0.4.0.tar.gz.
File metadata
- Download URL: pyvider_components-0.4.0.tar.gz
- Upload date:
- Size: 99.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a46fef39ca3e7024787948ef5d2052d715f0f6d69611a7e39fcd8a874ddc5aea
|
|
| MD5 |
0eefd29992f04e8aad66617827b41139
|
|
| BLAKE2b-256 |
81d9aadbc143f0f6bf92954714be3c403466cae285bb1922129740e3d92de795
|
File details
Details for the file pyvider_components-0.4.0-py3-none-any.whl.
File metadata
- Download URL: pyvider_components-0.4.0-py3-none-any.whl
- Upload date:
- Size: 150.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10122a6b54dfe310fb2167c35b1ee2858d7c1aa3a6fdabc0f00e1a44431ee80e
|
|
| MD5 |
c9b9448b178da408602e178eb2c67dc8
|
|
| BLAKE2b-256 |
8cef87f7327ff4deb78677aa9ecfdc273cdacf7c4706a947bf9d38de94d60a3c
|