Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luxchanlu/pulumi-supabase
Pulumi for supabase
https://github.com/luxchanlu/pulumi-supabase
go golang pulumi supabase
Last synced: about 2 months ago
JSON representation
Pulumi for supabase
- Host: GitHub
- URL: https://github.com/luxchanlu/pulumi-supabase
- Owner: LuxChanLu
- License: mit
- Created: 2022-10-31T14:10:44.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-01-08T21:37:33.000Z (almost 2 years ago)
- Last Synced: 2024-06-21T16:56:10.450Z (7 months ago)
- Topics: go, golang, pulumi, supabase
- Language: Python
- Homepage:
- Size: 207 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pulumi Component Provider Boilerplate (Go)
pulumi plugin install resource supabase --server github://api.github.com/LuxChanLu/pulumi-supabase
This repo is a boilerplate showing how to create a Pulumi component provider written in Go. You can search-replace `supabase` with the name of your desired provider as a starting point for creating a component provider for your component resources.## Background
This repository is part of the [guide for authoring and publishing a Pulumi Package](https://www.pulumi.com/docs/guides/pulumi-packages/how-to-author).Learn about the concepts behind [Pulumi Packages](https://www.pulumi.com/docs/guides/pulumi-packages/#pulumi-packages) and, more specifically, [Pulumi Components](https://www.pulumi.com/docs/intro/concepts/resources/components/)
## Sample supabase Component Provider
An example `StaticPage` [component resource](https://www.pulumi.com/docs/intro/concepts/resources/#components) is available in `provider/pkg/provider/staticPage.go`. This component creates a static web page hosted in an AWS S3 Bucket. There is nothing special about `StaticPage` -- it is a typical component resource written in Go.
The component provider makes component resources available to other languages. The implementation is in `provider/pkg/provider/provider.go`. Each component resource in the provider must have an implementation in the `Construct` function to create an instance of the requested component resource and return its `URN` and state (outputs). There is an initial implementation that demonstrates an implementation of `Construct` for the example `StaticPage` component.
A code generator is available which generates SDKs in TypeScript, Python, Go and .NET which are also checked in to the `sdk` folder. The SDKs are generated from a schema in `schema.yaml`. This file should be kept aligned with the component resources supported by the component provider implementation.
An example of using the `StaticPage` component in TypeScript is in `examples/simple`.
Note that the generated provider plugin (`pulumi-resource-supabase`) must be on your `PATH` to be used by Pulumi deployments. If creating a provider for distribution to other users, you should ensure they install this plugin to their `PATH`.
## Prerequisites
- Go 1.17
- Pulumi CLI
- Node.js (to build the Node.js SDK)
- Yarn (to build the Node.js SDK)
- Python 3.6+ (to build the Python SDK)
- .NET Core SDK (to build the .NET SDK)## Build and Test
```bash
# Build and install the provider (plugin copied to $GOPATH/bin)
make install_provider# Regenerate SDKs
make generate# Test Node.js SDK
$ make install_nodejs_sdk
$ cd examples/simple
$ yarn install
$ yarn link @pulumi/supabase
$ pulumi stack init test
$ pulumi config set aws:region us-east-1
$ pulumi up
```## Naming
The `supabase` provider's plugin binary must be named `pulumi-resource-supabase` (in the format `pulumi-resource-`).
While the provider plugin must follow this naming convention, the SDK package naming can be customized. TODO explain.
## Configuring CI and releases
1. Follow the instructions laid out in the [deployment templates](./deployment-templates/README-DEPLOYMENT.md).
## Example component
Let's look at the example `StaticPage` component resource in more detail.
### Schema
The example `StaticPage` component resource is defined in `schema.yaml`:
```yaml
resources:
supabase:index:StaticPage:
isComponent: true
inputProperties:
indexContent:
type: string
description: The HTML content for index.html.
requiredInputs:
- indexContent
properties:
bucket:
"$ref": "/aws/v4.0.0/schema.json#/resources/aws:s3%2Fbucket:Bucket"
description: The bucket resource.
websiteUrl:
type: string
description: The website URL.
required:
- bucket
- websiteUrl
```The component resource's type token is `supabase:index:StaticPage` in the format of `::`. In this case, it's in the `supabase` package and `index` module. This is the same type token passed to `RegisterComponentResource` inside the implementation of `NewStaticPage` in `provider/pkg/provider/staticPage.go`, and also the same token referenced in `Construct` in `provider/pkg/provider/provider.go`.
This component has a required `indexContent` input property typed as `string`, and two required output properties: `bucket` and `websiteUrl`. Note that `bucket` is typed as the `aws:s3/bucket:Bucket` resource from the `aws` provider (in the schema the `/` is escaped as `%2F`).
Since this component returns a type from the `aws` provider, each SDK must reference the associated Pulumi `aws` SDK for the language. For the .NET, Node.js, and Python SDKs, dependencies are specified in the `language` section of the schema:
```yaml
language:
csharp:
packageReferences:
Pulumi: 3.*
Pulumi.Aws: 4.*
go:
generateResourceContainerTypes: true
importBasePath: github.com/LuxChanLu/pulumi-supabase/sdk/go/supabase
nodejs:
dependencies:
"@pulumi/aws": "^4.0.0"
devDependencies:
typescript: "^3.7.0"
python:
requires:
pulumi: ">=3.0.0,<4.0.0"
pulumi-aws: ">=4.0.0,<5.0.0"
```For the Go SDK, dependencies are specified in the `sdk/go.mod` file.
### Implementation
The implementation of this component is in `provider/pkg/provider/staticPage.go` and the structure of the component's inputs and outputs aligns with what is defined in `schema.yaml`:
```go
// The set of arguments for creating a StaticPage component resource.
type StaticPageArgs struct {
IndexContent pulumi.StringInput `pulumi:"indexContent"`
}// The StaticPage component resource.
type StaticPage struct {
pulumi.ResourceStateBucket *s3.Bucket `pulumi:"bucket"`
WebsiteUrl pulumi.StringOutput `pulumi:"websiteUrl"`
}// NewStaticPage creates a new StaticPage component resource.
func NewStaticPage(ctx *pulumi.Context, name string, args *StaticPageArgs, opts ...pulumi.ResourceOption) (*StaticPage, error) {
...
}
```The provider makes this component resource available in the `construct` function in `provider/pkg/provider/provider.go`. When `construct` is called and the `typ` argument is `supabase:index:StaticPage`, we create an instance of the `StaticPage` component resource and return its `URN` and state.
```go
func constructStaticPage(ctx *pulumi.Context, name string, inputs provider.ConstructInputs,
options pulumi.ResourceOption) (*provider.ConstructResult, error) {// Copy the raw inputs to StaticPageArgs. `inputs.CopyTo` uses the types and `pulumi:` tags
// on the struct's fields to convert the raw values to the appropriate Input types.
args := &StaticPageArgs{}
if err := inputs.CopyTo(args); err != nil {
return nil, errors.Wrap(err, "setting args")
}// Create the component resource.
staticPage, err := NewStaticPage(ctx, name, args, options)
if err != nil {
return nil, errors.Wrap(err, "creating component")
}// Return the component resource's URN and state. `NewConstructResult` automatically sets the
// ConstructResult's state based on resource struct fields tagged with `pulumi:` tags with a value
// that is convertible to `pulumi.Input`.
return provider.NewConstructResult(staticPage)
}
```