Update Go module path from forge.lthn.ai/core/go-forge to dappco.re/go/core/forge. Migrate all import paths and dependency references (go-io → dappco.re/go/core/io, go-log → dappco.re/go/core/log). Update documentation (CLAUDE.md, README.md, docs/) to reflect new paths. Co-Authored-By: Virgil <virgil@lethean.io>
41 lines
1.3 KiB
Go
41 lines
1.3 KiB
Go
package forge
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"iter"
|
|
|
|
"dappco.re/go/core/forge/types"
|
|
)
|
|
|
|
// WebhookService handles webhook (hook) operations within a repository.
|
|
// Embeds Resource for standard CRUD on /api/v1/repos/{owner}/{repo}/hooks/{id}.
|
|
type WebhookService struct {
|
|
Resource[types.Hook, types.CreateHookOption, types.EditHookOption]
|
|
}
|
|
|
|
func newWebhookService(c *Client) *WebhookService {
|
|
return &WebhookService{
|
|
Resource: *NewResource[types.Hook, types.CreateHookOption, types.EditHookOption](
|
|
c, "/api/v1/repos/{owner}/{repo}/hooks/{id}",
|
|
),
|
|
}
|
|
}
|
|
|
|
// TestHook triggers a test delivery for a webhook.
|
|
func (s *WebhookService) TestHook(ctx context.Context, owner, repo string, id int64) error {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/hooks/%d/tests", owner, repo, id)
|
|
return s.client.Post(ctx, path, nil, nil)
|
|
}
|
|
|
|
// ListOrgHooks returns all webhooks for an organisation.
|
|
func (s *WebhookService) ListOrgHooks(ctx context.Context, org string) ([]types.Hook, error) {
|
|
path := fmt.Sprintf("/api/v1/orgs/%s/hooks", org)
|
|
return ListAll[types.Hook](ctx, s.client, path, nil)
|
|
}
|
|
|
|
// IterOrgHooks returns an iterator over all webhooks for an organisation.
|
|
func (s *WebhookService) IterOrgHooks(ctx context.Context, org string) iter.Seq2[types.Hook, error] {
|
|
path := fmt.Sprintf("/api/v1/orgs/%s/hooks", org)
|
|
return ListIter[types.Hook](ctx, s.client, path, nil)
|
|
}
|