From 581db9a0a4a9924a8f42a091c9cb0c5c4f8f56d8 Mon Sep 17 00:00:00 2001 From: weichou Date: Mon, 15 Mar 2021 12:58:06 +0800 Subject: [PATCH] refactor: Remove ApiVersion from normal DTOs except EventDTO Close #541 Signed-off-by: weichou --- v2/dtos/device.go | 32 +++++++++---------- v2/dtos/deviceprofile.go | 36 ++++++++++----------- v2/dtos/deviceprofile_test.go | 2 -- v2/dtos/deviceservice.go | 22 ++++++------- v2/dtos/interval.go | 18 +++++------ v2/dtos/intervalaction.go | 15 ++++----- v2/dtos/notification.go | 38 ++++++++++------------- v2/dtos/notification_test.go | 3 -- v2/dtos/provisionwatcher.go | 2 -- v2/dtos/requests/device.go | 1 - v2/dtos/requests/device_test.go | 2 -- v2/dtos/requests/deviceprofile.go | 1 - v2/dtos/requests/deviceprofile_test.go | 2 -- v2/dtos/requests/deviceservice.go | 1 - v2/dtos/requests/deviceservice_test.go | 2 -- v2/dtos/requests/interval.go | 1 - v2/dtos/requests/interval_test.go | 11 +++---- v2/dtos/requests/intervalaction.go | 1 - v2/dtos/requests/notification.go | 1 - v2/dtos/requests/provisionwatcher.go | 1 - v2/dtos/requests/provisionwatcher_test.go | 1 - v2/dtos/requests/subscription.go | 1 - v2/dtos/requests/subscription_test.go | 1 - v2/dtos/subscription.go | 24 +++++++------- 24 files changed, 88 insertions(+), 131 deletions(-) diff --git a/v2/dtos/device.go b/v2/dtos/device.go index f7dd3043..1ad56c9f 100644 --- a/v2/dtos/device.go +++ b/v2/dtos/device.go @@ -13,22 +13,21 @@ import ( // Device and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/core-metadata/2.x#/Device type Device struct { - common.Versionable `json:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Description string `json:"description,omitempty"` - AdminState string `json:"adminState" validate:"oneof='LOCKED' 'UNLOCKED'"` - OperatingState string `json:"operatingState" validate:"oneof='UP' 'DOWN' 'UNKNOWN'"` - LastConnected int64 `json:"lastConnected,omitempty"` - LastReported int64 `json:"lastReported,omitempty"` - Labels []string `json:"labels,omitempty"` - Location interface{} `json:"location,omitempty"` - ServiceName string `json:"serviceName" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - ProfileName string `json:"profileName" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - AutoEvents []AutoEvent `json:"autoEvents,omitempty" validate:"dive"` - Protocols map[string]ProtocolProperties `json:"protocols" validate:"required,gt=0"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Description string `json:"description,omitempty"` + AdminState string `json:"adminState" validate:"oneof='LOCKED' 'UNLOCKED'"` + OperatingState string `json:"operatingState" validate:"oneof='UP' 'DOWN' 'UNKNOWN'"` + LastConnected int64 `json:"lastConnected,omitempty"` + LastReported int64 `json:"lastReported,omitempty"` + Labels []string `json:"labels,omitempty"` + Location interface{} `json:"location,omitempty"` + ServiceName string `json:"serviceName" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + ProfileName string `json:"profileName" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + AutoEvents []AutoEvent `json:"autoEvents,omitempty" validate:"dive"` + Protocols map[string]ProtocolProperties `json:"protocols" validate:"required,gt=0"` } // UpdateDevice and its properties are defined in the APIv2 specification: @@ -73,7 +72,6 @@ func ToDeviceModel(dto Device) models.Device { // FromDeviceModelToDTO transforms the Device Model to the Device DTO func FromDeviceModelToDTO(d models.Device) Device { var dto Device - dto.Versionable = common.NewVersionable() dto.Id = d.Id dto.Name = d.Name dto.Description = d.Description diff --git a/v2/dtos/deviceprofile.go b/v2/dtos/deviceprofile.go index 036b6d46..0dc315a9 100644 --- a/v2/dtos/deviceprofile.go +++ b/v2/dtos/deviceprofile.go @@ -10,22 +10,20 @@ import ( "github.com/edgexfoundry/go-mod-core-contracts/v2/errors" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2" - "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/dtos/common" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/models" ) // DeviceProfile and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/core-metadata/2.x#/DeviceProfile type DeviceProfile struct { - common.Versionable `json:",inline" yaml:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Name string `json:"name" yaml:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Manufacturer string `json:"manufacturer,omitempty" yaml:"manufacturer,omitempty"` - Description string `json:"description,omitempty" yaml:"description,omitempty"` - Model string `json:"model,omitempty" yaml:"model,omitempty"` - Labels []string `json:"labels,omitempty" yaml:"labels,flow,omitempty"` - DeviceResources []DeviceResource `json:"deviceResources" yaml:"deviceResources" validate:"required,gt=0,dive"` - DeviceCommands []DeviceCommand `json:"deviceCommands,omitempty" yaml:"deviceCommands,omitempty" validate:"dive"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Name string `json:"name" yaml:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Manufacturer string `json:"manufacturer,omitempty" yaml:"manufacturer,omitempty"` + Description string `json:"description,omitempty" yaml:"description,omitempty"` + Model string `json:"model,omitempty" yaml:"model,omitempty"` + Labels []string `json:"labels,omitempty" yaml:"labels,flow,omitempty"` + DeviceResources []DeviceResource `json:"deviceResources" yaml:"deviceResources" validate:"required,gt=0,dive"` + DeviceCommands []DeviceCommand `json:"deviceCommands,omitempty" yaml:"deviceCommands,omitempty" validate:"dive"` } // Validate satisfies the Validator interface @@ -40,15 +38,14 @@ func (dp *DeviceProfile) Validate() error { // UnmarshalYAML implements the Unmarshaler interface for the DeviceProfile type func (dp *DeviceProfile) UnmarshalYAML(unmarshal func(interface{}) error) error { var alias struct { - common.Versionable `yaml:",inline"` - Id string `yaml:"id"` - Name string `yaml:"name"` - Manufacturer string `yaml:"manufacturer"` - Description string `yaml:"description"` - Model string `yaml:"model"` - Labels []string `yaml:"labels"` - DeviceResources []DeviceResource `yaml:"deviceResources"` - DeviceCommands []DeviceCommand `yaml:"deviceCommands"` + Id string `yaml:"id"` + Name string `yaml:"name"` + Manufacturer string `yaml:"manufacturer"` + Description string `yaml:"description"` + Model string `yaml:"model"` + Labels []string `yaml:"labels"` + DeviceResources []DeviceResource `yaml:"deviceResources"` + DeviceCommands []DeviceCommand `yaml:"deviceCommands"` } if err := unmarshal(&alias); err != nil { return errors.NewCommonEdgeX(errors.KindContractInvalid, "failed to unmarshal request body as YAML.", err) @@ -87,7 +84,6 @@ func ToDeviceProfileModel(deviceProfileDTO DeviceProfile) models.DeviceProfile { // FromDeviceProfileModelToDTO transforms the DeviceProfile Model to the DeviceProfile DTO func FromDeviceProfileModelToDTO(deviceProfile models.DeviceProfile) DeviceProfile { return DeviceProfile{ - Versionable: common.NewVersionable(), Id: deviceProfile.Id, Name: deviceProfile.Name, Description: deviceProfile.Description, diff --git a/v2/dtos/deviceprofile_test.go b/v2/dtos/deviceprofile_test.go index 49d8640a..b9f51d66 100644 --- a/v2/dtos/deviceprofile_test.go +++ b/v2/dtos/deviceprofile_test.go @@ -10,7 +10,6 @@ import ( "testing" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2" - "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/dtos/common" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/models" "github.com/stretchr/testify/assert" @@ -49,7 +48,6 @@ var testDeviceProfile = models.DeviceProfile{ func profileData() DeviceProfile { return DeviceProfile{ - Versionable: common.NewVersionable(), Name: TestDeviceProfileName, Manufacturer: TestManufacturer, Description: TestDescription, diff --git a/v2/dtos/deviceservice.go b/v2/dtos/deviceservice.go index b13739bf..63fa9e4b 100644 --- a/v2/dtos/deviceservice.go +++ b/v2/dtos/deviceservice.go @@ -13,17 +13,16 @@ import ( // DeviceService and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/core-metadata/2.x#/DeviceService type DeviceService struct { - common.Versionable `json:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Description string `json:"description,omitempty"` - LastConnected int64 `json:"lastConnected,omitempty"` - LastReported int64 `json:"lastReported,omitempty"` - Labels []string `json:"labels,omitempty"` - BaseAddress string `json:"baseAddress" validate:"required,uri"` - AdminState string `json:"adminState" validate:"oneof='LOCKED' 'UNLOCKED'"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Description string `json:"description,omitempty"` + LastConnected int64 `json:"lastConnected,omitempty"` + LastReported int64 `json:"lastReported,omitempty"` + Labels []string `json:"labels,omitempty"` + BaseAddress string `json:"baseAddress" validate:"required,uri"` + AdminState string `json:"adminState" validate:"oneof='LOCKED' 'UNLOCKED'"` } // UpdateDeviceService and its properties are defined in the APIv2 specification: @@ -54,7 +53,6 @@ func ToDeviceServiceModel(dto DeviceService) models.DeviceService { // FromDeviceServiceModelToDTO transforms the DeviceService Model to the DeviceService DTO func FromDeviceServiceModelToDTO(ds models.DeviceService) DeviceService { var dto DeviceService - dto.Versionable = common.NewVersionable() dto.Id = ds.Id dto.Name = ds.Name dto.Description = ds.Description diff --git a/v2/dtos/interval.go b/v2/dtos/interval.go index 48cce3a8..432fe86a 100644 --- a/v2/dtos/interval.go +++ b/v2/dtos/interval.go @@ -13,15 +13,14 @@ import ( // Interval and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/support-scheduler/2.x#/Interval type Interval struct { - common.Versionable `json:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Name string `json:"name" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Start string `json:"start,omitempty" validate:"omitempty,edgex-dto-interval-datetime"` - End string `json:"end,omitempty" validate:"omitempty,edgex-dto-interval-datetime"` - Frequency string `json:"frequency" validate:"required,edgex-dto-frequency"` - RunOnce bool `json:"runOnce,omitempty"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Name string `json:"name" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Start string `json:"start,omitempty" validate:"omitempty,edgex-dto-interval-datetime"` + End string `json:"end,omitempty" validate:"omitempty,edgex-dto-interval-datetime"` + Frequency string `json:"frequency" validate:"required,edgex-dto-frequency"` + RunOnce bool `json:"runOnce,omitempty"` } // UpdateInterval and its properties are defined in the APIv2 specification: @@ -51,7 +50,6 @@ func ToIntervalModel(dto Interval) models.Interval { // FromIntervalModelToDTO transforms the Interval Model to the Interval DTO func FromIntervalModelToDTO(model models.Interval) Interval { var dto Interval - dto.Versionable = common.NewVersionable() dto.Id = model.Id dto.Name = model.Name dto.Start = model.Start diff --git a/v2/dtos/intervalaction.go b/v2/dtos/intervalaction.go index b96b459a..b7ad5b4f 100644 --- a/v2/dtos/intervalaction.go +++ b/v2/dtos/intervalaction.go @@ -15,18 +15,16 @@ import ( // IntervalAction and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/support-scheduler/2.x#/IntervalAction type IntervalAction struct { - common.Versionable `json:",inline"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Name string `json:"name" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - IntervalName string `json:"intervalName" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Address Address `json:"address" validate:"required"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Name string `json:"name" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + IntervalName string `json:"intervalName" validate:"edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Address Address `json:"address" validate:"required"` } func NewIntervalAction(name string, intervalName string, address Address) IntervalAction { return IntervalAction{ - Versionable: common.NewVersionable(), Id: uuid.NewString(), Name: name, IntervalName: intervalName, @@ -57,7 +55,6 @@ func ToIntervalActionModel(dto IntervalAction) models.IntervalAction { // FromIntervalActionModelToDTO transforms the IntervalAction Model to the IntervalAction DTO func FromIntervalActionModelToDTO(model models.IntervalAction) IntervalAction { var dto IntervalAction - dto.Versionable = common.NewVersionable() dto.Id = model.Id dto.Name = model.Name dto.IntervalName = model.IntervalName diff --git a/v2/dtos/notification.go b/v2/dtos/notification.go index e6bf94b4..8f2d9540 100644 --- a/v2/dtos/notification.go +++ b/v2/dtos/notification.go @@ -6,7 +6,6 @@ package dtos import ( - "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/dtos/common" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/models" "github.com/google/uuid" @@ -15,30 +14,28 @@ import ( // Notification and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/support-notifications/2.x#/Notification type Notification struct { - common.Versionable `json:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Category string `json:"category,omitempty" validate:"required_without=Labels,omitempty,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Labels []string `json:"labels,omitempty" validate:"required_without=Category,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Content string `json:"content" validate:"required,edgex-dto-none-empty-string"` - ContentType string `json:"contentType,omitempty"` - Description string `json:"description,omitempty"` - Sender string `json:"sender" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Severity string `json:"severity" validate:"required,oneof='MINOR' 'NORMAL' 'CRITICAL'"` - Status string `json:"status,omitempty" validate:"omitempty,oneof='NEW' 'PROCESSED' 'ESCALATED'"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Category string `json:"category,omitempty" validate:"required_without=Labels,omitempty,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Labels []string `json:"labels,omitempty" validate:"required_without=Category,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Content string `json:"content" validate:"required,edgex-dto-none-empty-string"` + ContentType string `json:"contentType,omitempty"` + Description string `json:"description,omitempty"` + Sender string `json:"sender" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Severity string `json:"severity" validate:"required,oneof='MINOR' 'NORMAL' 'CRITICAL'"` + Status string `json:"status,omitempty" validate:"omitempty,oneof='NEW' 'PROCESSED' 'ESCALATED'"` } // NewNotification creates and returns a Notification DTO func NewNotification(labels []string, category, content, sender, severity string) Notification { return Notification{ - Versionable: common.NewVersionable(), - Id: uuid.NewString(), - Labels: labels, - Category: category, - Content: content, - Sender: sender, - Severity: severity, + Id: uuid.NewString(), + Labels: labels, + Category: category, + Content: content, + Sender: sender, + Severity: severity, } } @@ -71,7 +68,6 @@ func ToNotificationModels(notifications []Notification) []models.Notification { // FromNotificationModelToDTO transforms the Notification Model to the Notification DTO func FromNotificationModelToDTO(n models.Notification) Notification { return Notification{ - Versionable: common.NewVersionable(), Id: n.Id, Created: n.Created, Modified: n.Modified, diff --git a/v2/dtos/notification_test.go b/v2/dtos/notification_test.go index a8e727e7..b49fc2aa 100644 --- a/v2/dtos/notification_test.go +++ b/v2/dtos/notification_test.go @@ -3,14 +3,12 @@ package dtos import ( "testing" - "github.com/edgexfoundry/go-mod-core-contracts/v2/v2" "github.com/edgexfoundry/go-mod-core-contracts/v2/v2/models" "github.com/stretchr/testify/assert" ) func TestNewNotification(t *testing.T) { - expectedApiVersion := v2.ApiVersion expectedLabels := []string{"label1", "label2"} expectedCategory := "category" expectedContent := "content" @@ -19,7 +17,6 @@ func TestNewNotification(t *testing.T) { actual := NewNotification(expectedLabels, expectedCategory, expectedContent, expectedSender, expectedSeverity) - assert.Equal(t, expectedApiVersion, actual.ApiVersion) assert.NotEmpty(t, actual.Id) assert.Equal(t, expectedLabels, actual.Labels) assert.Equal(t, expectedCategory, actual.Category) diff --git a/v2/dtos/provisionwatcher.go b/v2/dtos/provisionwatcher.go index 8852e258..bbfeb2ae 100644 --- a/v2/dtos/provisionwatcher.go +++ b/v2/dtos/provisionwatcher.go @@ -13,7 +13,6 @@ import ( // ProvisionWatcher and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/core-metadata/2.x#/ProvisionWatcher type ProvisionWatcher struct { - common.Versionable `json:",inline"` Id string `json:"id,omitempty" validate:"omitempty,uuid"` Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` Labels []string `json:"labels,omitempty"` @@ -59,7 +58,6 @@ func ToProvisionWatcherModel(dto ProvisionWatcher) models.ProvisionWatcher { // FromProvisionWatcherModelToDTO transforms the ProvisionWatcher Model to the ProvisionWatcher DTO func FromProvisionWatcherModelToDTO(pw models.ProvisionWatcher) ProvisionWatcher { return ProvisionWatcher{ - Versionable: common.NewVersionable(), Id: pw.Id, Name: pw.Name, Labels: pw.Labels, diff --git a/v2/dtos/requests/device.go b/v2/dtos/requests/device.go index a500271d..a10db7bf 100644 --- a/v2/dtos/requests/device.go +++ b/v2/dtos/requests/device.go @@ -131,7 +131,6 @@ func ReplaceDeviceModelFieldsWithDTO(device *models.Device, patch dtos.UpdateDev } func NewAddDeviceRequest(dto dtos.Device) AddDeviceRequest { - dto.Versionable = common.NewVersionable() return AddDeviceRequest{ BaseRequest: common.NewBaseRequest(), Device: dto, diff --git a/v2/dtos/requests/device_test.go b/v2/dtos/requests/device_test.go index d1c49b5a..b9c1c7c1 100644 --- a/v2/dtos/requests/device_test.go +++ b/v2/dtos/requests/device_test.go @@ -41,7 +41,6 @@ var testAddDevice = AddDeviceRequest{ Versionable: common.NewVersionable(), }, Device: dtos.Device{ - Versionable: common.NewVersionable(), Name: TestDeviceName, ServiceName: TestDeviceServiceName, ProfileName: TestDeviceProfileName, @@ -438,7 +437,6 @@ func TestNewAddDeviceRequest(t *testing.T) { actual := NewAddDeviceRequest(dtos.Device{}) assert.Equal(t, expectedApiVersion, actual.ApiVersion) - assert.Equal(t, expectedApiVersion, actual.Device.ApiVersion) } func TestNewUpdateDeviceRequest(t *testing.T) { diff --git a/v2/dtos/requests/deviceprofile.go b/v2/dtos/requests/deviceprofile.go index c3cb09a7..1bd5fd55 100644 --- a/v2/dtos/requests/deviceprofile.go +++ b/v2/dtos/requests/deviceprofile.go @@ -75,7 +75,6 @@ func DeviceProfileReqToDeviceProfileModels(addRequests []DeviceProfileRequest) ( } func NewDeviceProfileRequest(dto dtos.DeviceProfile) DeviceProfileRequest { - dto.Versionable = common.NewVersionable() return DeviceProfileRequest{ BaseRequest: common.NewBaseRequest(), Profile: dto, diff --git a/v2/dtos/requests/deviceprofile_test.go b/v2/dtos/requests/deviceprofile_test.go index 99bbdddc..36c18af0 100644 --- a/v2/dtos/requests/deviceprofile_test.go +++ b/v2/dtos/requests/deviceprofile_test.go @@ -48,7 +48,6 @@ func profileData() DeviceProfileRequest { Versionable: common.NewVersionable(), }, Profile: dtos.DeviceProfile{ - Versionable: common.NewVersionable(), Name: TestDeviceProfileName, Manufacturer: TestManufacturer, Description: TestDescription, @@ -195,5 +194,4 @@ func TestNewDeviceProfileRequest(t *testing.T) { actual := NewDeviceProfileRequest(dtos.DeviceProfile{}) assert.Equal(t, expectedApiVersion, actual.ApiVersion) - assert.Equal(t, expectedApiVersion, actual.Profile.ApiVersion) } diff --git a/v2/dtos/requests/deviceservice.go b/v2/dtos/requests/deviceservice.go index 08529458..caeed097 100644 --- a/v2/dtos/requests/deviceservice.go +++ b/v2/dtos/requests/deviceservice.go @@ -104,7 +104,6 @@ func ReplaceDeviceServiceModelFieldsWithDTO(ds *models.DeviceService, patch dtos } func NewAddDeviceServiceRequest(dto dtos.DeviceService) AddDeviceServiceRequest { - dto.Versionable = common.NewVersionable() return AddDeviceServiceRequest{ BaseRequest: common.NewBaseRequest(), Service: dto, diff --git a/v2/dtos/requests/deviceservice_test.go b/v2/dtos/requests/deviceservice_test.go index c6e3baa5..a55b0e5f 100644 --- a/v2/dtos/requests/deviceservice_test.go +++ b/v2/dtos/requests/deviceservice_test.go @@ -25,7 +25,6 @@ var testAddDeviceService = AddDeviceServiceRequest{ Versionable: common.NewVersionable(), }, Service: dtos.DeviceService{ - Versionable: common.NewVersionable(), Name: TestDeviceServiceName, BaseAddress: TestBaseAddress, Labels: []string{"MODBUS", "TEMP"}, @@ -319,7 +318,6 @@ func TestNewAddDeviceServiceRequest(t *testing.T) { actual := NewAddDeviceServiceRequest(dtos.DeviceService{}) assert.Equal(t, expectedApiVersion, actual.ApiVersion) - assert.Equal(t, expectedApiVersion, actual.Service.ApiVersion) } func TestNewUpdateDeviceServiceRequest(t *testing.T) { diff --git a/v2/dtos/requests/interval.go b/v2/dtos/requests/interval.go index 923c6602..13f90a43 100644 --- a/v2/dtos/requests/interval.go +++ b/v2/dtos/requests/interval.go @@ -107,7 +107,6 @@ func ReplaceIntervalModelFieldsWithDTO(interval *models.Interval, patch dtos.Upd } func NewAddIntervalRequest(dto dtos.Interval) AddIntervalRequest { - dto.Versionable = common.NewVersionable() return AddIntervalRequest{ BaseRequest: common.NewBaseRequest(), Interval: dto, diff --git a/v2/dtos/requests/interval_test.go b/v2/dtos/requests/interval_test.go index edf8cdf8..f6c79bc8 100644 --- a/v2/dtos/requests/interval_test.go +++ b/v2/dtos/requests/interval_test.go @@ -24,12 +24,11 @@ func addIntervalRequestData() AddIntervalRequest { Versionable: common.NewVersionable(), }, Interval: dtos.Interval{ - Versionable: common.NewVersionable(), - Name: TestIntervalName, - Start: TestIntervalStart, - End: TestIntervalEnd, - Frequency: TestIntervalFrequency, - RunOnce: TestIntervalRunOnce, + Name: TestIntervalName, + Start: TestIntervalStart, + End: TestIntervalEnd, + Frequency: TestIntervalFrequency, + RunOnce: TestIntervalRunOnce, }, } } diff --git a/v2/dtos/requests/intervalaction.go b/v2/dtos/requests/intervalaction.go index 1a20996d..67495928 100644 --- a/v2/dtos/requests/intervalaction.go +++ b/v2/dtos/requests/intervalaction.go @@ -117,7 +117,6 @@ func ReplaceIntervalActionModelFieldsWithDTO(action *models.IntervalAction, patc } func NewAddIntervalActionRequest(dto dtos.IntervalAction) AddIntervalActionRequest { - dto.Versionable = common.NewVersionable() return AddIntervalActionRequest{ BaseRequest: common.NewBaseRequest(), Action: dto, diff --git a/v2/dtos/requests/notification.go b/v2/dtos/requests/notification.go index c5a2e414..d93936fe 100644 --- a/v2/dtos/requests/notification.go +++ b/v2/dtos/requests/notification.go @@ -58,7 +58,6 @@ func AddNotificationReqToNotificationModels(reqs []AddNotificationRequest) (n [] } func NewAddNotificationRequest(dto dtos.Notification) AddNotificationRequest { - dto.Versionable = common.NewVersionable() return AddNotificationRequest{ BaseRequest: common.NewBaseRequest(), Notification: dto, diff --git a/v2/dtos/requests/provisionwatcher.go b/v2/dtos/requests/provisionwatcher.go index 03063ae4..ed87bccc 100644 --- a/v2/dtos/requests/provisionwatcher.go +++ b/v2/dtos/requests/provisionwatcher.go @@ -116,7 +116,6 @@ func ReplaceProvisionWatcherModelFieldsWithDTO(pw *models.ProvisionWatcher, patc } func NewAddProvisionWatcherRequest(dto dtos.ProvisionWatcher) AddProvisionWatcherRequest { - dto.Versionable = common.NewVersionable() return AddProvisionWatcherRequest{ BaseRequest: common.NewBaseRequest(), ProvisionWatcher: dto, diff --git a/v2/dtos/requests/provisionwatcher_test.go b/v2/dtos/requests/provisionwatcher_test.go index 4b7d6211..4164da32 100644 --- a/v2/dtos/requests/provisionwatcher_test.go +++ b/v2/dtos/requests/provisionwatcher_test.go @@ -32,7 +32,6 @@ var testAddProvisionWatcher = AddProvisionWatcherRequest{ Versionable: common.NewVersionable(), }, ProvisionWatcher: dtos.ProvisionWatcher{ - Versionable: common.NewVersionable(), Name: testProvisionWatcherName, Labels: testProvisionWatcherLabels, Identifiers: testIdentifiers, diff --git a/v2/dtos/requests/subscription.go b/v2/dtos/requests/subscription.go index 8b3fcc65..6ceea5fb 100644 --- a/v2/dtos/requests/subscription.go +++ b/v2/dtos/requests/subscription.go @@ -116,7 +116,6 @@ func ReplaceSubscriptionModelFieldsWithDTO(s *models.Subscription, patch dtos.Up } func NewAddSubscriptionRequest(dto dtos.Subscription) AddSubscriptionRequest { - dto.Versionable = common.NewVersionable() return AddSubscriptionRequest{ BaseRequest: common.NewBaseRequest(), Subscription: dto, diff --git a/v2/dtos/requests/subscription_test.go b/v2/dtos/requests/subscription_test.go index ae1cbe15..be18deef 100644 --- a/v2/dtos/requests/subscription_test.go +++ b/v2/dtos/requests/subscription_test.go @@ -38,7 +38,6 @@ func addSubscriptionRequestData() AddSubscriptionRequest { Versionable: common.NewVersionable(), }, Subscription: dtos.Subscription{ - Versionable: common.NewVersionable(), Name: testSubscriptionName, Categories: testSubscriptionCategories, Labels: testSubscriptionLabels, diff --git a/v2/dtos/subscription.go b/v2/dtos/subscription.go index 62e6285a..8197b79d 100644 --- a/v2/dtos/subscription.go +++ b/v2/dtos/subscription.go @@ -13,18 +13,17 @@ import ( // Subscription and its properties are defined in the APIv2 specification: // https://app.swaggerhub.com/apis-docs/EdgeXFoundry1/support-notifications/2.x#/Subscription type Subscription struct { - common.Versionable `json:",inline"` - Id string `json:"id,omitempty" validate:"omitempty,uuid"` - Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Channels []Channel `json:"channels" validate:"required,gt=0,dive"` - Receiver string `json:"receiver" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Categories []string `json:"categories,omitempty" validate:"required_without=Labels,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Labels []string `json:"labels,omitempty" validate:"required_without=Categories,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` - Created int64 `json:"created,omitempty"` - Modified int64 `json:"modified,omitempty"` - Description string `json:"description,omitempty"` - ResendLimit int64 `json:"resendLimit,omitempty"` - ResendInterval string `json:"resendInterval,omitempty" validate:"omitempty,edgex-dto-frequency"` + Id string `json:"id,omitempty" validate:"omitempty,uuid"` + Name string `json:"name" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Channels []Channel `json:"channels" validate:"required,gt=0,dive"` + Receiver string `json:"receiver" validate:"required,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Categories []string `json:"categories,omitempty" validate:"required_without=Labels,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Labels []string `json:"labels,omitempty" validate:"required_without=Categories,omitempty,gt=0,dive,edgex-dto-none-empty-string,edgex-dto-rfc3986-unreserved-chars"` + Created int64 `json:"created,omitempty"` + Modified int64 `json:"modified,omitempty"` + Description string `json:"description,omitempty"` + ResendLimit int64 `json:"resendLimit,omitempty"` + ResendInterval string `json:"resendInterval,omitempty" validate:"omitempty,edgex-dto-frequency"` } // UpdateSubscription and its properties are defined in the APIv2 specification: @@ -79,7 +78,6 @@ func ToSubscriptionModels(subs []Subscription) []models.Subscription { // FromSubscriptionModelToDTO transforms the Subscription Model to the Subscription DTO func FromSubscriptionModelToDTO(s models.Subscription) Subscription { return Subscription{ - Versionable: common.NewVersionable(), Categories: s.Categories, Labels: s.Labels, Channels: FromChannelModelsToDTOs(s.Channels),