Files
prefect-go/pkg/client/concurrency_limits.go

115 lines
3.8 KiB
Go

package client
import (
"context"
"fmt"
"git.schultes.dev/schultesdev/prefect-go/pkg/models"
"github.com/google/uuid"
)
// ConcurrencyLimitsService handles operations related to v1 concurrency limits.
type ConcurrencyLimitsService struct {
client *Client
}
// Create creates a new concurrency limit.
func (s *ConcurrencyLimitsService) Create(ctx context.Context, req *models.ConcurrencyLimitCreate) (*models.ConcurrencyLimit, error) {
var limit models.ConcurrencyLimit
if err := s.client.post(ctx, "/concurrency_limits/", req, &limit); err != nil {
return nil, fmt.Errorf("failed to create concurrency limit: %w", err)
}
return &limit, nil
}
// Get retrieves a concurrency limit by ID.
func (s *ConcurrencyLimitsService) Get(ctx context.Context, id uuid.UUID) (*models.ConcurrencyLimit, error) {
var limit models.ConcurrencyLimit
path := joinPath("/concurrency_limits", id.String())
if err := s.client.get(ctx, path, &limit); err != nil {
return nil, fmt.Errorf("failed to get concurrency limit: %w", err)
}
return &limit, nil
}
// GetByTag retrieves a concurrency limit by tag.
func (s *ConcurrencyLimitsService) GetByTag(ctx context.Context, tag string) (*models.ConcurrencyLimit, error) {
var limit models.ConcurrencyLimit
path := joinPath("/concurrency_limits/tag", tag)
if err := s.client.get(ctx, path, &limit); err != nil {
return nil, fmt.Errorf("failed to get concurrency limit by tag: %w", err)
}
return &limit, nil
}
// Delete deletes a concurrency limit by ID.
func (s *ConcurrencyLimitsService) Delete(ctx context.Context, id uuid.UUID) error {
path := joinPath("/concurrency_limits", id.String())
if err := s.client.delete(ctx, path); err != nil {
return fmt.Errorf("failed to delete concurrency limit: %w", err)
}
return nil
}
// DeleteByTag deletes a concurrency limit by tag.
func (s *ConcurrencyLimitsService) DeleteByTag(ctx context.Context, tag string) error {
path := joinPath("/concurrency_limits/tag", tag)
if err := s.client.delete(ctx, path); err != nil {
return fmt.Errorf("failed to delete concurrency limit by tag: %w", err)
}
return nil
}
// ResetByTag resets a concurrency limit by tag.
func (s *ConcurrencyLimitsService) ResetByTag(ctx context.Context, tag string) error {
path := joinPath("/concurrency_limits/tag", tag, "reset")
if err := s.client.post(ctx, path, nil, nil); err != nil {
return fmt.Errorf("failed to reset concurrency limit: %w", err)
}
return nil
}
// List retrieves concurrency limits with optional filtering.
func (s *ConcurrencyLimitsService) List(ctx context.Context) ([]models.ConcurrencyLimit, error) {
var limits []models.ConcurrencyLimit
if err := s.client.post(ctx, "/concurrency_limits/filter", nil, &limits); err != nil {
return nil, fmt.Errorf("failed to list concurrency limits: %w", err)
}
return limits, nil
}
// Increment increments concurrency limit slots.
func (s *ConcurrencyLimitsService) Increment(ctx context.Context, names []string, slots int, mode string) ([]models.MinimalConcurrencyLimitResponse, error) {
req := struct {
Names []string `json:"names"`
Slots int `json:"slots"`
Mode string `json:"mode,omitempty"`
}{
Names: names,
Slots: slots,
Mode: mode,
}
var resp []models.MinimalConcurrencyLimitResponse
if err := s.client.post(ctx, "/concurrency_limits/increment", req, &resp); err != nil {
return nil, fmt.Errorf("failed to increment concurrency limits: %w", err)
}
return resp, nil
}
// Decrement decrements concurrency limit slots.
func (s *ConcurrencyLimitsService) Decrement(ctx context.Context, names []string, slots int) error {
req := struct {
Names []string `json:"names"`
Slots int `json:"slots"`
}{
Names: names,
Slots: slots,
}
if err := s.client.post(ctx, "/concurrency_limits/decrement", req, nil); err != nil {
return fmt.Errorf("failed to decrement concurrency limits: %w", err)
}
return nil
}