Skip to content

Commit

Permalink
Merge pull request #13 from incident-io/rob/add-severities-stream
Browse files Browse the repository at this point in the history
Add severities stream
  • Loading branch information
rliddler authored Oct 19, 2023
2 parents 327ab86 + 6149804 commit 3874e51
Showing 1 changed file with 48 additions and 0 deletions.
48 changes: 48 additions & 0 deletions tap/stream_severities.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
package tap

import (
"context"

kitlog "github.com/go-kit/log"
"github.com/incident-io/singer-tap/client"
"github.com/incident-io/singer-tap/model"
"github.com/pkg/errors"
)

func init() {
register(&StreamSeverities{})
}

type StreamSeverities struct {
}

func (s *StreamSeverities) Output() *Output {
return &Output{
Type: OutputTypeSchema,
Stream: "severities",
Schema: &model.Schema{
HasAdditionalProperties: false,
Type: []string{"object"},
Properties: model.SeverityV2.Schema().Properties,
},
KeyProperties: []string{"id"},
BookmarkProperties: []string{},
}
}

func (s *StreamSeverities) GetRecords(ctx context.Context, logger kitlog.Logger, cl *client.ClientWithResponses) ([]map[string]any, error) {
var (
results = []map[string]any{}
)

response, err := cl.SeveritiesV1ListWithResponse(ctx)
if err != nil {
return nil, errors.Wrap(err, "listing severities")
}

for _, element := range response.JSON200.Severities {
results = append(results, model.SeverityV2.Serialize(&element))
}

return results, nil
}

0 comments on commit 3874e51

Please sign in to comment.