devices: added tracing and telemetry to devices_list and update
This commit is contained in:
parent
cf14079f1f
commit
6c09278e0a
|
@ -2,6 +2,7 @@ package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/tigorlazuardi/bluemage/go/pkg/errs"
|
"github.com/tigorlazuardi/bluemage/go/pkg/errs"
|
||||||
|
"github.com/tigorlazuardi/bluemage/go/pkg/telemetry"
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
|
|
||||||
. "github.com/go-jet/jet/v2/sqlite"
|
. "github.com/go-jet/jet/v2/sqlite"
|
||||||
|
@ -61,7 +62,7 @@ func (request ListDevicesRequest) Statement() SelectStatement {
|
||||||
|
|
||||||
func (api *API) DevicesList(ctx context.Context, req ListDevicesRequest) (resp []model.Devices, err error) {
|
func (api *API) DevicesList(ctx context.Context, req ListDevicesRequest) (resp []model.Devices, err error) {
|
||||||
ctx, span := tracer.Start(ctx, "DevicesList")
|
ctx, span := tracer.Start(ctx, "DevicesList")
|
||||||
defer span.End()
|
defer func() { telemetry.EndWithStatus(span, err) }()
|
||||||
|
|
||||||
stmt := req.Statement()
|
stmt := req.Statement()
|
||||||
if err := stmt.QueryContext(ctx, api.DB, &resp); err != nil {
|
if err := stmt.QueryContext(ctx, api.DB, &resp); err != nil {
|
||||||
|
|
|
@ -8,16 +8,21 @@ import (
|
||||||
"github.com/tigorlazuardi/bluemage/go/gen/models"
|
"github.com/tigorlazuardi/bluemage/go/gen/models"
|
||||||
"github.com/tigorlazuardi/bluemage/go/pkg/errs"
|
"github.com/tigorlazuardi/bluemage/go/pkg/errs"
|
||||||
"github.com/tigorlazuardi/bluemage/go/pkg/log"
|
"github.com/tigorlazuardi/bluemage/go/pkg/log"
|
||||||
|
"github.com/tigorlazuardi/bluemage/go/pkg/telemetry"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (api *API) DevicesUpdate(ctx context.Context, slug string, update *models.DeviceSetter) (err error) {
|
func (api *API) DevicesUpdate(ctx context.Context, slug string, update *models.DeviceSetter) (err error) {
|
||||||
|
ctx, span := tracer.Start(ctx, "DevicesUpdate")
|
||||||
|
defer func() { telemetry.EndWithStatus(span, err) }()
|
||||||
|
|
||||||
exist, err := api.DevicesExist(ctx, slug)
|
exist, err := api.DevicesExist(ctx, slug)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
if !exist {
|
if !exist {
|
||||||
return errs.Failf("device with slug %q does not exist", slug)
|
err = errs.Failf("device with slug %q does not exist", slug)
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx, coll := log.WithQueryCollector(ctx)
|
ctx, coll := log.WithQueryCollector(ctx)
|
||||||
|
@ -30,16 +35,19 @@ func (api *API) DevicesUpdate(ctx context.Context, slug string, update *models.D
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if sqlite3Err := new(sqlite3.Error); errors.As(err, &sqlite3Err) {
|
if sqlite3Err := new(sqlite3.Error); errors.As(err, &sqlite3Err) {
|
||||||
if sqlite3Err.Code == sqlite3.ErrConstraint {
|
if sqlite3Err.Code == sqlite3.ErrConstraint {
|
||||||
return errs.
|
err = errs.
|
||||||
Wrapw(
|
Wrapw(
|
||||||
err, "a device with the same slug already exists",
|
err, "a device with the same slug already exists",
|
||||||
"slug", slug,
|
"slug", slug,
|
||||||
"update", update,
|
"update", update,
|
||||||
"query", coll,
|
"query", coll,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return errs.Wrapw(err, "failed to update device", "slug", slug, "update", update, "query", coll)
|
err = errs.Wrapw(err, "failed to update device", "slug", slug, "update", update, "query", coll)
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -40,7 +40,7 @@ type DeviceConverter interface {
|
||||||
JetModelDeviceToProtoDevice(model.Devices) *device.Device
|
JetModelDeviceToProtoDevice(model.Devices) *device.Device
|
||||||
|
|
||||||
// goverter:useZeroValueOnPointerInconsistency
|
// goverter:useZeroValueOnPointerInconsistency
|
||||||
ListDevicesRequestToAPIListDevicesRequest(*device.ListDevicesRequest) api.ListDevicesRequest
|
ProtoListDevicesRequestToAPIListDevicesRequest(*device.ListDevicesRequest) api.ListDevicesRequest
|
||||||
|
|
||||||
// goverter:ignore Slug SingleFolderMode CreatedAt UpdatedAt
|
// goverter:ignore Slug SingleFolderMode CreatedAt UpdatedAt
|
||||||
// goverter:map Nsfw NSFW
|
// goverter:map Nsfw NSFW
|
||||||
|
|
|
@ -48,12 +48,14 @@ func (d *DeviceHandler) GetDevice(ctx context.Context, request *connect.Request[
|
||||||
|
|
||||||
// ListDevices implements v1connect.DeviceServiceHandler.
|
// ListDevices implements v1connect.DeviceServiceHandler.
|
||||||
func (d *DeviceHandler) ListDevices(ctx context.Context, request *connect.Request[device.ListDevicesRequest]) (*connect.Response[device.ListDevicesResponse], error) {
|
func (d *DeviceHandler) ListDevices(ctx context.Context, request *connect.Request[device.ListDevicesRequest]) (*connect.Response[device.ListDevicesResponse], error) {
|
||||||
listRequest := deviceConvert.ListDevicesRequestToAPIListDevicesRequest(request.Msg)
|
listRequest := deviceConvert.ProtoListDevicesRequestToAPIListDevicesRequest(request.Msg)
|
||||||
devices, err := d.API.DevicesList(ctx, listRequest)
|
devices, err := d.API.DevicesList(ctx, listRequest)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errs.IntoConnectError(err)
|
return nil, errs.IntoConnectError(err)
|
||||||
}
|
}
|
||||||
resp := &device.ListDevicesResponse{}
|
resp := &device.ListDevicesResponse{
|
||||||
|
Devices: make([]*device.Device, 0, len(devices)),
|
||||||
|
}
|
||||||
for _, device := range devices {
|
for _, device := range devices {
|
||||||
resp.Devices = append(resp.Devices, deviceConvert.JetModelDeviceToProtoDevice(device))
|
resp.Devices = append(resp.Devices, deviceConvert.JetModelDeviceToProtoDevice(device))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue