-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstyle.go
91 lines (81 loc) · 3.96 KB
/
style.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// Code generated by jsonschema. DO NOT EDIT.
package beerjson
import "encoding/json"
import "fmt"
// ID: https://raw.githubusercontent.com/beerjson/beerjson/master/json/style.json
// RecipeStyleType defines style information stored in a recipe record
type RecipeStyleType struct {
StyleGuide *string `json:"style_guide,omitempty"`
KeyType *StyleCategories `json:"type,omitempty"`
Name *string `json:"name,omitempty"`
Category *string `json:"category,omitempty"`
CategoryNumber *int32 `json:"category_number,omitempty"`
StyleLetter *string `json:"style_letter,omitempty", validate:"max=1,min=1,regex=[A-Z ]"`
}
// The descriptive base type for both style guideline records, and recipe style provisions. Provides unique properties to identify individual styles
type StyleBase struct {
StyleGuide string `json:"style_guide", validate:"required"`
KeyType StyleCategories `json:"type", validate:"required"`
Name string `json:"name", validate:"required"`
Category string `json:"category", validate:"required"`
CategoryNumber *int32 `json:"category_number,omitempty"`
StyleLetter *string `json:"style_letter,omitempty", validate:"max=1,min=1,regex=[A-Z ]"`
}
type StyleCategories string
func (s *StyleCategories) UnmarshalJSON(b []byte) error {
var v string
err := json.Unmarshal(b, &v)
if err != nil {
return err
}
*s = StyleCategories(v)
switch *s {
case StyleCategories_Beer:
return nil
case StyleCategories_Cider:
return nil
case StyleCategories_Kombucha:
return nil
case StyleCategories_Mead:
return nil
case StyleCategories_Other:
return nil
case StyleCategories_Soda:
return nil
case StyleCategories_Wine:
return nil
}
return fmt.Errorf("StyleCategories: value '%v' does not match any value", v)
}
const (
StyleCategories_Beer StyleCategories = "beer"
StyleCategories_Cider StyleCategories = "cider"
StyleCategories_Kombucha StyleCategories = "kombucha"
StyleCategories_Mead StyleCategories = "mead"
StyleCategories_Other StyleCategories = "other"
StyleCategories_Soda StyleCategories = "soda"
StyleCategories_Wine StyleCategories = "wine"
)
// StyleType provide information for Style categorization
type StyleType struct {
Examples *string `json:"examples,omitempty"`
KeyType *StyleCategories `json:"type,omitempty"`
Name *string `json:"name,omitempty"`
OriginalGravity *GravityRangeType `json:"original_gravity,omitempty"`
Carbonation *CarbonationRangeType `json:"carbonation,omitempty"`
Flavor *string `json:"flavor,omitempty"`
FinalGravity *GravityRangeType `json:"final_gravity,omitempty"`
Category *string `json:"category,omitempty"`
Color *ColorRangeType `json:"color,omitempty"`
OverallImpression *string `json:"overall_impression,omitempty"`
Appearance *string `json:"appearance,omitempty"`
Ingredients *string `json:"ingredients,omitempty"`
Aroma *string `json:"aroma,omitempty"`
Mouthfeel *string `json:"mouthfeel,omitempty"`
InternationalBitternessUnits *BitternessRangeType `json:"international_bitterness_units,omitempty"`
StyleLetter *string `json:"style_letter,omitempty", validate:"min=1,regex=[A-Z ],max=1"`
StyleGuide *string `json:"style_guide,omitempty"`
CategoryNumber *int32 `json:"category_number,omitempty"`
Notes *string `json:"notes,omitempty"`
AlcoholByVolume *PercentRangeType `json:"alcohol_by_volume,omitempty"`
}