OpenRTB v2.5 types for Go programming language (Golang)
go get -u "github.com/mxmCherry/openrtb"
import "github.com/mxmCherry/openrtb"
This repo follows semver - see releases. Master always contains latest code, so better use some package manager to vendor specific version.
- UpperCamelCase
- Capitalized abbreviations (e.g.,
AT
,COPPA
,PMP
etc.) - Capitalized
ID
keys
- Key types should be chosen according to OpenRTB specification (attribute types)
- Numeric types:
int64
- time, duration, unbound enums (likeBidRequest.at
- exchange-specific auctions types are > 500)int8
- short enums (with values <= 127), boolean-like attributes (likeBidRequest.test
)uint64
- width, height, bitrate etc. (unbound positive numbers)float64
- coordinates, prices etc.
- Enums:
- all enums, described in section 5, must be typed with section name singularized (e.g., "5.2 Banner Ad Types" ->
type BannerAdType int8
) - all typed enums must have constants for each element, prefixed with type name (e.g., "5.2 Banner Ad Types - XHTML Text Ad (usually mobile)" ->
const BannerAdTypeXHTMLTextAd BannerAdType = 1
) - never use
iota
for enum constants - section "5.1 Content Categories" should remain untyped and have no constants
- all enums, described in section 5, must be typed with section name singularized (e.g., "5.2 Banner Ad Types" ->
Documentation (godoc)
- Godoc: documenting Go code
- Each entity (type, struct key or constant) should be documented
- Comments for entities should be copy-pasted "as-is" from OpenRTB specification (except section 5 - replace "table" with "list" there; ideally, each sentence must be on a new line)
- Each RTB type should be kept in its own file, named after type
- File names are in underscore_case, e.g.,
type BidRequest
should be declared inbid_request.go
- go fmt your code
- Review all integral types, probably, switch everything to signed ones or just to
int
? - Consider switching back to
encoding/json.RawMessage
, as Go 1.8 fixed serialisation for non-ptr (probably, when Go 1.9 or even 1.10 is out) - Review enum types (typed enum attributes + constants)
- Review types, that are enums (or "open enums" like
BidRequest.at
) themselves, but not described in section 5 - make them typed