Add ListIter in pagination + generic Resource.Iter for streaming paginated results as iter.Seq2[T, error]. Add Iter* methods across all service files (actions, admin, branches, issues, labels, notifs, orgs, packages, pulls, releases, repos, teams, users, webhooks). Modernise cmd/forgegen with slices.Sort, maps.Keys, strings.FieldsFuncSeq. Co-Authored-By: Gemini <noreply@google.com> Co-Authored-By: Virgil <virgil@lethean.io>
66 lines
2.4 KiB
Go
66 lines
2.4 KiB
Go
package forge
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"iter"
|
|
|
|
"forge.lthn.ai/core/go-forge/types"
|
|
)
|
|
|
|
// ReleaseService handles release operations within a repository.
|
|
type ReleaseService struct {
|
|
Resource[types.Release, types.CreateReleaseOption, types.EditReleaseOption]
|
|
}
|
|
|
|
func newReleaseService(c *Client) *ReleaseService {
|
|
return &ReleaseService{
|
|
Resource: *NewResource[types.Release, types.CreateReleaseOption, types.EditReleaseOption](
|
|
c, "/api/v1/repos/{owner}/{repo}/releases/{id}",
|
|
),
|
|
}
|
|
}
|
|
|
|
// GetByTag returns a release by its tag name.
|
|
func (s *ReleaseService) GetByTag(ctx context.Context, owner, repo, tag string) (*types.Release, error) {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner, repo, tag)
|
|
var out types.Release
|
|
if err := s.client.Get(ctx, path, &out); err != nil {
|
|
return nil, err
|
|
}
|
|
return &out, nil
|
|
}
|
|
|
|
// DeleteByTag deletes a release by its tag name.
|
|
func (s *ReleaseService) DeleteByTag(ctx context.Context, owner, repo, tag string) error {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/tags/%s", owner, repo, tag)
|
|
return s.client.Delete(ctx, path)
|
|
}
|
|
|
|
// ListAssets returns all assets for a release.
|
|
func (s *ReleaseService) ListAssets(ctx context.Context, owner, repo string, releaseID int64) ([]types.Attachment, error) {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/%d/assets", owner, repo, releaseID)
|
|
return ListAll[types.Attachment](ctx, s.client, path, nil)
|
|
}
|
|
|
|
// IterAssets returns an iterator over all assets for a release.
|
|
func (s *ReleaseService) IterAssets(ctx context.Context, owner, repo string, releaseID int64) iter.Seq2[types.Attachment, error] {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/%d/assets", owner, repo, releaseID)
|
|
return ListIter[types.Attachment](ctx, s.client, path, nil)
|
|
}
|
|
|
|
// GetAsset returns a single asset for a release.
|
|
func (s *ReleaseService) GetAsset(ctx context.Context, owner, repo string, releaseID, assetID int64) (*types.Attachment, error) {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/%d/assets/%d", owner, repo, releaseID, assetID)
|
|
var out types.Attachment
|
|
if err := s.client.Get(ctx, path, &out); err != nil {
|
|
return nil, err
|
|
}
|
|
return &out, nil
|
|
}
|
|
|
|
// DeleteAsset deletes a single asset from a release.
|
|
func (s *ReleaseService) DeleteAsset(ctx context.Context, owner, repo string, releaseID, assetID int64) error {
|
|
path := fmt.Sprintf("/api/v1/repos/%s/%s/releases/%d/assets/%d", owner, repo, releaseID, assetID)
|
|
return s.client.Delete(ctx, path)
|
|
}
|