Skip to content

Commit

Permalink
feat: reimplement "mackerel_role_metadata" resource
Browse files Browse the repository at this point in the history
  • Loading branch information
tosuke committed Aug 7, 2024
1 parent 3d46bc5 commit dad098d
Show file tree
Hide file tree
Showing 4 changed files with 198 additions and 0 deletions.
1 change: 1 addition & 0 deletions internal/provider/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ func (m *mackerelProvider) Resources(context.Context) []func() resource.Resource
return []func() resource.Resource{
NewMackerelNotificationGroupResource,
NewMackerelRoleResource,
NewMackerelRoleMetadataResource,
NewMackerelServiceResource,
NewMackerelServiceMetadataResource,
}
Expand Down
171 changes: 171 additions & 0 deletions internal/provider/resource_mackerel_role_metadata.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,171 @@
package provider

import (
"context"

"github.com/hashicorp/terraform-plugin-framework-jsontypes/jsontypes"
"github.com/hashicorp/terraform-plugin-framework/path"
"github.com/hashicorp/terraform-plugin-framework/resource"
"github.com/hashicorp/terraform-plugin-framework/resource/schema"
"github.com/hashicorp/terraform-plugin-framework/resource/schema/planmodifier"
"github.com/hashicorp/terraform-plugin-framework/resource/schema/stringplanmodifier"
"github.com/hashicorp/terraform-plugin-framework/schema/validator"
"github.com/mackerelio-labs/terraform-provider-mackerel/internal/mackerel"
)

var (
_ resource.Resource = (*mackerelRoleMetadataResource)(nil)
_ resource.ResourceWithConfigure = (*mackerelRoleMetadataResource)(nil)
_ resource.ResourceWithImportState = (*mackerelRoleMetadataResource)(nil)
)

func NewMackerelRoleMetadataResource() resource.Resource {
return &mackerelRoleMetadataResource{}
}

type mackerelRoleMetadataResource struct {
Client *mackerel.Client
}

func (r *mackerelRoleMetadataResource) Metadata(_ context.Context, req resource.MetadataRequest, resp *resource.MetadataResponse) {
resp.TypeName = req.ProviderTypeName + "_role_metadata"
}

func (r *mackerelRoleMetadataResource) Schema(_ context.Context, _ resource.SchemaRequest, resp *resource.SchemaResponse) {
resp.Schema = schema.Schema{
Description: "This resource creates and manages a Role Metadata.",

Attributes: map[string]schema.Attribute{
"id": schema.StringAttribute{
Computed: true,
PlanModifiers: []planmodifier.String{
stringplanmodifier.UseStateForUnknown(), // immutable
},
},
"service": schema.StringAttribute{
Description: "The name of the service.",
Required: true,
Validators: []validator.String{
mackerel.ServiceNameValidator(),
},
PlanModifiers: []planmodifier.String{
stringplanmodifier.RequiresReplace(), // force new
},
},
"role": schema.StringAttribute{
Description: "The name of the role.",
Required: true,
Validators: []validator.String{
mackerel.RoleNameValidator(),
},
PlanModifiers: []planmodifier.String{
stringplanmodifier.RequiresReplace(), // force new
},
},
"namespace": schema.StringAttribute{
Description: "The idenfier for the metadata.",
Required: true,
PlanModifiers: []planmodifier.String{
stringplanmodifier.RequiresReplace(), // force new
},
},
"metadata_json": schema.StringAttribute{
Description: "Arbitrary JSON data for the role.",
Required: true,
CustomType: jsontypes.NormalizedType{},
},
},
}
}

func (r *mackerelRoleMetadataResource) Configure(ctx context.Context, req resource.ConfigureRequest, resp *resource.ConfigureResponse) {
client, diags := retrieveClient(ctx, req.ProviderData)
resp.Diagnostics.Append(diags...)
if diags.HasError() {
return
}
r.Client = client
}

func (r *mackerelRoleMetadataResource) Create(ctx context.Context, req resource.CreateRequest, resp *resource.CreateResponse) {
var data mackerel.RoleMetadataModel
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}

if err := data.Create(ctx, r.Client); err != nil {
resp.Diagnostics.AddError(
"Unable to create Role Metadata",
err.Error(),
)
return
}

resp.Diagnostics.Append(resp.State.Set(ctx, &data)...)
}

func (r *mackerelRoleMetadataResource) Read(ctx context.Context, req resource.ReadRequest, resp *resource.ReadResponse) {
var data mackerel.RoleMetadataModel
resp.Diagnostics.Append(req.State.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}

if err := data.Read(ctx, r.Client); err != nil {
resp.Diagnostics.AddError(
"Unable to read Role Metadata",
err.Error(),
)
return
}

resp.Diagnostics.Append(resp.State.Set(ctx, &data)...)
}

func (r *mackerelRoleMetadataResource) Update(ctx context.Context, req resource.UpdateRequest, resp *resource.UpdateResponse) {
var data mackerel.RoleMetadataModel
resp.Diagnostics.Append(req.Plan.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}

if err := data.Update(ctx, r.Client); err != nil {
resp.Diagnostics.AddError(
"Unable to update Role Metadata",
err.Error(),
)
return
}

resp.Diagnostics.Append(resp.State.Set(ctx, &data)...)
}

func (r *mackerelRoleMetadataResource) Delete(ctx context.Context, req resource.DeleteRequest, resp *resource.DeleteResponse) {
var data mackerel.RoleMetadataModel
resp.Diagnostics.Append(req.State.Get(ctx, &data)...)
if resp.Diagnostics.HasError() {
return
}

if err := data.Delete(ctx, r.Client); err != nil {
resp.Diagnostics.AddError(
"Unable to delete Role Metadata",
err.Error(),
)
return
}
}

func (r *mackerelRoleMetadataResource) ImportState(ctx context.Context, req resource.ImportStateRequest, resp *resource.ImportStateResponse) {
data, err := mackerel.ImportRoleMetadata(req.ID)
if err != nil {
resp.Diagnostics.AddAttributeError(
path.Root("id"),
"Invalid ID",
err.Error(),
)
return
}
resp.Diagnostics.Append(resp.State.Set(ctx, &data)...)
}
25 changes: 25 additions & 0 deletions internal/provider/resource_mackerel_role_metadata_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
package provider_test

import (
"context"
"testing"

fwresource "github.com/hashicorp/terraform-plugin-framework/resource"
"github.com/mackerelio-labs/terraform-provider-mackerel/internal/provider"
)

func Test_MackerelRoleMetadataResource_schema(t *testing.T) {
t.Parallel()

ctx := context.Background()
req := fwresource.SchemaRequest{}
resp := fwresource.SchemaResponse{}
provider.NewMackerelRoleMetadataResource().Schema(ctx, req, &resp)
if resp.Diagnostics.HasError() {
t.Fatalf("schema diagnostics: %+v", resp.Diagnostics)
}

if diags := resp.Schema.ValidateImplementation(ctx); diags.HasError() {
t.Fatalf("schema validation diagnostics: %+v", diags)
}
}
1 change: 1 addition & 0 deletions mackerel/provider.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ func protoV5ProviderServer(provider *schema.Provider) tfprotov5.ProviderServer {
// Resources
delete(provider.ResourcesMap, "mackerel_notification_group")
delete(provider.ResourcesMap, "mackerel_role")
delete(provider.ResourcesMap, "mackerel_role_metadata")
delete(provider.ResourcesMap, "mackerel_service")
delete(provider.ResourcesMap, "mackerel_service_metadata")

Expand Down

0 comments on commit dad098d

Please sign in to comment.