www/content/blog/terraform/forgejo.md
Julien Dessaux 8354360aaf
All checks were successful
/ all (push) Successful in 38s
fix(blog): add missing description and made a few edits
2025-06-11 13:53:24 +02:00

1.7 KiB

title description date tags
Writing an OpenTofu/Terraform provider for Forgejo My second open source provider 2025-05-28
Forgejo
OpenTofu
terraform

Introduction

Last month I started writing an OpenTofu/Terraform provider for Forgejo. I wanted to automate this forge in the same way I already automate GitHub: create and manage repositories, provision actions secrets and variables, configure issue labels, manage mirrors, etc.

A community provider already existed but it is really barebones and missing almost all the resources I need. I could have tried to contribute to it, but after looking at the code I decided to start from scratch.

I wrote providers before so I could get right to it.

Writing a Terraform provider

My notes from [writing a Terraform provider for eventline]({{< ref "eventline.md" >}}) still apply. With a few previous experiences writing providers, this has become straightforward work.

The only significant difficulties and frustrations arose from the Forgejo API which is pretty inconsistent to say it nicely. A community SDK forked from Gitea exists but after looking at its code I decided to write my own small API client.

Conclusion

Writing a Terraform provider is a lot of fun, I recommend it! If you have a piece of software that you wish had a Terraform provider, know that it is not hard to make it a reality. It is also a great learning project, being well-bounded in scope and immediately useful.

Here is the repository of my Forgejo provider for reference and here is the documentation.