This is a Terraform provider for Telnyx. It is currently in alpha status and not recommended for production use.
Official documentation is hosted on the Terraform Registry.
Ensure the following tools are installed before starting development:
- direnv — for managing environment variables automatically.
- asdf — for managing language versions.
 ⚠️ Install using the officialgitmethod to avoid issues with pre-commit hooks locating~/.asdf/bin.
Note: These tools require a UNIX-like shell (bash, zsh). On Windows, use WSL or Git Bash. If using PyCharm, configure the terminal to use Git Bash.
- 
Create a .envfile at the project root and set the following variable:TELNYX_API_KEY=your_api_key_here 
- 
Run direnv allowin the project directory to load environment variables automatically.
- 
Run tests: just test
- 
Format Go code: just format-go 
- 
Format Terraform (HCL) code: just format-hcl 
- 
Environment variables are managed using .envanddirenv.
Docker provides a consistent and isolated environment, particularly useful when local setups vary or when running CI pipelines.
- 
Build Docker Image: just build-docker 
- 
Run Tests in Docker: just test-docker 
- 
Generate Documentation in Docker: just gen-docs-docker 
- 
Open an Interactive Development Shell (Alpine-based): just dev-docker 
⚠️ Docker workflows are ephemeral; no build artifacts or state persist between runs.
| Task | Local Command | Docker Command | 
|---|---|---|
| Run Tests | just test | just test-docker | 
| Format Go Code | just format-go | N/A | 
| Format HCL Code | just format-hcl | N/A | 
| Generate Docs | N/A | just gen-docs-docker | 
| Interactive Shell | N/A | just dev-docker | 
This project follows Conventional Commits to power Semantic Release.
- 
Commit Format: <type>[optional scope]: <description>Examples: - feat: Add new resource for SIP trunking
- fix(provider): Resolve issue with API key handling
 
- 
Pull Requests: - Name PRs using the conventional commit format. This ensures clean, semantically meaningful commits when merging.
 
- This project uses Husky and Lint-Staged to enforce formatting and validate commit messages.
- If a commit fails, ensure your message follows the Conventional Commits format and code formatting is correct.
This project uses just for repeatable development workflows. Review the justfile for additional commands.
This project is maintained by Patient Engagement Technologies.