117 lines
3.2 KiB
Go
117 lines
3.2 KiB
Go
package model
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"fmt"
|
|
"net/http"
|
|
"strconv"
|
|
|
|
"github.com/manyminds/api2go"
|
|
"github.com/manyminds/api2go/jsonapi"
|
|
)
|
|
|
|
type Car struct {
|
|
ID uint64 `json:"-"`
|
|
Brand string `json:"brand"`
|
|
Model string `json:"model"`
|
|
Price uint64 `json:"price"`
|
|
Status string `json:"status"` // OnTheWay, InStock, Sold, Discontinued
|
|
Mileage int64 `json:"mileage"` // I suppose it should be made unsigned, but that's what the task says ¯\_(ツ)_/¯
|
|
}
|
|
|
|
func (c Car) Verify() (bool, api2go.HTTPError) {
|
|
var verifyErrors []api2go.Error
|
|
var httpError api2go.HTTPError
|
|
|
|
if c.Brand == "" {
|
|
newErr := newVerifyError(
|
|
"Invalid Attribute",
|
|
"attribute cannot be empty",
|
|
"/data/attributes/brand")
|
|
verifyErrors = append(verifyErrors, newErr)
|
|
}
|
|
if c.Model == "" {
|
|
newErr := newVerifyError(
|
|
"Invalid Attribute",
|
|
"attribute cannot be empty",
|
|
"/data/attributes/model")
|
|
verifyErrors = append(verifyErrors, newErr)
|
|
}
|
|
if c.Status != "OnTheWay" &&
|
|
c.Status != "InStock" &&
|
|
c.Status != "Sold" &&
|
|
c.Status != "Discontinued" {
|
|
newErr := newVerifyError(
|
|
"Invalid Attribute",
|
|
"attribute must be one of: OnTheWay, InStock, Sold, Discontinued",
|
|
"/data/attributes/status")
|
|
verifyErrors = append(verifyErrors, newErr)
|
|
}
|
|
|
|
ok := len(verifyErrors) == 0
|
|
|
|
if !ok {
|
|
httpError = api2go.NewHTTPError(
|
|
errors.New("Invalid content"),
|
|
"Invalid content",
|
|
http.StatusBadRequest)
|
|
httpError.Errors = verifyErrors
|
|
}
|
|
|
|
return ok, httpError
|
|
}
|
|
|
|
func newVerifyError(title string, detail string, pointer string) api2go.Error {
|
|
var newError api2go.Error
|
|
newError.Title = title
|
|
newError.Detail = detail
|
|
newError.Source = &api2go.ErrorSource{Pointer: pointer}
|
|
return newError
|
|
}
|
|
|
|
// GetID to satisfy jsonapi.MarshalIdentifier interface
|
|
func (c Car) GetID() string {
|
|
return fmt.Sprintf("%d", c.ID)
|
|
}
|
|
|
|
// SetID to satisfy jsonapi.UnmarshalIdentifier interface
|
|
func (c *Car) SetID(id string) error {
|
|
intID, err := strconv.ParseUint(id, 10, 64)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
c.ID = intID
|
|
return nil
|
|
}
|
|
|
|
// GetReferences to satisfy the jsonapi.MarshalReferences interface
|
|
func (c Car) GetReferences() []jsonapi.Reference {
|
|
return []jsonapi.Reference{}
|
|
}
|
|
|
|
// GetReferencedIDs to satisfy the jsonapi.MarshalLinkedRelations interface
|
|
func (c Car) GetReferencedIDs() []jsonapi.ReferenceID {
|
|
return []jsonapi.ReferenceID{}
|
|
}
|
|
|
|
// GetReferencedStructs to satisfy the jsonapi.MarhsalIncludedRelations interface
|
|
func (c Car) GetReferencedStructs() []jsonapi.MarshalIdentifier {
|
|
return []jsonapi.MarshalIdentifier{}
|
|
}
|
|
|
|
// SetToManyReferenceIDs sets the sweets reference IDs and satisfies the jsonapi.UnmarshalToManyRelations interface
|
|
func (c *Car) SetToManyReferenceIDs(name string, IDs []string) error {
|
|
return errors.New("There is no to-many relationship with the name " + name)
|
|
}
|
|
|
|
// AddToManyIDs adds some new sweets that a users loves so much
|
|
func (c *Car) AddToManyIDs(name string, IDs []string) error {
|
|
return errors.New("There is no to-many relationship with the name " + name)
|
|
}
|
|
|
|
// DeleteToManyIDs removes some sweets from a users because they made him very sick
|
|
func (c *Car) DeleteToManyIDs(name string, IDs []string) error {
|
|
return errors.New("There is no to-many relationship with the name " + name)
|
|
}
|