blob: 9902bb9e5bd36ff3c30849cadd4d3088d486cd60 [file] [log] [blame]
// Code generated by protoc-gen-go. DO NOT EDIT.
// source: feeds.proto
/*
Package maps_booking_feeds is a generated protocol buffer package.
It is generated from these files:
feeds.proto
It has these top-level messages:
FeedMetadata
AvailabilityFeed
ServiceAvailability
Availability
Resources
TimeRange
ServiceFeed
Service
Price
SchedulingRules
TaxRate
ServiceIntakeFormField
ServiceIntakeForm
Deposit
NoShowFee
PriceType
RequireCreditCard
ActionLink
ActionPlatform
TicketType
RelatedMedia
ServiceAttributeValueId
*/
package maps_booking_feeds
import proto "github.com/golang/protobuf/proto"
import fmt "fmt"
import math "math"
// Reference imports to suppress errors if they are not otherwise used.
var _ = proto.Marshal
var _ = fmt.Errorf
var _ = math.Inf
// This is a compile-time assertion to ensure that this generated file
// is compatible with the proto package it is being compiled against.
// A compilation error at this line likely means your copy of the
// proto package needs to be updated.
const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
// Defines how a total price is determined from an availability.
type PriceType int32
const (
// The price is for a fixed amount. This is the default value if the field is
// not set.
PriceType_FIXED_RATE_DEFAULT PriceType = 0
// The price specified is per person, and the total price is calculated
// according to the party size specified in Resources as
// price_micros * party_size. A PER_PERSON price must be accompanied by a
// party size in the availability resources. If it is not, a party size of one
// is used.
PriceType_PER_PERSON PriceType = 1
)
var PriceType_name = map[int32]string{
0: "FIXED_RATE_DEFAULT",
1: "PER_PERSON",
}
var PriceType_value = map[string]int32{
"FIXED_RATE_DEFAULT": 0,
"PER_PERSON": 1,
}
func (x PriceType) String() string {
return proto.EnumName(PriceType_name, int32(x))
}
func (PriceType) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{0}
}
// Defines whether a credit card is required in order to book an appointment.
type RequireCreditCard int32
const (
// The credit card requirement is not explicitly specified and the
// behaviour is identical to the one specified for CONDITIONAL.
RequireCreditCard_REQUIRE_CREDIT_CARD_UNSPECIFIED RequireCreditCard = 0
// Google will require a credit card for the booking if any of the following
// conditions are met:
// * the availability has a price and the prepayment_type is REQUIRED
// * the no_show_fee is set
// * the deposit field is set.
RequireCreditCard_REQUIRE_CREDIT_CARD_CONDITIONAL RequireCreditCard = 1
// A credit card is always required in order to book this availability
// regardless of other field values.
RequireCreditCard_REQUIRE_CREDIT_CARD_ALWAYS RequireCreditCard = 2
)
var RequireCreditCard_name = map[int32]string{
0: "REQUIRE_CREDIT_CARD_UNSPECIFIED",
1: "REQUIRE_CREDIT_CARD_CONDITIONAL",
2: "REQUIRE_CREDIT_CARD_ALWAYS",
}
var RequireCreditCard_value = map[string]int32{
"REQUIRE_CREDIT_CARD_UNSPECIFIED": 0,
"REQUIRE_CREDIT_CARD_CONDITIONAL": 1,
"REQUIRE_CREDIT_CARD_ALWAYS": 2,
}
func (x RequireCreditCard) String() string {
return proto.EnumName(RequireCreditCard_name, int32(x))
}
func (RequireCreditCard) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{1}
}
// The platform that the action is performed on. Web application is the general
// fallback. It is recommended to have at least one ActionLink with
// ACTION_PLATFORM_WEB_APPLICATION. Links with Android and iOS as platform are
// only used on the respective system.
type ActionPlatform int32
const (
// The platform is unspecified.
ActionPlatform_ACTION_PLATFORM_UNSPECIFIED ActionPlatform = 0
// The action platform is web in general.
ActionPlatform_ACTION_PLATFORM_WEB_APPLICATION ActionPlatform = 1
// The action platform is web on mobile devices.
ActionPlatform_ACTION_PLATFORM_MOBILE_WEB ActionPlatform = 2
// The action platform is Android OS.
ActionPlatform_ACTION_PLATFORM_ANDROID ActionPlatform = 3
// The action platform is iOS.
ActionPlatform_ACTION_PLATFORM_IOS ActionPlatform = 4
)
var ActionPlatform_name = map[int32]string{
0: "ACTION_PLATFORM_UNSPECIFIED",
1: "ACTION_PLATFORM_WEB_APPLICATION",
2: "ACTION_PLATFORM_MOBILE_WEB",
3: "ACTION_PLATFORM_ANDROID",
4: "ACTION_PLATFORM_IOS",
}
var ActionPlatform_value = map[string]int32{
"ACTION_PLATFORM_UNSPECIFIED": 0,
"ACTION_PLATFORM_WEB_APPLICATION": 1,
"ACTION_PLATFORM_MOBILE_WEB": 2,
"ACTION_PLATFORM_ANDROID": 3,
"ACTION_PLATFORM_IOS": 4,
}
func (x ActionPlatform) String() string {
return proto.EnumName(ActionPlatform_name, int32(x))
}
func (ActionPlatform) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{2}
}
type FeedMetadata_ProcessingInstruction int32
const (
// By default we will assume that this feed is an incremental feed.
FeedMetadata_PROCESS_UNKNOWN FeedMetadata_ProcessingInstruction = 0
// This Feed message is one shard of a complete feed. Anything previously
// supplied by this partner will be deleted; the contents of this feed
// represent the entire state of the world.
FeedMetadata_PROCESS_AS_COMPLETE FeedMetadata_ProcessingInstruction = 1
// This Feed message is one shard of an incremental feed. Existing entities
// will be left untouched except as modified in this feed.
FeedMetadata_PROCESS_AS_INCREMENTAL FeedMetadata_ProcessingInstruction = 2
)
var FeedMetadata_ProcessingInstruction_name = map[int32]string{
0: "PROCESS_UNKNOWN",
1: "PROCESS_AS_COMPLETE",
2: "PROCESS_AS_INCREMENTAL",
}
var FeedMetadata_ProcessingInstruction_value = map[string]int32{
"PROCESS_UNKNOWN": 0,
"PROCESS_AS_COMPLETE": 1,
"PROCESS_AS_INCREMENTAL": 2,
}
func (x FeedMetadata_ProcessingInstruction) String() string {
return proto.EnumName(FeedMetadata_ProcessingInstruction_name, int32(x))
}
func (FeedMetadata_ProcessingInstruction) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{0, 0}
}
// Enum to indicate the prepayment type.
type Service_PrepaymentType int32
const (
// By default we will assume that the prepayment is NOT_SUPPORTED.
Service_PREPAYMENT_TYPE_UNSPECIFIED Service_PrepaymentType = 0
// The user has to pay this service at the booking time.
Service_REQUIRED Service_PrepaymentType = 1
// The user can choose to pre-pay this service at the booking time or later,
// but it is not required in order to book.
Service_OPTIONAL Service_PrepaymentType = 2
// The prepayment is not supported for this service.
Service_NOT_SUPPORTED Service_PrepaymentType = 3
)
var Service_PrepaymentType_name = map[int32]string{
0: "PREPAYMENT_TYPE_UNSPECIFIED",
1: "REQUIRED",
2: "OPTIONAL",
3: "NOT_SUPPORTED",
}
var Service_PrepaymentType_value = map[string]int32{
"PREPAYMENT_TYPE_UNSPECIFIED": 0,
"REQUIRED": 1,
"OPTIONAL": 2,
"NOT_SUPPORTED": 3,
}
func (x Service_PrepaymentType) String() string {
return proto.EnumName(Service_PrepaymentType_name, int32(x))
}
func (Service_PrepaymentType) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{7, 0}
}
type Service_ServiceType int32
const (
Service_SERVICE_TYPE_UNSPECIFIED Service_ServiceType = 0
Service_SERVICE_TYPE_DINING_RESERVATION Service_ServiceType = 1
Service_SERVICE_TYPE_FOOD_ORDERING Service_ServiceType = 2
Service_SERVICE_TYPE_EVENT_TICKET Service_ServiceType = 3
Service_SERVICE_TYPE_TRIP_TOUR Service_ServiceType = 4
)
var Service_ServiceType_name = map[int32]string{
0: "SERVICE_TYPE_UNSPECIFIED",
1: "SERVICE_TYPE_DINING_RESERVATION",
2: "SERVICE_TYPE_FOOD_ORDERING",
3: "SERVICE_TYPE_EVENT_TICKET",
4: "SERVICE_TYPE_TRIP_TOUR",
}
var Service_ServiceType_value = map[string]int32{
"SERVICE_TYPE_UNSPECIFIED": 0,
"SERVICE_TYPE_DINING_RESERVATION": 1,
"SERVICE_TYPE_FOOD_ORDERING": 2,
"SERVICE_TYPE_EVENT_TICKET": 3,
"SERVICE_TYPE_TRIP_TOUR": 4,
}
func (x Service_ServiceType) String() string {
return proto.EnumName(Service_ServiceType_name, int32(x))
}
func (Service_ServiceType) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{7, 1}
}
// Enum to indicate the type of field.
type ServiceIntakeFormField_FieldType int32
const (
// Fields of unspecified or unknown type will be ignored.
ServiceIntakeFormField_FIELD_TYPE_UNSPECIFIED ServiceIntakeFormField_FieldType = 0
// A one-line input field for text.
ServiceIntakeFormField_SHORT_ANSWER ServiceIntakeFormField_FieldType = 1
// A multi-line input field for text.
ServiceIntakeFormField_PARAGRAPH ServiceIntakeFormField_FieldType = 2
// A set of radio buttons that requires one choice from many options.
ServiceIntakeFormField_MULTIPLE_CHOICE ServiceIntakeFormField_FieldType = 3
// One or more enumerated items with checkboxes.
ServiceIntakeFormField_CHECKBOXES ServiceIntakeFormField_FieldType = 4
// A selection from a dropdown.
ServiceIntakeFormField_DROPDOWN ServiceIntakeFormField_FieldType = 5
// A yes/no button.
ServiceIntakeFormField_BOOLEAN ServiceIntakeFormField_FieldType = 6
)
var ServiceIntakeFormField_FieldType_name = map[int32]string{
0: "FIELD_TYPE_UNSPECIFIED",
1: "SHORT_ANSWER",
2: "PARAGRAPH",
3: "MULTIPLE_CHOICE",
4: "CHECKBOXES",
5: "DROPDOWN",
6: "BOOLEAN",
}
var ServiceIntakeFormField_FieldType_value = map[string]int32{
"FIELD_TYPE_UNSPECIFIED": 0,
"SHORT_ANSWER": 1,
"PARAGRAPH": 2,
"MULTIPLE_CHOICE": 3,
"CHECKBOXES": 4,
"DROPDOWN": 5,
"BOOLEAN": 6,
}
func (x ServiceIntakeFormField_FieldType) String() string {
return proto.EnumName(ServiceIntakeFormField_FieldType_name, int32(x))
}
func (ServiceIntakeFormField_FieldType) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{11, 0}
}
// Enum to indicate the type of this media source. Only photos are supported.
// Please reach out to Google if supporting animations or videos is
// important to your feature and we will find the best solution for you.
type RelatedMedia_MediaType int32
const (
// Unused.
RelatedMedia_TYPE_UNSPECIFIED RelatedMedia_MediaType = 0
// Indicates the media provided by the url is a photo.
RelatedMedia_PHOTO RelatedMedia_MediaType = 1
)
var RelatedMedia_MediaType_name = map[int32]string{
0: "TYPE_UNSPECIFIED",
1: "PHOTO",
}
var RelatedMedia_MediaType_value = map[string]int32{
"TYPE_UNSPECIFIED": 0,
"PHOTO": 1,
}
func (x RelatedMedia_MediaType) String() string {
return proto.EnumName(RelatedMedia_MediaType_name, int32(x))
}
func (RelatedMedia_MediaType) EnumDescriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{17, 0}
}
type FeedMetadata struct {
// Instructs us how to process the feed: either as a shard of a complete feed,
// or as a shard of an incremental update.
ProcessingInstruction FeedMetadata_ProcessingInstruction `protobuf:"varint,1,opt,name=processing_instruction,json=processingInstruction,enum=maps.booking.feeds.FeedMetadata_ProcessingInstruction" json:"processing_instruction,omitempty"`
// The current shard and total number of shards for this feed.
//
// Shard number is assumed to be zero-based.
//
// There does not need to be any relationship to the file name.
//
// Shards do not need to be transferred in order, and they may not be
// processed in order.
ShardNumber int32 `protobuf:"varint,2,opt,name=shard_number,json=shardNumber" json:"shard_number,omitempty"`
TotalShards int32 `protobuf:"varint,3,opt,name=total_shards,json=totalShards" json:"total_shards,omitempty"`
// An identifier that must be consistent across all shards in a feed.
// This value must be globally unique across each feed type.
//
// This value ensures that complete feeds spanning multiple shards are
// processed together correctly.
//
// Clients only need to set this value when the processing_instruction is set
// to PROCESS_AS_COMPLETE and the feed spans multiple shards (defined by
// total_shards).
//
// Feeds that span multiple shards must set this nonce to the same value.
Nonce uint64 `protobuf:"varint,5,opt,name=nonce" json:"nonce,omitempty"`
// The timestamp at which this feed shard was generated.
//
// In Unix time format (seconds since the epoch).
GenerationTimestamp int64 `protobuf:"varint,4,opt,name=generation_timestamp,json=generationTimestamp" json:"generation_timestamp,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *FeedMetadata) Reset() { *m = FeedMetadata{} }
func (m *FeedMetadata) String() string { return proto.CompactTextString(m) }
func (*FeedMetadata) ProtoMessage() {}
func (*FeedMetadata) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{0}
}
func (m *FeedMetadata) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_FeedMetadata.Unmarshal(m, b)
}
func (m *FeedMetadata) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_FeedMetadata.Marshal(b, m, deterministic)
}
func (dst *FeedMetadata) XXX_Merge(src proto.Message) {
xxx_messageInfo_FeedMetadata.Merge(dst, src)
}
func (m *FeedMetadata) XXX_Size() int {
return xxx_messageInfo_FeedMetadata.Size(m)
}
func (m *FeedMetadata) XXX_DiscardUnknown() {
xxx_messageInfo_FeedMetadata.DiscardUnknown(m)
}
var xxx_messageInfo_FeedMetadata proto.InternalMessageInfo
func (m *FeedMetadata) GetProcessingInstruction() FeedMetadata_ProcessingInstruction {
if m != nil {
return m.ProcessingInstruction
}
return FeedMetadata_PROCESS_UNKNOWN
}
func (m *FeedMetadata) GetShardNumber() int32 {
if m != nil {
return m.ShardNumber
}
return 0
}
func (m *FeedMetadata) GetTotalShards() int32 {
if m != nil {
return m.TotalShards
}
return 0
}
func (m *FeedMetadata) GetNonce() uint64 {
if m != nil {
return m.Nonce
}
return 0
}
func (m *FeedMetadata) GetGenerationTimestamp() int64 {
if m != nil {
return m.GenerationTimestamp
}
return 0
}
type AvailabilityFeed struct {
Metadata *FeedMetadata `protobuf:"bytes,1,opt,name=metadata" json:"metadata,omitempty"`
ServiceAvailability []*ServiceAvailability `protobuf:"bytes,2,rep,name=service_availability,json=serviceAvailability" json:"service_availability,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *AvailabilityFeed) Reset() { *m = AvailabilityFeed{} }
func (m *AvailabilityFeed) String() string { return proto.CompactTextString(m) }
func (*AvailabilityFeed) ProtoMessage() {}
func (*AvailabilityFeed) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{1}
}
func (m *AvailabilityFeed) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_AvailabilityFeed.Unmarshal(m, b)
}
func (m *AvailabilityFeed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_AvailabilityFeed.Marshal(b, m, deterministic)
}
func (dst *AvailabilityFeed) XXX_Merge(src proto.Message) {
xxx_messageInfo_AvailabilityFeed.Merge(dst, src)
}
func (m *AvailabilityFeed) XXX_Size() int {
return xxx_messageInfo_AvailabilityFeed.Size(m)
}
func (m *AvailabilityFeed) XXX_DiscardUnknown() {
xxx_messageInfo_AvailabilityFeed.DiscardUnknown(m)
}
var xxx_messageInfo_AvailabilityFeed proto.InternalMessageInfo
func (m *AvailabilityFeed) GetMetadata() *FeedMetadata {
if m != nil {
return m.Metadata
}
return nil
}
func (m *AvailabilityFeed) GetServiceAvailability() []*ServiceAvailability {
if m != nil {
return m.ServiceAvailability
}
return nil
}
type ServiceAvailability struct {
// If provided, we will consider the Availability entities provided to be a
// complete snapshot from [start_timestamp_restrict, end_timestamp_restrict).
// That is, all existing availability will be deleted if the following
// condition holds true:
//
// start_timestamp_restrict <= Availability.start_sec &&
// Availability.start_sec < end_timestamp_restrict
//
// If a resource_restrict message is set, the condition is further restricted:
//
// Availability.resource.staff_id == resource_restrict.staff_id &&
// Availability.resource.room_id == resource_restrict.room_id
//
// These fields are typically used to provide a complete update of
// availability in a given time range.
//
// Setting start_timestamp_restrict while leaving end_timestamp_restrict unset
// is interpreted to mean all time beginning at start_timestamp_restrict.
//
// Setting end_timestamp_restrict while leaving start_timestamp_restrict unset
// is interpreted to mean all time up to the end_timestamp_restrict.
//
// In Unix time format (seconds since the epoch).
StartTimestampRestrict int64 `protobuf:"varint,1,opt,name=start_timestamp_restrict,json=startTimestampRestrict" json:"start_timestamp_restrict,omitempty"`
EndTimestampRestrict int64 `protobuf:"varint,2,opt,name=end_timestamp_restrict,json=endTimestampRestrict" json:"end_timestamp_restrict,omitempty"`
// If provided, the timestamp restricts will be applied only to the given
// merchant or service.
//
// These fields are typically used to provide complete snapshot of
// availability in a given range (defined above) for a specific merchant or
// service.
//
// Leaving these fields unset, or setting these to the empty string or null,
// is interpreted to mean that no restrict is intended.
MerchantIdRestrict string `protobuf:"bytes,3,opt,name=merchant_id_restrict,json=merchantIdRestrict" json:"merchant_id_restrict,omitempty"`
ServiceIdRestrict string `protobuf:"bytes,4,opt,name=service_id_restrict,json=serviceIdRestrict" json:"service_id_restrict,omitempty"`
// Setting resources_restrict further restricts the scope of the update to
// just this set of resources. All id fields of the resources must match
// exactly.
ResourcesRestrict *Resources `protobuf:"bytes,6,opt,name=resources_restrict,json=resourcesRestrict" json:"resources_restrict,omitempty"`
Availability []*Availability `protobuf:"bytes,5,rep,name=availability" json:"availability,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ServiceAvailability) Reset() { *m = ServiceAvailability{} }
func (m *ServiceAvailability) String() string { return proto.CompactTextString(m) }
func (*ServiceAvailability) ProtoMessage() {}
func (*ServiceAvailability) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{2}
}
func (m *ServiceAvailability) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ServiceAvailability.Unmarshal(m, b)
}
func (m *ServiceAvailability) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ServiceAvailability.Marshal(b, m, deterministic)
}
func (dst *ServiceAvailability) XXX_Merge(src proto.Message) {
xxx_messageInfo_ServiceAvailability.Merge(dst, src)
}
func (m *ServiceAvailability) XXX_Size() int {
return xxx_messageInfo_ServiceAvailability.Size(m)
}
func (m *ServiceAvailability) XXX_DiscardUnknown() {
xxx_messageInfo_ServiceAvailability.DiscardUnknown(m)
}
var xxx_messageInfo_ServiceAvailability proto.InternalMessageInfo
func (m *ServiceAvailability) GetStartTimestampRestrict() int64 {
if m != nil {
return m.StartTimestampRestrict
}
return 0
}
func (m *ServiceAvailability) GetEndTimestampRestrict() int64 {
if m != nil {
return m.EndTimestampRestrict
}
return 0
}
func (m *ServiceAvailability) GetMerchantIdRestrict() string {
if m != nil {
return m.MerchantIdRestrict
}
return ""
}
func (m *ServiceAvailability) GetServiceIdRestrict() string {
if m != nil {
return m.ServiceIdRestrict
}
return ""
}
func (m *ServiceAvailability) GetResourcesRestrict() *Resources {
if m != nil {
return m.ResourcesRestrict
}
return nil
}
func (m *ServiceAvailability) GetAvailability() []*Availability {
if m != nil {
return m.Availability
}
return nil
}
// An availability of the merchant's service, indicating time and number
// of spots.
// The availability feed should be a list of this message.
// Please note that it's up to the partner to call out all the possible
// availabilities.
// If a massage therapist is available 9am-12pm, and they provide
// one-hour massage sessions, the aggregator should provide the feed as
// availability {start_sec: 9am, duration: 60 minutes, ...}
// availability {start_sec: 10am, duration: 60 minutes, ...}
// availability {start_sec: 11am, duration: 60 minutes, ...}
// instead of
// availability {start_sec: 9am, duration: 180 minutes, ...}
//
type Availability struct {
// An opaque string from an aggregator to identify a merchant.
MerchantId string `protobuf:"bytes,1,opt,name=merchant_id,json=merchantId" json:"merchant_id,omitempty"`
// An opaque string from aggregator to identify a service of the
// merchant.
ServiceId string `protobuf:"bytes,2,opt,name=service_id,json=serviceId" json:"service_id,omitempty"`
// Start time of this availability, using epoch time in seconds.
StartSec int64 `protobuf:"varint,3,opt,name=start_sec,json=startSec" json:"start_sec,omitempty"`
// Duration of the service in seconds, e.g. 30 minutes for a chair massage.
DurationSec int64 `protobuf:"varint,4,opt,name=duration_sec,json=durationSec" json:"duration_sec,omitempty"`
// Number of total spots and open spots of this availability.
// E.g. a Yoga class of 10 spots with 3 booked.
// availability {spots_total: 10, spots_open: 7 ...}
// E.g. a chair massage session which was already booked.
// availability {spots_total: 1, spots_open: 0 ...}
//
// Note: If sending requests using the availability compression format defined
// below, these two fields will be inferred. A Recurrence
// implies spots_total=1 and spots_open=1. A ScheduleException implies
// spots_total=1 and spots_open=0.
SpotsTotal int64 `protobuf:"varint,5,opt,name=spots_total,json=spotsTotal" json:"spots_total,omitempty"`
SpotsOpen int64 `protobuf:"varint,6,opt,name=spots_open,json=spotsOpen" json:"spots_open,omitempty"`
// An optional opaque string to identify this availability slot. If set, it
// will be included in the requests that book/update/cancel appointments.
AvailabilityTag string `protobuf:"bytes,7,opt,name=availability_tag,json=availabilityTag" json:"availability_tag,omitempty"`
// Optional resources used to disambiguate this availability slot from
// others when different staff, room, or party_size values are part
// of the service.
//
// E.g. the same Yoga class with two 2 instructors.
// availability { resources { staff_id: "1" staff_name: "Amy" }
// spots_total: 10 spots_open: 7 }
// availability { resources { staff_id: "2" staff_name: "John" }
// spots_total: 5 spots_open: 2 }
Resources *Resources `protobuf:"bytes,8,opt,name=resources" json:"resources,omitempty"`
// A list of ids referencing the payment options which can be used to pay
// for this slot. The actual payment options are defined at the Merchant
// level, and can also be shared among multiple Merchants.
//
// This field overrides any payment_option_ids specified in the service
// message. Similarly payment_option_ids specified here do NOT have to be
// present in the service message, though must be defined at the
// Merchant level.
PaymentOptionId []string `protobuf:"bytes,9,rep,name=payment_option_id,json=paymentOptionId" json:"payment_option_id,omitempty"`
// The recurrence information for the availability, representing more than one
// start time. A recurrence should contain appointments for one working day.
Recurrence *Availability_Recurrence `protobuf:"bytes,10,opt,name=recurrence" json:"recurrence,omitempty"`
// When this service cannot be scheduled. To limit the number of
// schedule_exception messages consider joining adjacent exceptions.
ScheduleException []*Availability_ScheduleException `protobuf:"bytes,11,rep,name=schedule_exception,json=scheduleException" json:"schedule_exception,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Availability) Reset() { *m = Availability{} }
func (m *Availability) String() string { return proto.CompactTextString(m) }
func (*Availability) ProtoMessage() {}
func (*Availability) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{3}
}
func (m *Availability) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Availability.Unmarshal(m, b)
}
func (m *Availability) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Availability.Marshal(b, m, deterministic)
}
func (dst *Availability) XXX_Merge(src proto.Message) {
xxx_messageInfo_Availability.Merge(dst, src)
}
func (m *Availability) XXX_Size() int {
return xxx_messageInfo_Availability.Size(m)
}
func (m *Availability) XXX_DiscardUnknown() {
xxx_messageInfo_Availability.DiscardUnknown(m)
}
var xxx_messageInfo_Availability proto.InternalMessageInfo
func (m *Availability) GetMerchantId() string {
if m != nil {
return m.MerchantId
}
return ""
}
func (m *Availability) GetServiceId() string {
if m != nil {
return m.ServiceId
}
return ""
}
func (m *Availability) GetStartSec() int64 {
if m != nil {
return m.StartSec
}
return 0
}
func (m *Availability) GetDurationSec() int64 {
if m != nil {
return m.DurationSec
}
return 0
}
func (m *Availability) GetSpotsTotal() int64 {
if m != nil {
return m.SpotsTotal
}
return 0
}
func (m *Availability) GetSpotsOpen() int64 {
if m != nil {
return m.SpotsOpen
}
return 0
}
func (m *Availability) GetAvailabilityTag() string {
if m != nil {
return m.AvailabilityTag
}
return ""
}
func (m *Availability) GetResources() *Resources {
if m != nil {
return m.Resources
}
return nil
}
func (m *Availability) GetPaymentOptionId() []string {
if m != nil {
return m.PaymentOptionId
}
return nil
}
func (m *Availability) GetRecurrence() *Availability_Recurrence {
if m != nil {
return m.Recurrence
}
return nil
}
func (m *Availability) GetScheduleException() []*Availability_ScheduleException {
if m != nil {
return m.ScheduleException
}
return nil
}
// Recurrence messages are optional, but allow for a more compact
// representation of consistently repeating availability slots. They typically
// represent a day's working schedule.
// ScheduleException messages are then used to represent booked/unavailable
// time ranges within the work day.
//
// Requirements:
// 1. The expansion of availability slots or recurrences must NOT create
// identical slots. If the ids, start_sec, duration_sec, and resources
// match, slots are considered identical.
// 2. Do NOT mix the standard availability format and recurrence within the
// slots of a single service. Recurrence benefits merchants/services that
// offer appointments. The standard format is geared towards
// merchants/services with regularly scheduled classes.
type Availability_Recurrence struct {
// The inclusive maximum UTC timestamp the availability repeats until.
RepeatUntilSec int64 `protobuf:"varint,1,opt,name=repeat_until_sec,json=repeatUntilSec" json:"repeat_until_sec,omitempty"`
// Defines the time between successive availability slots.
//
// E.g. An availability with a duration of 20 min, a repeat_every_sec of
// 30 min, a start_sec of 9:00am, and a repeat_until_sec of 11:00am will
// yield slots at 9-9:20am, 9:30-9:50am, 10-10:20am, 10:30-10:50am,
// 11-11:20am.
RepeatEverySec int32 `protobuf:"varint,2,opt,name=repeat_every_sec,json=repeatEverySec" json:"repeat_every_sec,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Availability_Recurrence) Reset() { *m = Availability_Recurrence{} }
func (m *Availability_Recurrence) String() string { return proto.CompactTextString(m) }
func (*Availability_Recurrence) ProtoMessage() {}
func (*Availability_Recurrence) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{3, 0}
}
func (m *Availability_Recurrence) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Availability_Recurrence.Unmarshal(m, b)
}
func (m *Availability_Recurrence) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Availability_Recurrence.Marshal(b, m, deterministic)
}
func (dst *Availability_Recurrence) XXX_Merge(src proto.Message) {
xxx_messageInfo_Availability_Recurrence.Merge(dst, src)
}
func (m *Availability_Recurrence) XXX_Size() int {
return xxx_messageInfo_Availability_Recurrence.Size(m)
}
func (m *Availability_Recurrence) XXX_DiscardUnknown() {
xxx_messageInfo_Availability_Recurrence.DiscardUnknown(m)
}
var xxx_messageInfo_Availability_Recurrence proto.InternalMessageInfo
func (m *Availability_Recurrence) GetRepeatUntilSec() int64 {
if m != nil {
return m.RepeatUntilSec
}
return 0
}
func (m *Availability_Recurrence) GetRepeatEverySec() int32 {
if m != nil {
return m.RepeatEverySec
}
return 0
}
// ScheduleException messages are used to represent booked/unavailable time
// ranges within the work day. As time slots are booked, the list of
// exceptions should grow to reflect the newly unavailable time ranges.
// The recurrence itself shouldn't be modified.
type Availability_ScheduleException struct {
// The time range of the exception.
TimeRange *TimeRange `protobuf:"bytes,1,opt,name=time_range,json=timeRange" json:"time_range,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Availability_ScheduleException) Reset() { *m = Availability_ScheduleException{} }
func (m *Availability_ScheduleException) String() string { return proto.CompactTextString(m) }
func (*Availability_ScheduleException) ProtoMessage() {}
func (*Availability_ScheduleException) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{3, 1}
}
func (m *Availability_ScheduleException) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Availability_ScheduleException.Unmarshal(m, b)
}
func (m *Availability_ScheduleException) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Availability_ScheduleException.Marshal(b, m, deterministic)
}
func (dst *Availability_ScheduleException) XXX_Merge(src proto.Message) {
xxx_messageInfo_Availability_ScheduleException.Merge(dst, src)
}
func (m *Availability_ScheduleException) XXX_Size() int {
return xxx_messageInfo_Availability_ScheduleException.Size(m)
}
func (m *Availability_ScheduleException) XXX_DiscardUnknown() {
xxx_messageInfo_Availability_ScheduleException.DiscardUnknown(m)
}
var xxx_messageInfo_Availability_ScheduleException proto.InternalMessageInfo
func (m *Availability_ScheduleException) GetTimeRange() *TimeRange {
if m != nil {
return m.TimeRange
}
return nil
}
// A resource is used to disambiguate availability slots from one another when
// different staff, room or party_size values are part of the service.
// Multiple slots for the same service and time interval can co-exist when they
// have different resources.
type Resources struct {
// Optional id for a staff member providing the service. This field identifies
// the staff member across all merchants, services, and availability records.
// It also needs to be stable over time to allow correlation with past
// bookings.
// This field must be present if staff_name is present.
StaffId string `protobuf:"bytes,1,opt,name=staff_id,json=staffId" json:"staff_id,omitempty"`
// Optional name of a staff member providing the service. This field will be
// displayed to users making a booking, and should be human readable, as
// opposed to an opaque identifier.
// This field must be present if staff_id is present.
StaffName string `protobuf:"bytes,2,opt,name=staff_name,json=staffName" json:"staff_name,omitempty"`
// An optional id for the room the service is located in. This field
// identifies the room across all merchants, services, and availability
// records. It also needs to be stable over time to allow correlation with
// past bookings.
// This field must be present if room_name is present.
RoomId string `protobuf:"bytes,3,opt,name=room_id,json=roomId" json:"room_id,omitempty"`
// An optional name for the room the service is located in. This
// field will be displayed to users making a booking, and should be human
// readable, as opposed to an opaque identifier.
// This field must be present if room_id is present.
RoomName string `protobuf:"bytes,4,opt,name=room_name,json=roomName" json:"room_name,omitempty"`
// Applicable only for Dining: The party size which can be accommodated
// during this time slot. A restaurant can be associated with multiple Slots
// for the same time, each specifying a different party_size, if for instance
// 2, 3, or 4 people can be seated with a reservation.
PartySize int32 `protobuf:"varint,5,opt,name=party_size,json=partySize" json:"party_size,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Resources) Reset() { *m = Resources{} }
func (m *Resources) String() string { return proto.CompactTextString(m) }
func (*Resources) ProtoMessage() {}
func (*Resources) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{4}
}
func (m *Resources) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Resources.Unmarshal(m, b)
}
func (m *Resources) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Resources.Marshal(b, m, deterministic)
}
func (dst *Resources) XXX_Merge(src proto.Message) {
xxx_messageInfo_Resources.Merge(dst, src)
}
func (m *Resources) XXX_Size() int {
return xxx_messageInfo_Resources.Size(m)
}
func (m *Resources) XXX_DiscardUnknown() {
xxx_messageInfo_Resources.DiscardUnknown(m)
}
var xxx_messageInfo_Resources proto.InternalMessageInfo
func (m *Resources) GetStaffId() string {
if m != nil {
return m.StaffId
}
return ""
}
func (m *Resources) GetStaffName() string {
if m != nil {
return m.StaffName
}
return ""
}
func (m *Resources) GetRoomId() string {
if m != nil {
return m.RoomId
}
return ""
}
func (m *Resources) GetRoomName() string {
if m != nil {
return m.RoomName
}
return ""
}
func (m *Resources) GetPartySize() int32 {
if m != nil {
return m.PartySize
}
return 0
}
type TimeRange struct {
BeginSec int64 `protobuf:"varint,1,opt,name=begin_sec,json=beginSec" json:"begin_sec,omitempty"`
EndSec int64 `protobuf:"varint,2,opt,name=end_sec,json=endSec" json:"end_sec,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *TimeRange) Reset() { *m = TimeRange{} }
func (m *TimeRange) String() string { return proto.CompactTextString(m) }
func (*TimeRange) ProtoMessage() {}
func (*TimeRange) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{5}
}
func (m *TimeRange) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_TimeRange.Unmarshal(m, b)
}
func (m *TimeRange) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_TimeRange.Marshal(b, m, deterministic)
}
func (dst *TimeRange) XXX_Merge(src proto.Message) {
xxx_messageInfo_TimeRange.Merge(dst, src)
}
func (m *TimeRange) XXX_Size() int {
return xxx_messageInfo_TimeRange.Size(m)
}
func (m *TimeRange) XXX_DiscardUnknown() {
xxx_messageInfo_TimeRange.DiscardUnknown(m)
}
var xxx_messageInfo_TimeRange proto.InternalMessageInfo
func (m *TimeRange) GetBeginSec() int64 {
if m != nil {
return m.BeginSec
}
return 0
}
func (m *TimeRange) GetEndSec() int64 {
if m != nil {
return m.EndSec
}
return 0
}
type ServiceFeed struct {
Metadata *FeedMetadata `protobuf:"bytes,1,opt,name=metadata" json:"metadata,omitempty"`
Service []*Service `protobuf:"bytes,2,rep,name=service" json:"service,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ServiceFeed) Reset() { *m = ServiceFeed{} }
func (m *ServiceFeed) String() string { return proto.CompactTextString(m) }
func (*ServiceFeed) ProtoMessage() {}
func (*ServiceFeed) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{6}
}
func (m *ServiceFeed) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ServiceFeed.Unmarshal(m, b)
}
func (m *ServiceFeed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ServiceFeed.Marshal(b, m, deterministic)
}
func (dst *ServiceFeed) XXX_Merge(src proto.Message) {
xxx_messageInfo_ServiceFeed.Merge(dst, src)
}
func (m *ServiceFeed) XXX_Size() int {
return xxx_messageInfo_ServiceFeed.Size(m)
}
func (m *ServiceFeed) XXX_DiscardUnknown() {
xxx_messageInfo_ServiceFeed.DiscardUnknown(m)
}
var xxx_messageInfo_ServiceFeed proto.InternalMessageInfo
func (m *ServiceFeed) GetMetadata() *FeedMetadata {
if m != nil {
return m.Metadata
}
return nil
}
func (m *ServiceFeed) GetService() []*Service {
if m != nil {
return m.Service
}
return nil
}
// The definition of a service provided by a merchant.
type Service struct {
// An opaque string from an aggregator partner which uniquely identifies a
// merchant. (required)
MerchantId string `protobuf:"bytes,1,opt,name=merchant_id,json=merchantId" json:"merchant_id,omitempty"`
// An opaque string from an aggregator partner which uniquely identifies the
// service. (required)
ServiceId string `protobuf:"bytes,2,opt,name=service_id,json=serviceId" json:"service_id,omitempty"`
// The name of the service, suitable for display to users, e.g. "Men's
// haircut". (required)
Name string `protobuf:"bytes,3,opt,name=name" json:"name,omitempty"`
// The description of the service, suitable for display to users.
//
// This field now supports both plain text and HTML-like formatting rules to
// display structural contents to end-users. Unlike plain text sections,
// customized layouts can be created here using headings, paragraphs, lists
// and some phrase tags. Please read the following instructions and notes
// carefully to create better user-experience.
//
// Supported HTML-like formatting tags:
//
// Heading tags: <h1>, <h2>, <h3>, <h4>, <h5>, <h6>
// Heading tags can be used to display titles and sub-titles. For example,
// <h1>Itinerary</h1> will display the inline text as the most important
// heading of the section. Note that any inner HTML tags, styles or
// attributes will be ignored. For example, <h1 style=".."> will be treated
// the same as <h1>. Only pure text wil be preserved.
//
// Paragraph tag: <p>:
// Paragraph tag can be used to wrap detailed introduction or contents. Any
// inner tags, styles or attributes will be ignored with a few exceptions:
// <br>, <strong> and <em>. Please see the phrase tag section below for more
// details.
//
// List tags: <ul>, <ol>, <li>
// <ul> tag can be used with <li> tag to display unordered lists, and <ol>
// tag can be used with <li> to display ordered lists. This is a good tool
// to display checklists, highlights or any other lists that fit your
// use-cases.
// Example: To show a list of features of a cruise trip:
// <ol>
// <li>Wonderful ocean view and chances to play with wildlife.</li>
// <li>Carefully designed travel arrangements and services.</li>
// <li>Gauranteed lowest price.</li>
// </ol>
// Note that only <li> children under <ul> or <ol> tags will be converted. All
// other children will be dropped. Also any inner tags, attributes and styles
// will be ignored, only pure text contents are preserved.
//
// Division tag: <div>
// All supported inner tags of the <div> tag will be parsed with the rules
// stated above. But <div> tag itself does not mean any grouping or
// indenting here. Also any inner attributes and styles will be ignored.
//
// Phrase tags: <br>, <strong>, <em>:
// Only the three tags mentioned above are supported. <br> can be used to
// break lines in paragraphs, and <strong>/<em> can be used to highlight
// important text. Any other phrase tags will be ignored.
//
// Unsupported tags:
// * <html>, <header> and <body> tags are not allowed.
// * Any URLs, anchors, links will be striped, and will never be displayed
// to end-users. If you want to use photos to create a rich user experience,
// please use the "related_media" field below to send your photo urls
// * Any other tags not mentioned above are not supported (for example
// <table>, <td> ...).
//
// Important notes:
// * Try not to use other tags except for the supported ones mentioned
// above, because contents within unsupported tags will be excluded from UI
// rendering and may lead to undesired user experience.
// * Try avoid deep nested structures like more than 3 different heading
// levels or nested lists. Keeping the structure flat, simple and
// straightforward helps to create a better user experience.
// * If the currently supported layouts are not enough for your use cases,
// please contact Google with your requests and we will find the best
// approach for you.
//
// (required)
Description string `protobuf:"bytes,4,opt,name=description" json:"description,omitempty"`
// The price of the service. (optional, overridden when payment options or
// ticket types present)
Price *Price `protobuf:"bytes,5,opt,name=price" json:"price,omitempty"`
// Rules to book/cancel an appointment. (optional)
Rules *SchedulingRules `protobuf:"bytes,6,opt,name=rules" json:"rules,omitempty"`
// Intake forms to customize the service. (optional)
Form []*ServiceIntakeForm `protobuf:"bytes,7,rep,name=form" json:"form,omitempty"`
// Whether a prepayment is required, optional or not supported. (optional)
PrepaymentType Service_PrepaymentType `protobuf:"varint,8,opt,name=prepayment_type,json=prepaymentType,enum=maps.booking.feeds.Service_PrepaymentType" json:"prepayment_type,omitempty"`
// The service's tax rate. If present this field overrides any tax_rate set at
// the merchant level. An empty message (i.e. tax_rate { }) will reset the
// applied tax rate to zero. (optional)
TaxRate *TaxRate `protobuf:"bytes,9,opt,name=tax_rate,json=taxRate" json:"tax_rate,omitempty"`
// A list of ids referencing the payment options which can be used to pay
// for this service. The actual payment options are defined at the Merchant
// level, and can also be shared among multiple Merchants. (optional)
PaymentOptionId []string `protobuf:"bytes,10,rep,name=payment_option_id,json=paymentOptionId" json:"payment_option_id,omitempty"`
// Defines how a deposit may be charged to the user. Can be overridden at the
// availability level. (optional)
Deposit *Deposit `protobuf:"bytes,11,opt,name=deposit" json:"deposit,omitempty"`
// Defines a no show fee that may be charged to the user. Can be overridden
// at the availability level. (optional)
NoShowFee *NoShowFee `protobuf:"bytes,12,opt,name=no_show_fee,json=noShowFee" json:"no_show_fee,omitempty"`
// Indicates whether the user must provide a credit card in order to book this
// service.
// This value can be overridden at the availability level. (optional)
RequireCreditCard RequireCreditCard `protobuf:"varint,13,opt,name=require_credit_card,json=requireCreditCard,enum=maps.booking.feeds.RequireCreditCard" json:"require_credit_card,omitempty"`
// An action link related to this service.
ActionLink []*ActionLink `protobuf:"bytes,14,rep,name=action_link,json=actionLink" json:"action_link,omitempty"`
// The predefined type of this service. Currently, only used with action_link.
Type Service_ServiceType `protobuf:"varint,15,opt,name=type,enum=maps.booking.feeds.Service_ServiceType" json:"type,omitempty"`
// Types of tickets that can be booked/purchased for this service, if tickets
// are supported. (optional)
TicketType []*TicketType `protobuf:"bytes,16,rep,name=ticket_type,json=ticketType" json:"ticket_type,omitempty"`
// Photos related to this service. Google will crawl these media to
// ensure that they are displayed to end-users in the most efficient way.
// (optional)
RelatedMedia []*RelatedMedia `protobuf:"bytes,17,rep,name=related_media,json=relatedMedia" json:"related_media,omitempty"`
// Service attribute values that apply to this service (optional).
// Each Service may have zero or more values for each service attribute
// defined in the corresponding Merchant.
ServiceAttributeValueId []*ServiceAttributeValueId `protobuf:"bytes,18,rep,name=service_attribute_value_id,json=serviceAttributeValueId" json:"service_attribute_value_id,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Service) Reset() { *m = Service{} }
func (m *Service) String() string { return proto.CompactTextString(m) }
func (*Service) ProtoMessage() {}
func (*Service) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{7}
}
func (m *Service) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Service.Unmarshal(m, b)
}
func (m *Service) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Service.Marshal(b, m, deterministic)
}
func (dst *Service) XXX_Merge(src proto.Message) {
xxx_messageInfo_Service.Merge(dst, src)
}
func (m *Service) XXX_Size() int {
return xxx_messageInfo_Service.Size(m)
}
func (m *Service) XXX_DiscardUnknown() {
xxx_messageInfo_Service.DiscardUnknown(m)
}
var xxx_messageInfo_Service proto.InternalMessageInfo
func (m *Service) GetMerchantId() string {
if m != nil {
return m.MerchantId
}
return ""
}
func (m *Service) GetServiceId() string {
if m != nil {
return m.ServiceId
}
return ""
}
func (m *Service) GetName() string {
if m != nil {
return m.Name
}
return ""
}
func (m *Service) GetDescription() string {
if m != nil {
return m.Description
}
return ""
}
func (m *Service) GetPrice() *Price {
if m != nil {
return m.Price
}
return nil
}
func (m *Service) GetRules() *SchedulingRules {
if m != nil {
return m.Rules
}
return nil
}
func (m *Service) GetForm() []*ServiceIntakeForm {
if m != nil {
return m.Form
}
return nil
}
func (m *Service) GetPrepaymentType() Service_PrepaymentType {
if m != nil {
return m.PrepaymentType
}
return Service_PREPAYMENT_TYPE_UNSPECIFIED
}
func (m *Service) GetTaxRate() *TaxRate {
if m != nil {
return m.TaxRate
}
return nil
}
func (m *Service) GetPaymentOptionId() []string {
if m != nil {
return m.PaymentOptionId
}
return nil
}
func (m *Service) GetDeposit() *Deposit {
if m != nil {
return m.Deposit
}
return nil
}
func (m *Service) GetNoShowFee() *NoShowFee {
if m != nil {
return m.NoShowFee
}
return nil
}
func (m *Service) GetRequireCreditCard() RequireCreditCard {
if m != nil {
return m.RequireCreditCard
}
return RequireCreditCard_REQUIRE_CREDIT_CARD_UNSPECIFIED
}
func (m *Service) GetActionLink() []*ActionLink {
if m != nil {
return m.ActionLink
}
return nil
}
func (m *Service) GetType() Service_ServiceType {
if m != nil {
return m.Type
}
return Service_SERVICE_TYPE_UNSPECIFIED
}
func (m *Service) GetTicketType() []*TicketType {
if m != nil {
return m.TicketType
}
return nil
}
func (m *Service) GetRelatedMedia() []*RelatedMedia {
if m != nil {
return m.RelatedMedia
}
return nil
}
func (m *Service) GetServiceAttributeValueId() []*ServiceAttributeValueId {
if m != nil {
return m.ServiceAttributeValueId
}
return nil
}
// The price of a service or a fee.
type Price struct {
// The price in micro-units of the currency.
// Fractions of smallest currency unit will be rounded using nearest even
// rounding. (e.g. For USD 2.5 cents rounded to 2 cents, 3.5 cents rounded to
// 4 cents, 0.5 cents rounded to 0 cents, 2.51 cents rounded to 3 cents).
// (required)
PriceMicros int64 `protobuf:"varint,1,opt,name=price_micros,json=priceMicros" json:"price_micros,omitempty"`
// The currency of the price that is defined in ISO 4217. (required)
CurrencyCode string `protobuf:"bytes,2,opt,name=currency_code,json=currencyCode" json:"currency_code,omitempty"`
// An optional and opaque string that identifies the pricing option that is
// associated with the extended price. (optional)
PricingOptionTag string `protobuf:"bytes,3,opt,name=pricing_option_tag,json=pricingOptionTag" json:"pricing_option_tag,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Price) Reset() { *m = Price{} }
func (m *Price) String() string { return proto.CompactTextString(m) }
func (*Price) ProtoMessage() {}
func (*Price) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{8}
}
func (m *Price) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Price.Unmarshal(m, b)
}
func (m *Price) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Price.Marshal(b, m, deterministic)
}
func (dst *Price) XXX_Merge(src proto.Message) {
xxx_messageInfo_Price.Merge(dst, src)
}
func (m *Price) XXX_Size() int {
return xxx_messageInfo_Price.Size(m)
}
func (m *Price) XXX_DiscardUnknown() {
xxx_messageInfo_Price.DiscardUnknown(m)
}
var xxx_messageInfo_Price proto.InternalMessageInfo
func (m *Price) GetPriceMicros() int64 {
if m != nil {
return m.PriceMicros
}
return 0
}
func (m *Price) GetCurrencyCode() string {
if m != nil {
return m.CurrencyCode
}
return ""
}
func (m *Price) GetPricingOptionTag() string {
if m != nil {
return m.PricingOptionTag
}
return ""
}
// The scheduling rules for a service.
type SchedulingRules struct {
// The minimum advance notice in seconds required to book an appointment.
// (optional)
MinAdvanceBooking int64 `protobuf:"varint,1,opt,name=min_advance_booking,json=minAdvanceBooking" json:"min_advance_booking,omitempty"`
// The minimum advance notice in seconds required to cancel a booked
// appointment online. (optional)
MinAdvanceOnlineCanceling int64 `protobuf:"varint,2,opt,name=min_advance_online_canceling,json=minAdvanceOnlineCanceling" json:"min_advance_online_canceling,omitempty"`
// The fee for canceling within the minimum advance notice period.
LateCancellationFee *Price `protobuf:"bytes,3,opt,name=late_cancellation_fee,json=lateCancellationFee" json:"late_cancellation_fee,omitempty"` // Deprecated: Do not use.
// The fee for no-show without canceling.
NoshowFee *Price `protobuf:"bytes,4,opt,name=noshow_fee,json=noshowFee" json:"noshow_fee,omitempty"` // Deprecated: Do not use.
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *SchedulingRules) Reset() { *m = SchedulingRules{} }
func (m *SchedulingRules) String() string { return proto.CompactTextString(m) }
func (*SchedulingRules) ProtoMessage() {}
func (*SchedulingRules) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{9}
}
func (m *SchedulingRules) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_SchedulingRules.Unmarshal(m, b)
}
func (m *SchedulingRules) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_SchedulingRules.Marshal(b, m, deterministic)
}
func (dst *SchedulingRules) XXX_Merge(src proto.Message) {
xxx_messageInfo_SchedulingRules.Merge(dst, src)
}
func (m *SchedulingRules) XXX_Size() int {
return xxx_messageInfo_SchedulingRules.Size(m)
}
func (m *SchedulingRules) XXX_DiscardUnknown() {
xxx_messageInfo_SchedulingRules.DiscardUnknown(m)
}
var xxx_messageInfo_SchedulingRules proto.InternalMessageInfo
func (m *SchedulingRules) GetMinAdvanceBooking() int64 {
if m != nil {
return m.MinAdvanceBooking
}
return 0
}
func (m *SchedulingRules) GetMinAdvanceOnlineCanceling() int64 {
if m != nil {
return m.MinAdvanceOnlineCanceling
}
return 0
}
// Deprecated: Do not use.
func (m *SchedulingRules) GetLateCancellationFee() *Price {
if m != nil {
return m.LateCancellationFee
}
return nil
}
// Deprecated: Do not use.
func (m *SchedulingRules) GetNoshowFee() *Price {
if m != nil {
return m.NoshowFee
}
return nil
}
// A tax rate applied when charging the user for a service, and which can be set
// on either a per merchant, or per service basis.
type TaxRate struct {
// A tax rate in millionths of one percent, effectively giving 6 decimals of
// precision. For example, if the tax rate is 7.253%, this field should be set
// to 7253000.
//
// If this field is left unset or set to 0, the total price charged to a user
// for any service provided by this merchant is the exact price specified by
// Service.price. The service price is assumed to be exempt from or already
// inclusive of applicable taxes. Taxes will not be shown to the user as a
// separate line item.
//
// If this field is set to any nonzero value, the total price charged to a
// user for any service provided by this merchant will include the service
// price plus the tax assessed using the tax rate provided here. Fractions of
// the smallest currency unit (for example, fractions of one cent) will be
// rounded using nearest even rounding. Taxes will be shown to the user as a
// separate line item. (required)
MicroPercent int32 `protobuf:"varint,1,opt,name=micro_percent,json=microPercent" json:"micro_percent,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *TaxRate) Reset() { *m = TaxRate{} }
func (m *TaxRate) String() string { return proto.CompactTextString(m) }
func (*TaxRate) ProtoMessage() {}
func (*TaxRate) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{10}
}
func (m *TaxRate) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_TaxRate.Unmarshal(m, b)
}
func (m *TaxRate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_TaxRate.Marshal(b, m, deterministic)
}
func (dst *TaxRate) XXX_Merge(src proto.Message) {
xxx_messageInfo_TaxRate.Merge(dst, src)
}
func (m *TaxRate) XXX_Size() int {
return xxx_messageInfo_TaxRate.Size(m)
}
func (m *TaxRate) XXX_DiscardUnknown() {
xxx_messageInfo_TaxRate.DiscardUnknown(m)
}
var xxx_messageInfo_TaxRate proto.InternalMessageInfo
func (m *TaxRate) GetMicroPercent() int32 {
if m != nil {
return m.MicroPercent
}
return 0
}
// Defines a field that is included in a ServiceIntakeForm.
type ServiceIntakeFormField struct {
// The type of this field. (required)
Type ServiceIntakeFormField_FieldType `protobuf:"varint,1,opt,name=type,enum=maps.booking.feeds.ServiceIntakeFormField_FieldType" json:"type,omitempty"`
// The text shown to the user for this field. (required)
Label string `protobuf:"bytes,2,opt,name=label" json:"label,omitempty"`
// For MULTIPLE_CHOICE, CHECKBOXES, or DROPDOWN, the values to enumerate.
// (optional)
Value []string `protobuf:"bytes,3,rep,name=value" json:"value,omitempty"`
// Indicates whether an answer to this field is required by a user. (optional)
IsRequired bool `protobuf:"varint,4,opt,name=is_required,json=isRequired" json:"is_required,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ServiceIntakeFormField) Reset() { *m = ServiceIntakeFormField{} }
func (m *ServiceIntakeFormField) String() string { return proto.CompactTextString(m) }
func (*ServiceIntakeFormField) ProtoMessage() {}
func (*ServiceIntakeFormField) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{11}
}
func (m *ServiceIntakeFormField) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ServiceIntakeFormField.Unmarshal(m, b)
}
func (m *ServiceIntakeFormField) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ServiceIntakeFormField.Marshal(b, m, deterministic)
}
func (dst *ServiceIntakeFormField) XXX_Merge(src proto.Message) {
xxx_messageInfo_ServiceIntakeFormField.Merge(dst, src)
}
func (m *ServiceIntakeFormField) XXX_Size() int {
return xxx_messageInfo_ServiceIntakeFormField.Size(m)
}
func (m *ServiceIntakeFormField) XXX_DiscardUnknown() {
xxx_messageInfo_ServiceIntakeFormField.DiscardUnknown(m)
}
var xxx_messageInfo_ServiceIntakeFormField proto.InternalMessageInfo
func (m *ServiceIntakeFormField) GetType() ServiceIntakeFormField_FieldType {
if m != nil {
return m.Type
}
return ServiceIntakeFormField_FIELD_TYPE_UNSPECIFIED
}
func (m *ServiceIntakeFormField) GetLabel() string {
if m != nil {
return m.Label
}
return ""
}
func (m *ServiceIntakeFormField) GetValue() []string {
if m != nil {
return m.Value
}
return nil
}
func (m *ServiceIntakeFormField) GetIsRequired() bool {
if m != nil {
return m.IsRequired
}
return false
}
// Defines an intake form that customizes the service provided by a merchant.
type ServiceIntakeForm struct {
// Fields that will be displayed to the user. (required)
Field []*ServiceIntakeFormField `protobuf:"bytes,1,rep,name=field" json:"field,omitempty"`
// If true, this form will be shown to first time customers.
// (one of first_time_customers or returning_customers required)
FirstTimeCustomers bool `protobuf:"varint,2,opt,name=first_time_customers,json=firstTimeCustomers" json:"first_time_customers,omitempty"`
// If true, this form will be shown to repeat customers.
// (one of first_time_customers or returning_customers required)
ReturningCustomers bool `protobuf:"varint,3,opt,name=returning_customers,json=returningCustomers" json:"returning_customers,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ServiceIntakeForm) Reset() { *m = ServiceIntakeForm{} }
func (m *ServiceIntakeForm) String() string { return proto.CompactTextString(m) }
func (*ServiceIntakeForm) ProtoMessage() {}
func (*ServiceIntakeForm) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{12}
}
func (m *ServiceIntakeForm) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ServiceIntakeForm.Unmarshal(m, b)
}
func (m *ServiceIntakeForm) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ServiceIntakeForm.Marshal(b, m, deterministic)
}
func (dst *ServiceIntakeForm) XXX_Merge(src proto.Message) {
xxx_messageInfo_ServiceIntakeForm.Merge(dst, src)
}
func (m *ServiceIntakeForm) XXX_Size() int {
return xxx_messageInfo_ServiceIntakeForm.Size(m)
}
func (m *ServiceIntakeForm) XXX_DiscardUnknown() {
xxx_messageInfo_ServiceIntakeForm.DiscardUnknown(m)
}
var xxx_messageInfo_ServiceIntakeForm proto.InternalMessageInfo
func (m *ServiceIntakeForm) GetField() []*ServiceIntakeFormField {
if m != nil {
return m.Field
}
return nil
}
func (m *ServiceIntakeForm) GetFirstTimeCustomers() bool {
if m != nil {
return m.FirstTimeCustomers
}
return false
}
func (m *ServiceIntakeForm) GetReturningCustomers() bool {
if m != nil {
return m.ReturningCustomers
}
return false
}
// A deposit that the user may be charged or have a hold on their credit card
// for.
type Deposit struct {
// Deposit amount.
Deposit *Price `protobuf:"bytes,1,opt,name=deposit" json:"deposit,omitempty"`
// Minimum advance cancellation for the deposit.
MinAdvanceCancellationSec int64 `protobuf:"varint,2,opt,name=min_advance_cancellation_sec,json=minAdvanceCancellationSec" json:"min_advance_cancellation_sec,omitempty"`
// Defines how the deposit is determined from the availability.
DepositType PriceType `protobuf:"varint,3,opt,name=deposit_type,json=depositType,enum=maps.booking.feeds.PriceType" json:"deposit_type,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *Deposit) Reset() { *m = Deposit{} }
func (m *Deposit) String() string { return proto.CompactTextString(m) }
func (*Deposit) ProtoMessage() {}
func (*Deposit) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{13}
}
func (m *Deposit) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_Deposit.Unmarshal(m, b)
}
func (m *Deposit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_Deposit.Marshal(b, m, deterministic)
}
func (dst *Deposit) XXX_Merge(src proto.Message) {
xxx_messageInfo_Deposit.Merge(dst, src)
}
func (m *Deposit) XXX_Size() int {
return xxx_messageInfo_Deposit.Size(m)
}
func (m *Deposit) XXX_DiscardUnknown() {
xxx_messageInfo_Deposit.DiscardUnknown(m)
}
var xxx_messageInfo_Deposit proto.InternalMessageInfo
func (m *Deposit) GetDeposit() *Price {
if m != nil {
return m.Deposit
}
return nil
}
func (m *Deposit) GetMinAdvanceCancellationSec() int64 {
if m != nil {
return m.MinAdvanceCancellationSec
}
return 0
}
func (m *Deposit) GetDepositType() PriceType {
if m != nil {
return m.DepositType
}
return PriceType_FIXED_RATE_DEFAULT
}
// A fee that a user may be charged if they have made a booking but do not
// show up.
type NoShowFee struct {
// The amount the user may be charged if they do not show up for their
// reservation.
Fee *Price `protobuf:"bytes,1,opt,name=fee" json:"fee,omitempty"`
// Defines how the fee is determined from the availability.
FeeType PriceType `protobuf:"varint,3,opt,name=fee_type,json=feeType,enum=maps.booking.feeds.PriceType" json:"fee_type,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *NoShowFee) Reset() { *m = NoShowFee{} }
func (m *NoShowFee) String() string { return proto.CompactTextString(m) }
func (*NoShowFee) ProtoMessage() {}
func (*NoShowFee) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{14}
}
func (m *NoShowFee) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_NoShowFee.Unmarshal(m, b)
}
func (m *NoShowFee) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_NoShowFee.Marshal(b, m, deterministic)
}
func (dst *NoShowFee) XXX_Merge(src proto.Message) {
xxx_messageInfo_NoShowFee.Merge(dst, src)
}
func (m *NoShowFee) XXX_Size() int {
return xxx_messageInfo_NoShowFee.Size(m)
}
func (m *NoShowFee) XXX_DiscardUnknown() {
xxx_messageInfo_NoShowFee.DiscardUnknown(m)
}
var xxx_messageInfo_NoShowFee proto.InternalMessageInfo
func (m *NoShowFee) GetFee() *Price {
if m != nil {
return m.Fee
}
return nil
}
func (m *NoShowFee) GetFeeType() PriceType {
if m != nil {
return m.FeeType
}
return PriceType_FIXED_RATE_DEFAULT
}
// An action URL with associated language, list of countries restricted to, and
// optional platform that indicates which platform this action should be
// performed on.
type ActionLink struct {
// The entry point URL for this action link.
Url string `protobuf:"bytes,1,opt,name=url" json:"url,omitempty"`
// The BCP-47 language tag identifying the language in which the content
// from this URI is available.
Language string `protobuf:"bytes,2,opt,name=language" json:"language,omitempty"`
// ISO 3166-1 alpha-2 country code. Leave empty for unrestricted visibility.
RestrictedCountry []string `protobuf:"bytes,3,rep,name=restricted_country,json=restrictedCountry" json:"restricted_country,omitempty"`
// The platform that this action should be performed on. If this field is
// unset, ACTION_PLATFORM_WEB_APPLICATION will be used as fallback.
Platform ActionPlatform `protobuf:"varint,4,opt,name=platform,enum=maps.booking.feeds.ActionPlatform" json:"platform,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ActionLink) Reset() { *m = ActionLink{} }
func (m *ActionLink) String() string { return proto.CompactTextString(m) }
func (*ActionLink) ProtoMessage() {}
func (*ActionLink) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{15}
}
func (m *ActionLink) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ActionLink.Unmarshal(m, b)
}
func (m *ActionLink) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ActionLink.Marshal(b, m, deterministic)
}
func (dst *ActionLink) XXX_Merge(src proto.Message) {
xxx_messageInfo_ActionLink.Merge(dst, src)
}
func (m *ActionLink) XXX_Size() int {
return xxx_messageInfo_ActionLink.Size(m)
}
func (m *ActionLink) XXX_DiscardUnknown() {
xxx_messageInfo_ActionLink.DiscardUnknown(m)
}
var xxx_messageInfo_ActionLink proto.InternalMessageInfo
func (m *ActionLink) GetUrl() string {
if m != nil {
return m.Url
}
return ""
}
func (m *ActionLink) GetLanguage() string {
if m != nil {
return m.Language
}
return ""
}
func (m *ActionLink) GetRestrictedCountry() []string {
if m != nil {
return m.RestrictedCountry
}
return nil
}
func (m *ActionLink) GetPlatform() ActionPlatform {
if m != nil {
return m.Platform
}
return ActionPlatform_ACTION_PLATFORM_UNSPECIFIED
}
// TicketType is used to differentiate among tickets (where a ticket can be a
// spot on a raft trip, an admission to a museum, etc.) with different prices
// and/or availabilities due to different user types or different service
// attributes.
type TicketType struct {
// The ticket id is used to differentiate among different ticket types of the
// same service, and is only expected to be unique within a service.
TicketTypeId string `protobuf:"bytes,1,opt,name=ticket_type_id,json=ticketTypeId" json:"ticket_type_id,omitempty"`
// This can be user visible, e.g., “adult”, "child", “veteran”, “Row J”, etc.
ShortDescription string `protobuf:"bytes,2,opt,name=short_description,json=shortDescription" json:"short_description,omitempty"`
// The price of a single ticket of this type, exclusive of any taxes. The tax
// rate of Service is applied to its tickets.
Price *Price `protobuf:"bytes,3,opt,name=price" json:"price,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *TicketType) Reset() { *m = TicketType{} }
func (m *TicketType) String() string { return proto.CompactTextString(m) }
func (*TicketType) ProtoMessage() {}
func (*TicketType) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{16}
}
func (m *TicketType) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_TicketType.Unmarshal(m, b)
}
func (m *TicketType) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_TicketType.Marshal(b, m, deterministic)
}
func (dst *TicketType) XXX_Merge(src proto.Message) {
xxx_messageInfo_TicketType.Merge(dst, src)
}
func (m *TicketType) XXX_Size() int {
return xxx_messageInfo_TicketType.Size(m)
}
func (m *TicketType) XXX_DiscardUnknown() {
xxx_messageInfo_TicketType.DiscardUnknown(m)
}
var xxx_messageInfo_TicketType proto.InternalMessageInfo
func (m *TicketType) GetTicketTypeId() string {
if m != nil {
return m.TicketTypeId
}
return ""
}
func (m *TicketType) GetShortDescription() string {
if m != nil {
return m.ShortDescription
}
return ""
}
func (m *TicketType) GetPrice() *Price {
if m != nil {
return m.Price
}
return nil
}
// Defines a media source. This field only contains the URL of this media source
// (only photos are supported for now). Google will crawl the media data to
// ensure that they are displayed to end-users in the most efficient way.
type RelatedMedia struct {
// URL of this media source.
Url string `protobuf:"bytes,1,opt,name=url" json:"url,omitempty"`
// Type of this media source.
Type RelatedMedia_MediaType `protobuf:"varint,2,opt,name=type,enum=maps.booking.feeds.RelatedMedia_MediaType" json:"type,omitempty"`
// Caption of the media, only plain text is supported. (optional)
Caption string `protobuf:"bytes,3,opt,name=caption" json:"caption,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *RelatedMedia) Reset() { *m = RelatedMedia{} }
func (m *RelatedMedia) String() string { return proto.CompactTextString(m) }
func (*RelatedMedia) ProtoMessage() {}
func (*RelatedMedia) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{17}
}
func (m *RelatedMedia) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_RelatedMedia.Unmarshal(m, b)
}
func (m *RelatedMedia) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_RelatedMedia.Marshal(b, m, deterministic)
}
func (dst *RelatedMedia) XXX_Merge(src proto.Message) {
xxx_messageInfo_RelatedMedia.Merge(dst, src)
}
func (m *RelatedMedia) XXX_Size() int {
return xxx_messageInfo_RelatedMedia.Size(m)
}
func (m *RelatedMedia) XXX_DiscardUnknown() {
xxx_messageInfo_RelatedMedia.DiscardUnknown(m)
}
var xxx_messageInfo_RelatedMedia proto.InternalMessageInfo
func (m *RelatedMedia) GetUrl() string {
if m != nil {
return m.Url
}
return ""
}
func (m *RelatedMedia) GetType() RelatedMedia_MediaType {
if m != nil {
return m.Type
}
return RelatedMedia_TYPE_UNSPECIFIED
}
func (m *RelatedMedia) GetCaption() string {
if m != nil {
return m.Caption
}
return ""
}
// Identifies a particular value of a service attribute to be applied to a
// Service.
type ServiceAttributeValueId struct {
// ID of an attribute as defined in Merchant.service_attribute, e.g.
// "service-type".
AttributeId string `protobuf:"bytes,1,opt,name=attribute_id,json=attributeId" json:"attribute_id,omitempty"`
// ID of the value for this attribute, e.g. "haircut". Must match a value_id
// in the service attribute definition.
ValueId string `protobuf:"bytes,2,opt,name=value_id,json=valueId" json:"value_id,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
XXX_sizecache int32 `json:"-"`
}
func (m *ServiceAttributeValueId) Reset() { *m = ServiceAttributeValueId{} }
func (m *ServiceAttributeValueId) String() string { return proto.CompactTextString(m) }
func (*ServiceAttributeValueId) ProtoMessage() {}
func (*ServiceAttributeValueId) Descriptor() ([]byte, []int) {
return fileDescriptor_feeds_0b3f05d3b8d0e7eb, []int{18}
}
func (m *ServiceAttributeValueId) XXX_Unmarshal(b []byte) error {
return xxx_messageInfo_ServiceAttributeValueId.Unmarshal(m, b)
}
func (m *ServiceAttributeValueId) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
return xxx_messageInfo_ServiceAttributeValueId.Marshal(b, m, deterministic)
}
func (dst *ServiceAttributeValueId) XXX_Merge(src proto.Message) {
xxx_messageInfo_ServiceAttributeValueId.Merge(dst, src)
}
func (m *ServiceAttributeValueId) XXX_Size() int {
return xxx_messageInfo_ServiceAttributeValueId.Size(m)
}
func (m *ServiceAttributeValueId) XXX_DiscardUnknown() {
xxx_messageInfo_ServiceAttributeValueId.DiscardUnknown(m)
}
var xxx_messageInfo_ServiceAttributeValueId proto.InternalMessageInfo
func (m *ServiceAttributeValueId) GetAttributeId() string {
if m != nil {
return m.AttributeId
}
return ""
}
func (m *ServiceAttributeValueId) GetValueId() string {
if m != nil {
return m.ValueId
}
return ""
}
func init() {
proto.RegisterType((*FeedMetadata)(nil), "maps.booking.feeds.FeedMetadata")
proto.RegisterType((*AvailabilityFeed)(nil), "maps.booking.feeds.AvailabilityFeed")
proto.RegisterType((*ServiceAvailability)(nil), "maps.booking.feeds.ServiceAvailability")
proto.RegisterType((*Availability)(nil), "maps.booking.feeds.Availability")
proto.RegisterType((*Availability_Recurrence)(nil), "maps.booking.feeds.Availability.Recurrence")
proto.RegisterType((*Availability_ScheduleException)(nil), "maps.booking.feeds.Availability.ScheduleException")
proto.RegisterType((*Resources)(nil), "maps.booking.feeds.Resources")
proto.RegisterType((*TimeRange)(nil), "maps.booking.feeds.TimeRange")
proto.RegisterType((*ServiceFeed)(nil), "maps.booking.feeds.ServiceFeed")
proto.RegisterType((*Service)(nil), "maps.booking.feeds.Service")
proto.RegisterType((*Price)(nil), "maps.booking.feeds.Price")
proto.RegisterType((*SchedulingRules)(nil), "maps.booking.feeds.SchedulingRules")
proto.RegisterType((*TaxRate)(nil), "maps.booking.feeds.TaxRate")
proto.RegisterType((*ServiceIntakeFormField)(nil), "maps.booking.feeds.ServiceIntakeFormField")
proto.RegisterType((*ServiceIntakeForm)(nil), "maps.booking.feeds.ServiceIntakeForm")
proto.RegisterType((*Deposit)(nil), "maps.booking.feeds.Deposit")
proto.RegisterType((*NoShowFee)(nil), "maps.booking.feeds.NoShowFee")
proto.RegisterType((*ActionLink)(nil), "maps.booking.feeds.ActionLink")
proto.RegisterType((*TicketType)(nil), "maps.booking.feeds.TicketType")
proto.RegisterType((*RelatedMedia)(nil), "maps.booking.feeds.RelatedMedia")
proto.RegisterType((*ServiceAttributeValueId)(nil), "maps.booking.feeds.ServiceAttributeValueId")
proto.RegisterEnum("maps.booking.feeds.PriceType", PriceType_name, PriceType_value)
proto.RegisterEnum("maps.booking.feeds.RequireCreditCard", RequireCreditCard_name, RequireCreditCard_value)
proto.RegisterEnum("maps.booking.feeds.ActionPlatform", ActionPlatform_name, ActionPlatform_value)
proto.RegisterEnum("maps.booking.feeds.FeedMetadata_ProcessingInstruction", FeedMetadata_ProcessingInstruction_name, FeedMetadata_ProcessingInstruction_value)
proto.RegisterEnum("maps.booking.feeds.Service_PrepaymentType", Service_PrepaymentType_name, Service_PrepaymentType_value)
proto.RegisterEnum("maps.booking.feeds.Service_ServiceType", Service_ServiceType_name, Service_ServiceType_value)
proto.RegisterEnum("maps.booking.feeds.ServiceIntakeFormField_FieldType", ServiceIntakeFormField_FieldType_name, ServiceIntakeFormField_FieldType_value)
proto.RegisterEnum("maps.booking.feeds.RelatedMedia_MediaType", RelatedMedia_MediaType_name, RelatedMedia_MediaType_value)
}
func init() { proto.RegisterFile("feeds.proto", fileDescriptor_feeds_0b3f05d3b8d0e7eb) }
var fileDescriptor_feeds_0b3f05d3b8d0e7eb = []byte{
// 2250 bytes of a gzipped FileDescriptorProto
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x58, 0x4f, 0x73, 0xdb, 0xc6,
0x15, 0x0f, 0x48, 0xd1, 0x24, 0x1f, 0x69, 0x19, 0x5c, 0xc9, 0x12, 0x2c, 0xc7, 0xb1, 0x0a, 0x37,
0x53, 0x55, 0x4e, 0x99, 0x56, 0x4e, 0x32, 0xc9, 0xc4, 0x4d, 0x42, 0x81, 0x90, 0x85, 0x31, 0x45,
0xc0, 0x4b, 0xc8, 0x8e, 0x7b, 0xd9, 0x40, 0xc0, 0x4a, 0xc2, 0x98, 0x04, 0xd8, 0x05, 0xa8, 0x58,
0x99, 0xc9, 0xa5, 0xa7, 0x1e, 0x3b, 0xd3, 0x5b, 0x3f, 0x41, 0x3b, 0xf5, 0x07, 0xe8, 0xf4, 0xd6,
0x53, 0x3f, 0x4e, 0x3f, 0x40, 0x2f, 0x9d, 0x5d, 0x80, 0x00, 0x28, 0x41, 0x96, 0x3b, 0xed, 0x85,
0xc2, 0xbe, 0xf7, 0x7e, 0xfb, 0xe7, 0xbd, 0x7d, 0xbf, 0xf7, 0x56, 0xd0, 0x3a, 0xa6, 0xd4, 0x8b,
0xba, 0x53, 0x16, 0xc6, 0x21, 0x42, 0x13, 0x67, 0x1a, 0x75, 0x8f, 0xc2, 0xf0, 0x95, 0x1f, 0x9c,
0x74, 0x85, 0x46, 0xfd, 0x57, 0x05, 0xda, 0x7b, 0x94, 0x7a, 0x07, 0x34, 0x76, 0x3c, 0x27, 0x76,
0xd0, 0x04, 0xd6, 0xa6, 0x2c, 0x74, 0x69, 0x14, 0xf9, 0xc1, 0x09, 0xf1, 0x83, 0x28, 0x66, 0x33,
0x37, 0xf6, 0xc3, 0x40, 0x91, 0x36, 0xa5, 0xad, 0xe5, 0x9d, 0xcf, 0xba, 0x97, 0x67, 0xe9, 0x16,
0x67, 0xe8, 0x5a, 0x19, 0xdc, 0xc8, 0xd1, 0xf8, 0xf6, 0xb4, 0x4c, 0x8c, 0x7e, 0x02, 0xed, 0xe8,
0xd4, 0x61, 0x1e, 0x09, 0x66, 0x93, 0x23, 0xca, 0x94, 0xca, 0xa6, 0xb4, 0x55, 0xc3, 0x2d, 0x21,
0x1b, 0x0a, 0x11, 0x37, 0x89, 0xc3, 0xd8, 0x19, 0x13, 0x21, 0x8c, 0x94, 0x6a, 0x62, 0x22, 0x64,
0x23, 0x21, 0x42, 0xab, 0x50, 0x0b, 0xc2, 0xc0, 0xa5, 0x4a, 0x6d, 0x53, 0xda, 0x5a, 0xc2, 0xc9,
0x00, 0xfd, 0x0a, 0x56, 0x4f, 0x68, 0x40, 0x99, 0xc3, 0x57, 0x22, 0xb1, 0x3f, 0xa1, 0x51, 0xec,
0x4c, 0xa6, 0xca, 0xd2, 0xa6, 0xb4, 0x55, 0xc5, 0x2b, 0xb9, 0xce, 0x9e, 0xab, 0x54, 0x07, 0x6e,
0x97, 0x6e, 0x1f, 0xad, 0xc0, 0x2d, 0x0b, 0x9b, 0x9a, 0x3e, 0x1a, 0x91, 0xc3, 0xe1, 0xd3, 0xa1,
0xf9, 0x62, 0x28, 0xbf, 0x87, 0xd6, 0x61, 0x65, 0x2e, 0xec, 0x8d, 0x88, 0x66, 0x1e, 0x58, 0x03,
0xdd, 0xd6, 0x65, 0x09, 0x6d, 0xc0, 0x5a, 0x41, 0x61, 0x0c, 0x35, 0xac, 0x1f, 0xe8, 0x43, 0xbb,
0x37, 0x90, 0x2b, 0xea, 0x1b, 0x09, 0xe4, 0xde, 0x99, 0xe3, 0x8f, 0x9d, 0x23, 0x7f, 0xec, 0xc7,
0xe7, 0xdc, 0x77, 0xe8, 0x31, 0x34, 0x26, 0xa9, 0xff, 0x84, 0x9f, 0x5b, 0x3b, 0x9b, 0xd7, 0xf9,
0x19, 0x67, 0x08, 0xf4, 0x1b, 0x58, 0x8d, 0x28, 0x3b, 0xf3, 0x5d, 0x4a, 0x9c, 0xc2, 0xcc, 0x4a,
0x65, 0xb3, 0xba, 0xd5, 0xda, 0xf9, 0x59, 0xd9, 0x4c, 0xa3, 0xc4, 0xbe, 0xb8, 0x11, 0xbc, 0x12,
0x5d, 0x16, 0xaa, 0xff, 0xae, 0xc0, 0x4a, 0x89, 0x31, 0xfa, 0x1c, 0x94, 0x28, 0x76, 0x58, 0x9c,
0xfb, 0x95, 0x30, 0x1a, 0xc5, 0xcc, 0x77, 0x63, 0x71, 0x82, 0x2a, 0x5e, 0x13, 0xfa, 0xcc, 0xb7,
0x38, 0xd5, 0xa2, 0x4f, 0x60, 0x8d, 0x06, 0x5e, 0x19, 0xae, 0x22, 0x70, 0xab, 0x34, 0xf0, 0x2e,
0xa3, 0x7e, 0x09, 0xab, 0x13, 0xca, 0xdc, 0x53, 0x27, 0x88, 0x89, 0xef, 0xe5, 0x18, 0x7e, 0x1b,
0x9a, 0x18, 0xcd, 0x75, 0x86, 0x97, 0x21, 0xba, 0x30, 0x3f, 0xd0, 0x02, 0x60, 0x49, 0x00, 0x3a,
0xa9, 0xaa, 0x60, 0x3f, 0x00, 0xc4, 0x68, 0x14, 0xce, 0x98, 0x4b, 0xa3, 0xdc, 0xfc, 0x86, 0x88,
0xc6, 0xbd, 0x32, 0x1f, 0xe2, 0xb9, 0x35, 0xee, 0x64, 0xc0, 0x6c, 0xb6, 0x3e, 0xb4, 0x17, 0x62,
0x51, 0x13, 0xb1, 0x28, 0x8d, 0xea, 0x42, 0x10, 0x16, 0x50, 0xea, 0x3f, 0x6b, 0xd0, 0x5e, 0x70,
0xfb, 0x7d, 0x68, 0x15, 0xdc, 0x20, 0x3c, 0xdd, 0xc4, 0x90, 0x9f, 0x1e, 0xdd, 0x03, 0xc8, 0x4f,
0x2d, 0x3c, 0xda, 0xc4, 0xcd, 0xec, 0xb0, 0xe8, 0x2e, 0x34, 0x93, 0xb0, 0x45, 0xd4, 0x15, 0xbe,
0xab, 0xe2, 0x86, 0x10, 0x8c, 0xa8, 0xcb, 0x33, 0xcd, 0x9b, 0xa5, 0xe9, 0xc2, 0xf5, 0x49, 0xa2,
0xb4, 0xe6, 0x32, 0x6e, 0x72, 0x1f, 0x5a, 0xd1, 0x34, 0x8c, 0x23, 0x22, 0xd2, 0x4f, 0xe4, 0x5b,
0x15, 0x83, 0x10, 0xd9, 0x5c, 0x22, 0xd6, 0x17, 0x06, 0xe1, 0x94, 0x06, 0xc2, 0x7b, 0x55, 0xdc,
0x14, 0x12, 0x73, 0x4a, 0x03, 0xf4, 0x73, 0x90, 0x8b, 0x07, 0x24, 0xb1, 0x73, 0xa2, 0xd4, 0xc5,
0x26, 0x6f, 0x15, 0xe5, 0xb6, 0x73, 0x82, 0xbe, 0x84, 0x66, 0xe6, 0x56, 0xa5, 0xf1, 0x2e, 0x61,
0xc8, 0xed, 0xd1, 0x36, 0x74, 0xa6, 0xce, 0xf9, 0x84, 0x06, 0x31, 0x09, 0xa7, 0xe2, 0x40, 0xbe,
0xa7, 0x34, 0x37, 0xab, 0x7c, 0xa1, 0x54, 0x61, 0x0a, 0xb9, 0xe1, 0xa1, 0xa7, 0x00, 0x8c, 0xba,
0x33, 0xc6, 0x28, 0xa7, 0x10, 0x10, 0x2b, 0x3d, 0xbc, 0x2e, 0x50, 0x5d, 0x9c, 0x41, 0x70, 0x01,
0x8e, 0x1c, 0x40, 0x91, 0x7b, 0x4a, 0xbd, 0xd9, 0x98, 0x12, 0xfa, 0xda, 0xa5, 0x62, 0x11, 0xa5,
0x25, 0xa2, 0xbf, 0x73, 0xed, 0xa4, 0xa3, 0x14, 0xaa, 0xcf, 0x91, 0xb8, 0x13, 0x5d, 0x14, 0x6d,
0x7c, 0x07, 0x90, 0x2f, 0x8e, 0xb6, 0x40, 0x66, 0x74, 0x4a, 0x9d, 0x98, 0xcc, 0x82, 0xd8, 0x1f,
0x8b, 0xc0, 0x25, 0x09, 0xb8, 0x9c, 0xc8, 0x0f, 0xb9, 0x98, 0xc7, 0x2e, 0xb7, 0xa4, 0x67, 0x94,
0x9d, 0x0b, 0xcb, 0x84, 0x6f, 0x53, 0x4b, 0x9d, 0x8b, 0x47, 0xd4, 0xdd, 0x78, 0x06, 0x9d, 0x4b,
0x3b, 0x41, 0x8f, 0x01, 0x78, 0xce, 0x12, 0xe6, 0x04, 0x27, 0x34, 0x65, 0xa9, 0xd2, 0x80, 0xf0,
0xe4, 0xc5, 0xdc, 0x08, 0x37, 0xe3, 0xf9, 0xa7, 0xfa, 0x27, 0x09, 0x9a, 0x59, 0xa4, 0xd0, 0x1d,
0xe0, 0xb7, 0xee, 0xf8, 0x38, 0xbf, 0xc3, 0x75, 0x31, 0x4e, 0x2f, 0xb0, 0x50, 0x05, 0xce, 0x84,
0x66, 0x17, 0x98, 0x4b, 0x86, 0xce, 0x84, 0xa2, 0x75, 0xa8, 0xb3, 0x30, 0x9c, 0x70, 0x60, 0x92,
0xfa, 0x37, 0xf8, 0x30, 0xb9, 0xd9, 0x42, 0x21, 0x60, 0x49, 0x92, 0x37, 0xb8, 0x40, 0xa0, 0xee,
0x01, 0x4c, 0x1d, 0x16, 0x9f, 0x93, 0xc8, 0xff, 0x21, 0xa9, 0x12, 0x35, 0xdc, 0x14, 0x92, 0x91,
0xff, 0x03, 0x55, 0x7b, 0xd0, 0xcc, 0x36, 0xcd, 0x27, 0x3a, 0xa2, 0x27, 0x7e, 0x50, 0xf0, 0x64,
0x43, 0x08, 0xb8, 0x0f, 0xd7, 0xa1, 0xce, 0xc9, 0x6b, 0xee, 0xba, 0x2a, 0xbe, 0x41, 0x03, 0x6f,
0x44, 0x5d, 0xf5, 0x77, 0x12, 0xb4, 0x52, 0x9e, 0xfc, 0x3f, 0x30, 0xfa, 0xa7, 0x50, 0x4f, 0x73,
0x36, 0x25, 0xf1, 0xbb, 0x6f, 0x21, 0x71, 0x3c, 0xb7, 0x55, 0xdf, 0x00, 0xd4, 0x53, 0xe1, 0xff,
0xcc, 0x14, 0x08, 0x96, 0x84, 0x2b, 0x13, 0x2f, 0x8b, 0x6f, 0xb4, 0x09, 0x2d, 0x8f, 0x46, 0x2e,
0xf3, 0x93, 0x5b, 0x9d, 0x78, 0xb9, 0x28, 0x42, 0x1f, 0x43, 0x6d, 0xca, 0xfc, 0xb4, 0x12, 0xb7,
0x76, 0xee, 0x94, 0x6d, 0xdb, 0xe2, 0x06, 0x38, 0xb1, 0x43, 0x5f, 0x40, 0x8d, 0xcd, 0xc6, 0x34,
0x4a, 0x89, 0xf6, 0x41, 0xe9, 0x39, 0x93, 0xbb, 0xe8, 0x07, 0x27, 0x98, 0x9b, 0xe2, 0x04, 0x81,
0xbe, 0x80, 0xa5, 0xe3, 0x90, 0x4d, 0x94, 0xba, 0xf0, 0xd0, 0x87, 0x6f, 0xf1, 0x90, 0x11, 0xc4,
0xce, 0x2b, 0xba, 0x17, 0xb2, 0x09, 0x16, 0x10, 0x34, 0x82, 0x5b, 0x53, 0x46, 0xe7, 0x0c, 0x11,
0x9f, 0x4f, 0xa9, 0x60, 0x98, 0xe5, 0x9d, 0xed, 0xb7, 0xcc, 0xd2, 0xb5, 0x32, 0x88, 0x7d, 0x3e,
0xa5, 0x78, 0x79, 0xba, 0x30, 0x46, 0x9f, 0x41, 0x23, 0x76, 0x5e, 0x13, 0xe6, 0xc4, 0x54, 0x69,
0x8a, 0xd3, 0x94, 0x46, 0xcd, 0x76, 0x5e, 0x63, 0x27, 0xa6, 0xb8, 0x1e, 0x27, 0x1f, 0xe5, 0x5c,
0x05, 0xe5, 0x5c, 0xf5, 0x29, 0xd4, 0x3d, 0x3a, 0x0d, 0x23, 0x3f, 0x56, 0x5a, 0x57, 0x2f, 0xd1,
0x4f, 0x4c, 0xf0, 0xdc, 0x16, 0xfd, 0x1a, 0x5a, 0x41, 0x48, 0xa2, 0xd3, 0xf0, 0x7b, 0x72, 0x4c,
0xa9, 0xd2, 0xbe, 0x3a, 0x79, 0x87, 0xe1, 0xe8, 0x34, 0xfc, 0x7e, 0x8f, 0x52, 0xdc, 0x0c, 0xe6,
0x9f, 0xe8, 0x10, 0x56, 0x18, 0xfd, 0xed, 0xcc, 0x67, 0x94, 0xb8, 0x8c, 0x7a, 0x7e, 0x4c, 0x5c,
0x87, 0x79, 0xca, 0x4d, 0xe1, 0xb2, 0x0f, 0xcb, 0x49, 0x59, 0x98, 0x6b, 0xc2, 0x5a, 0x73, 0x98,
0xc7, 0x6b, 0xe4, 0x05, 0x11, 0xfa, 0x1a, 0x5a, 0x8e, 0x68, 0xaf, 0xc8, 0xd8, 0x0f, 0x5e, 0x29,
0xcb, 0x22, 0x8e, 0x1f, 0x94, 0x92, 0xa4, 0x30, 0x1b, 0xf8, 0xc1, 0x2b, 0x0c, 0x4e, 0xf6, 0x8d,
0xbe, 0x84, 0x25, 0x11, 0xbb, 0x5b, 0x62, 0x23, 0x6f, 0x6b, 0x74, 0xe6, 0x7f, 0x45, 0xe0, 0x04,
0x88, 0xaf, 0x1e, 0xfb, 0xee, 0x2b, 0x9a, 0xc6, 0x5f, 0xbe, 0x7a, 0x75, 0x5b, 0x98, 0x09, 0x28,
0xc4, 0xd9, 0x37, 0xd2, 0xe1, 0x26, 0xa3, 0x63, 0x27, 0xa6, 0x1e, 0x99, 0x50, 0xcf, 0x77, 0x94,
0xce, 0xd5, 0x35, 0x1e, 0x27, 0x86, 0x07, 0xdc, 0x0e, 0xb7, 0x59, 0x61, 0x84, 0x4e, 0x61, 0x23,
0xeb, 0xde, 0xe2, 0x98, 0xf9, 0x47, 0xb3, 0x98, 0x92, 0x33, 0x67, 0x3c, 0x13, 0x79, 0x89, 0xc4,
0x9c, 0x0f, 0xdf, 0xd6, 0xc3, 0xcd, 0x41, 0xcf, 0x39, 0xc6, 0xf0, 0xf0, 0x7a, 0x54, 0xae, 0x50,
0xbf, 0x83, 0xe5, 0xc5, 0x2b, 0x8c, 0xee, 0xc3, 0x5d, 0x0b, 0xeb, 0x56, 0xef, 0x25, 0x6f, 0x4f,
0x89, 0xfd, 0xd2, 0xd2, 0xc9, 0xe1, 0x70, 0x64, 0xe9, 0x9a, 0xb1, 0x67, 0xe8, 0x7d, 0xf9, 0x3d,
0xd4, 0x86, 0x06, 0xd6, 0x9f, 0x1d, 0x1a, 0x58, 0xef, 0xcb, 0x12, 0x1f, 0x99, 0x96, 0x6d, 0x98,
0x43, 0xde, 0xc9, 0xa2, 0x0e, 0xdc, 0x1c, 0x9a, 0x36, 0x19, 0x1d, 0x5a, 0x96, 0x89, 0x6d, 0xbd,
0x2f, 0x57, 0xd5, 0xbf, 0xe6, 0x2c, 0x28, 0xe6, 0x7f, 0x1f, 0x94, 0x91, 0x8e, 0x9f, 0x1b, 0x9a,
0x5e, 0x36, 0xf9, 0x03, 0xb8, 0xbf, 0xa0, 0xed, 0x1b, 0x43, 0x63, 0xf8, 0x84, 0x60, 0x9d, 0x4b,
0x7b, 0x7c, 0x1d, 0x59, 0x42, 0x1f, 0xc0, 0xc6, 0x82, 0xd1, 0x9e, 0x69, 0xf6, 0x89, 0x89, 0xfb,
0x3a, 0x36, 0x86, 0x4f, 0xe4, 0x0a, 0xba, 0x07, 0x77, 0x16, 0xf4, 0xfa, 0x73, 0x71, 0x14, 0x43,
0x7b, 0xaa, 0xdb, 0x72, 0x95, 0xb7, 0xe2, 0x0b, 0x6a, 0x1b, 0x1b, 0x16, 0xb1, 0xcd, 0x43, 0x2c,
0x2f, 0xa9, 0x3f, 0x42, 0x4d, 0x70, 0x11, 0x6f, 0x7c, 0x04, 0x1b, 0x91, 0x89, 0xef, 0xb2, 0x30,
0x4a, 0x59, 0xbf, 0x25, 0x64, 0x07, 0x42, 0x84, 0x1e, 0xc0, 0xcd, 0xb4, 0xe4, 0x9e, 0x13, 0x37,
0xf4, 0xe6, 0x95, 0xa9, 0x3d, 0x17, 0x6a, 0xa1, 0x47, 0xd1, 0x47, 0x80, 0x38, 0x86, 0xbf, 0x9c,
0xd2, 0x4c, 0xe6, 0xfd, 0x4d, 0xc2, 0xa0, 0x72, 0xaa, 0x49, 0x52, 0xd9, 0x76, 0x4e, 0xd4, 0x3f,
0x56, 0xe0, 0xd6, 0x05, 0x6a, 0xe3, 0x4d, 0xeb, 0xc4, 0x0f, 0x88, 0xe3, 0x9d, 0x39, 0x81, 0x4b,
0x49, 0x1a, 0xf0, 0x74, 0x43, 0x9d, 0x89, 0x1f, 0xf4, 0x12, 0xcd, 0x6e, 0xa2, 0x40, 0x5f, 0xc3,
0xfb, 0x45, 0xfb, 0x30, 0x18, 0xfb, 0x01, 0x25, 0x2e, 0x1f, 0xf0, 0x49, 0xd3, 0x22, 0x75, 0x27,
0x07, 0x9a, 0xc2, 0x42, 0x9b, 0x1b, 0xa0, 0x67, 0x70, 0x9b, 0xdf, 0xc5, 0x14, 0x32, 0x4e, 0x9a,
0x3f, 0xce, 0x11, 0xd5, 0x6b, 0x08, 0x7c, 0xb7, 0xa2, 0x48, 0x78, 0x85, 0x63, 0xb5, 0x02, 0x94,
0xb3, 0xc5, 0x63, 0x80, 0x20, 0xcc, 0xb8, 0x66, 0xe9, 0x5d, 0xe6, 0x69, 0x26, 0x80, 0x3d, 0x4a,
0xd5, 0x2e, 0xd4, 0x53, 0x86, 0xe4, 0x3e, 0x17, 0x01, 0x21, 0x53, 0xca, 0x5c, 0x1a, 0x24, 0x0f,
0x8b, 0x1a, 0x6e, 0x0b, 0xa1, 0x95, 0xc8, 0xd4, 0xbf, 0x57, 0x60, 0xed, 0x12, 0xcd, 0xef, 0xf9,
0x74, 0xec, 0xa1, 0xfd, 0x94, 0x1e, 0x92, 0x97, 0xeb, 0x27, 0xef, 0x54, 0x20, 0x04, 0xb2, 0x2b,
0x7e, 0x0b, 0x5c, 0xb1, 0x0a, 0xb5, 0xb1, 0x73, 0x44, 0xc7, 0x69, 0xd4, 0x93, 0x01, 0x97, 0x8a,
0x3c, 0x55, 0xaa, 0x82, 0xac, 0x93, 0x01, 0x2f, 0xbc, 0x3e, 0x7f, 0x40, 0x08, 0xb6, 0xf3, 0xc4,
0xf9, 0x1b, 0x18, 0xfc, 0x28, 0xa5, 0x44, 0x4f, 0xfd, 0xbd, 0x04, 0xcd, 0x6c, 0x01, 0x7e, 0x41,
0xf7, 0x0c, 0x7d, 0xd0, 0x2f, 0x4b, 0x10, 0x19, 0xda, 0xa3, 0x7d, 0x13, 0xdb, 0xa4, 0x37, 0x1c,
0xbd, 0xd0, 0xb1, 0x2c, 0xa1, 0x9b, 0xd0, 0xb4, 0x7a, 0xb8, 0xf7, 0x04, 0xf7, 0xac, 0x7d, 0xb9,
0xc2, 0x9f, 0xa5, 0x07, 0x87, 0x03, 0xdb, 0xb0, 0x06, 0x3a, 0xd1, 0xf6, 0x4d, 0x43, 0xd3, 0xe5,
0x2a, 0x5a, 0x06, 0xd0, 0xf6, 0x75, 0xed, 0xe9, 0xae, 0xf9, 0xad, 0x3e, 0x92, 0x97, 0x78, 0xd6,
0xf6, 0xb1, 0x69, 0xf5, 0xf9, 0xa3, 0xb5, 0x86, 0x5a, 0x50, 0xdf, 0x35, 0xcd, 0x81, 0xde, 0x1b,
0xca, 0x37, 0xd4, 0xbf, 0x49, 0xd0, 0xb9, 0xe4, 0x02, 0xf4, 0x0d, 0xd4, 0x8e, 0xf9, 0xfe, 0x14,
0x49, 0x90, 0xcf, 0xf6, 0xbb, 0x3b, 0x0e, 0x27, 0x40, 0xfe, 0x5a, 0x3b, 0xf6, 0x59, 0x94, 0xbc,
0x0e, 0x89, 0x3b, 0x8b, 0xe2, 0x70, 0x42, 0x59, 0x24, 0xdc, 0xd7, 0xc0, 0x48, 0xe8, 0x78, 0xc7,
0xa5, 0xcd, 0x35, 0xe8, 0x63, 0x5e, 0x62, 0xe2, 0x19, 0x0b, 0x78, 0xf2, 0xe4, 0x80, 0x6a, 0x02,
0xc8, 0x54, 0x19, 0x40, 0xfd, 0x87, 0x04, 0xf5, 0xb4, 0xce, 0xa1, 0x47, 0x79, 0x55, 0x94, 0xae,
0xeb, 0x3b, 0xb2, 0x9a, 0x78, 0x21, 0x75, 0x16, 0x12, 0x20, 0xef, 0xef, 0x0a, 0xa9, 0x53, 0xbc,
0xe7, 0xbc, 0x17, 0xfc, 0x06, 0xda, 0xe9, 0x5c, 0x49, 0x05, 0xa9, 0x8a, 0x6b, 0x76, 0xef, 0xca,
0xa5, 0xc5, 0x7d, 0x6a, 0xa5, 0x10, 0x3e, 0x50, 0x19, 0x34, 0xb3, 0x7a, 0x8b, 0x1e, 0x42, 0x95,
0xe7, 0xcb, 0xb5, 0x07, 0xe0, 0x56, 0xe8, 0x73, 0x68, 0x1c, 0x53, 0xfa, 0x5f, 0xac, 0x5b, 0x3f,
0xa6, 0xe2, 0x43, 0xfd, 0x8b, 0x04, 0x90, 0x97, 0x53, 0x24, 0x43, 0x75, 0xc6, 0xc6, 0x69, 0x7b,
0xc8, 0x3f, 0xd1, 0x06, 0x34, 0xc6, 0x4e, 0x70, 0x32, 0x73, 0x4e, 0xe6, 0x24, 0x97, 0x8d, 0xd1,
0x2f, 0xc4, 0x1b, 0x59, 0xbc, 0x70, 0xa9, 0x47, 0xdc, 0x70, 0x16, 0xc4, 0xec, 0x3c, 0xbd, 0xfe,
0x9d, 0x5c, 0xa3, 0x25, 0x0a, 0xf4, 0x15, 0x34, 0xa6, 0x63, 0x27, 0x16, 0x5d, 0xda, 0x92, 0xd8,
0xa5, 0x7a, 0x75, 0x75, 0xb7, 0x52, 0x4b, 0x9c, 0x61, 0xd4, 0x3f, 0x48, 0x00, 0x79, 0xf1, 0x45,
0x3f, 0x85, 0xe5, 0x42, 0xc5, 0xce, 0xbb, 0xda, 0x76, 0x5e, 0x94, 0x0d, 0x0f, 0x3d, 0x84, 0x4e,
0x74, 0x1a, 0xb2, 0x98, 0x14, 0x5b, 0xd5, 0xe4, 0x20, 0xb2, 0x50, 0xf4, 0xcb, 0xfa, 0xd5, 0xea,
0xbb, 0xf5, 0xab, 0xea, 0x9f, 0x25, 0x68, 0x17, 0x8b, 0x79, 0x89, 0x03, 0xbf, 0x4a, 0x69, 0xa7,
0x72, 0x75, 0x47, 0x59, 0x9c, 0xa1, 0x2b, 0x7e, 0x0b, 0x64, 0xa3, 0x40, 0xdd, 0x75, 0x92, 0x6d,
0x27, 0xa5, 0x63, 0x3e, 0x54, 0x3f, 0x82, 0x66, 0x66, 0x8c, 0x56, 0x41, 0x2e, 0xa1, 0x8c, 0x26,
0xd4, 0xac, 0x7d, 0xd3, 0x36, 0x65, 0x49, 0x7d, 0x01, 0xeb, 0x57, 0xb4, 0x08, 0xbc, 0xe0, 0xe5,
0xbd, 0x46, 0xe6, 0xc7, 0x56, 0x26, 0x33, 0x3c, 0xfe, 0x44, 0xcb, 0x9a, 0x90, 0xc4, 0x7b, 0xf5,
0xb3, 0x04, 0xbd, 0xfd, 0x08, 0x9a, 0xd9, 0xc5, 0x42, 0x6b, 0x80, 0xf6, 0x8c, 0x6f, 0xf5, 0x3e,
0xc1, 0x3d, 0x5b, 0x27, 0x7d, 0x7d, 0xaf, 0x77, 0x38, 0xb0, 0xe5, 0xf7, 0x38, 0x0b, 0x59, 0x3a,
0x26, 0x96, 0x8e, 0x47, 0xbc, 0x8e, 0x6f, 0xff, 0x08, 0x9d, 0x4b, 0x4d, 0x21, 0xef, 0x00, 0xd2,
0xf6, 0x82, 0x68, 0x58, 0xef, 0x1b, 0x36, 0xd1, 0x7a, 0xb8, 0x7f, 0xb9, 0x4d, 0x28, 0x33, 0xd2,
0xcc, 0x61, 0xdf, 0x48, 0x9b, 0x11, 0xd1, 0x26, 0x94, 0x19, 0xf5, 0x06, 0x2f, 0x7a, 0x2f, 0x47,
0x72, 0x65, 0xfb, 0x8d, 0x04, 0xcb, 0x8b, 0xf7, 0x8c, 0x37, 0x3f, 0x3d, 0x8d, 0x4f, 0x40, 0xac,
0x41, 0xcf, 0xde, 0x33, 0xf1, 0xc1, 0xe5, 0x85, 0x2f, 0x1a, 0xbc, 0xd0, 0x77, 0x49, 0xcf, 0xb2,
0x06, 0x86, 0x56, 0xe8, 0x4f, 0x2e, 0x1a, 0x1d, 0x98, 0xbb, 0xc6, 0x40, 0xe7, 0xb6, 0x72, 0x05,
0xdd, 0x85, 0xf5, 0x8b, 0xfa, 0xde, 0xb0, 0x8f, 0x4d, 0xa3, 0x2f, 0x57, 0xd1, 0x3a, 0xac, 0x5c,
0x54, 0x1a, 0xe6, 0x48, 0x5e, 0x3a, 0xba, 0x21, 0xfe, 0x65, 0xfb, 0xe8, 0x3f, 0x01, 0x00, 0x00,
0xff, 0xff, 0xcc, 0x96, 0x13, 0xc4, 0xc1, 0x15, 0x00, 0x00,
}