registry/vendor/google.golang.org/api/gan/v1beta1/gan-gen.go

3723 lines
125 KiB
Go
Raw Normal View History

// Package gan provides access to the Google Affiliate Network API.
//
// See https://developers.google.com/affiliate-network/
//
// Usage example:
//
// import "google.golang.org/api/gan/v1beta1"
// ...
// ganService, err := gan.New(oauthHttpClient)
package gan // import "google.golang.org/api/gan/v1beta1"
import (
"bytes"
"encoding/json"
"errors"
"fmt"
"golang.org/x/net/context"
"golang.org/x/net/context/ctxhttp"
"google.golang.org/api/googleapi"
"google.golang.org/api/internal"
"io"
"net/http"
"net/url"
"strconv"
"strings"
)
// Always reference these packages, just in case the auto-generated code
// below doesn't.
var _ = bytes.NewBuffer
var _ = strconv.Itoa
var _ = fmt.Sprintf
var _ = json.NewDecoder
var _ = io.Copy
var _ = url.Parse
var _ = googleapi.Version
var _ = errors.New
var _ = strings.Replace
var _ = internal.MarshalJSON
var _ = context.Canceled
var _ = ctxhttp.Do
const apiId = "gan:v1beta1"
const apiName = "gan"
const apiVersion = "v1beta1"
const basePath = "https://www.googleapis.com/gan/v1beta1/"
func New(client *http.Client) (*Service, error) {
if client == nil {
return nil, errors.New("client is nil")
}
s := &Service{client: client, BasePath: basePath}
s.Advertisers = NewAdvertisersService(s)
s.CcOffers = NewCcOffersService(s)
s.Events = NewEventsService(s)
s.Links = NewLinksService(s)
s.Publishers = NewPublishersService(s)
s.Reports = NewReportsService(s)
return s, nil
}
type Service struct {
client *http.Client
BasePath string // API endpoint base URL
UserAgent string // optional additional User-Agent fragment
Advertisers *AdvertisersService
CcOffers *CcOffersService
Events *EventsService
Links *LinksService
Publishers *PublishersService
Reports *ReportsService
}
func (s *Service) userAgent() string {
if s.UserAgent == "" {
return googleapi.UserAgent
}
return googleapi.UserAgent + " " + s.UserAgent
}
func NewAdvertisersService(s *Service) *AdvertisersService {
rs := &AdvertisersService{s: s}
return rs
}
type AdvertisersService struct {
s *Service
}
func NewCcOffersService(s *Service) *CcOffersService {
rs := &CcOffersService{s: s}
return rs
}
type CcOffersService struct {
s *Service
}
func NewEventsService(s *Service) *EventsService {
rs := &EventsService{s: s}
return rs
}
type EventsService struct {
s *Service
}
func NewLinksService(s *Service) *LinksService {
rs := &LinksService{s: s}
return rs
}
type LinksService struct {
s *Service
}
func NewPublishersService(s *Service) *PublishersService {
rs := &PublishersService{s: s}
return rs
}
type PublishersService struct {
s *Service
}
func NewReportsService(s *Service) *ReportsService {
rs := &ReportsService{s: s}
return rs
}
type ReportsService struct {
s *Service
}
// Advertiser: An AdvertiserResource.
type Advertiser struct {
// AllowPublisherCreatedLinks: True if the advertiser allows publisher
// created links, otherwise false.
AllowPublisherCreatedLinks bool `json:"allowPublisherCreatedLinks,omitempty"`
// Category: Category that this advertiser belongs to. A valid list of
// categories can be found here:
// http://www.google.com/support/affiliatenetwork/advertiser/bin/answer.py?hl=en&answer=107581
Category string `json:"category,omitempty"`
// CommissionDuration: The longest possible length of a commission (how
// long the cookies on the customer's browser last before they expire).
CommissionDuration int64 `json:"commissionDuration,omitempty"`
// ContactEmail: Email that this advertiser would like publishers to
// contact them with.
ContactEmail string `json:"contactEmail,omitempty"`
// ContactPhone: Phone that this advertiser would like publishers to
// contact them with.
ContactPhone string `json:"contactPhone,omitempty"`
// DefaultLinkId: The default link id for this advertiser.
DefaultLinkId int64 `json:"defaultLinkId,omitempty,string"`
// Description: Description of the website the advertiser advertises
// from.
Description string `json:"description,omitempty"`
// EpcNinetyDayAverage: The sum of fees paid to publishers divided by
// the total number of clicks over the past three months. This value
// should be multiplied by 100 at the time of display.
EpcNinetyDayAverage *Money `json:"epcNinetyDayAverage,omitempty"`
// EpcSevenDayAverage: The sum of fees paid to publishers divided by the
// total number of clicks over the past seven days. This value should be
// multiplied by 100 at the time of display.
EpcSevenDayAverage *Money `json:"epcSevenDayAverage,omitempty"`
// Id: The ID of this advertiser.
Id int64 `json:"id,omitempty,string"`
// Item: The requested advertiser.
Item *Advertiser `json:"item,omitempty"`
// JoinDate: Date that this advertiser was approved as a Google
// Affiliate Network advertiser.
JoinDate string `json:"joinDate,omitempty"`
// Kind: The kind for an advertiser.
Kind string `json:"kind,omitempty"`
// LogoUrl: URL to the logo this advertiser uses on the Google Affiliate
// Network.
LogoUrl string `json:"logoUrl,omitempty"`
// MerchantCenterIds: List of merchant center ids for this advertiser
MerchantCenterIds googleapi.Int64s `json:"merchantCenterIds,omitempty"`
// Name: The name of this advertiser.
Name string `json:"name,omitempty"`
// PayoutRank: A rank based on commissions paid to publishers over the
// past 90 days. A number between 1 and 4 where 4 means the top quartile
// (most money paid) and 1 means the bottom quartile (least money paid).
PayoutRank string `json:"payoutRank,omitempty"`
// ProductFeedsEnabled: Allows advertisers to submit product listings to
// Google Product Search.
ProductFeedsEnabled bool `json:"productFeedsEnabled,omitempty"`
// RedirectDomains: List of redirect URLs for this advertiser
RedirectDomains []string `json:"redirectDomains,omitempty"`
// SiteUrl: URL of the website this advertiser advertises from.
SiteUrl string `json:"siteUrl,omitempty"`
// Status: The status of the requesting publisher's relationship this
// advertiser.
Status string `json:"status,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g.
// "AllowPublisherCreatedLinks") to unconditionally include in API
// requests. By default, fields with empty values are omitted from API
// requests. However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Advertiser) MarshalJSON() ([]byte, error) {
type noMethod Advertiser
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type Advertisers struct {
// Items: The advertiser list.
Items []*Advertiser `json:"items,omitempty"`
// Kind: The kind for a page of advertisers.
Kind string `json:"kind,omitempty"`
// NextPageToken: The 'pageToken' to pass to the next request to get the
// next page, if there are more to retrieve.
NextPageToken string `json:"nextPageToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Items") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Advertisers) MarshalJSON() ([]byte, error) {
type noMethod Advertisers
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// CcOffer: A credit card offer. There are many possible result fields.
// We provide two different views of the data, or "projections." The
// "full" projection includes every result field. And the "summary"
// projection, which is the default, includes a smaller subset of the
// fields. The fields included in the summary projection are marked as
// such in their descriptions.
type CcOffer struct {
// AdditionalCardBenefits: More marketing copy about the card's
// benefits. A summary field.
AdditionalCardBenefits []string `json:"additionalCardBenefits,omitempty"`
// AdditionalCardHolderFee: Any extra fees levied on card holders.
AdditionalCardHolderFee string `json:"additionalCardHolderFee,omitempty"`
// AgeMinimum: The youngest a recipient of this card may be.
AgeMinimum float64 `json:"ageMinimum,omitempty"`
// AgeMinimumDetails: Text describing the details of the age minimum
// restriction.
AgeMinimumDetails string `json:"ageMinimumDetails,omitempty"`
// AnnualFee: The ongoing annual fee, in dollars.
AnnualFee float64 `json:"annualFee,omitempty"`
// AnnualFeeDisplay: Text describing the annual fee, including any
// difference for the first year. A summary field.
AnnualFeeDisplay string `json:"annualFeeDisplay,omitempty"`
// AnnualRewardMaximum: The largest number of units you may accumulate
// in a year.
AnnualRewardMaximum float64 `json:"annualRewardMaximum,omitempty"`
// ApprovedCategories: Possible categories for this card, eg "Low
// Interest" or "Good." A summary field.
ApprovedCategories []string `json:"approvedCategories,omitempty"`
// AprDisplay: Text describing the purchase APR. A summary field.
AprDisplay string `json:"aprDisplay,omitempty"`
// BalanceComputationMethod: Text describing how the balance is
// computed. A summary field.
BalanceComputationMethod string `json:"balanceComputationMethod,omitempty"`
// BalanceTransferTerms: Text describing the terms for balance
// transfers. A summary field.
BalanceTransferTerms string `json:"balanceTransferTerms,omitempty"`
// BonusRewards: For cards with rewards programs, extra circumstances
// whereby additional rewards may be granted.
BonusRewards []*CcOfferBonusRewards `json:"bonusRewards,omitempty"`
// CarRentalInsurance: If you get coverage when you use the card for the
// given activity, this field describes it.
CarRentalInsurance string `json:"carRentalInsurance,omitempty"`
// CardBenefits: A list of what the issuer thinks are the most important
// benefits of the card. Usually summarizes the rewards program, if
// there is one. A summary field.
CardBenefits []string `json:"cardBenefits,omitempty"`
// CardName: The issuer's name for the card, including any trademark or
// service mark designators. A summary field.
CardName string `json:"cardName,omitempty"`
// CardType: What kind of credit card this is, for example secured or
// unsecured.
CardType string `json:"cardType,omitempty"`
// CashAdvanceTerms: Text describing the terms for cash advances. A
// summary field.
CashAdvanceTerms string `json:"cashAdvanceTerms,omitempty"`
// CreditLimitMax: The high end for credit limits the issuer imposes on
// recipients of this card.
CreditLimitMax float64 `json:"creditLimitMax,omitempty"`
// CreditLimitMin: The low end for credit limits the issuer imposes on
// recipients of this card.
CreditLimitMin float64 `json:"creditLimitMin,omitempty"`
// CreditRatingDisplay: Text describing the credit ratings required for
// recipients of this card, for example "Excellent/Good." A summary
// field.
CreditRatingDisplay string `json:"creditRatingDisplay,omitempty"`
// DefaultFees: Fees for defaulting on your payments.
DefaultFees []*CcOfferDefaultFees `json:"defaultFees,omitempty"`
// Disclaimer: A notice that, if present, is referenced via an asterisk
// by many of the other summary fields. If this field is present, it
// will always start with an asterisk ("*"), and must be prominently
// displayed with the offer. A summary field.
Disclaimer string `json:"disclaimer,omitempty"`
// EmergencyInsurance: If you get coverage when you use the card for the
// given activity, this field describes it.
EmergencyInsurance string `json:"emergencyInsurance,omitempty"`
// ExistingCustomerOnly: Whether this card is only available to existing
// customers of the issuer.
ExistingCustomerOnly bool `json:"existingCustomerOnly,omitempty"`
// ExtendedWarranty: If you get coverage when you use the card for the
// given activity, this field describes it.
ExtendedWarranty string `json:"extendedWarranty,omitempty"`
// FirstYearAnnualFee: The annual fee for the first year, if different
// from the ongoing fee. Optional.
FirstYearAnnualFee float64 `json:"firstYearAnnualFee,omitempty"`
// FlightAccidentInsurance: If you get coverage when you use the card
// for the given activity, this field describes it.
FlightAccidentInsurance string `json:"flightAccidentInsurance,omitempty"`
// ForeignCurrencyTransactionFee: Fee for each transaction involving a
// foreign currency.
ForeignCurrencyTransactionFee string `json:"foreignCurrencyTransactionFee,omitempty"`
// FraudLiability: If you get coverage when you use the card for the
// given activity, this field describes it.
FraudLiability string `json:"fraudLiability,omitempty"`
// GracePeriodDisplay: Text describing the grace period before finance
// charges apply. A summary field.
GracePeriodDisplay string `json:"gracePeriodDisplay,omitempty"`
// ImageUrl: The link to the image of the card that is shown on Connect
// Commerce. A summary field.
ImageUrl string `json:"imageUrl,omitempty"`
// InitialSetupAndProcessingFee: Fee for setting up the card.
InitialSetupAndProcessingFee string `json:"initialSetupAndProcessingFee,omitempty"`
// IntroBalanceTransferTerms: Text describing the terms for introductory
// period balance transfers. A summary field.
IntroBalanceTransferTerms string `json:"introBalanceTransferTerms,omitempty"`
// IntroCashAdvanceTerms: Text describing the terms for introductory
// period cash advances. A summary field.
IntroCashAdvanceTerms string `json:"introCashAdvanceTerms,omitempty"`
// IntroPurchaseTerms: Text describing the terms for introductory period
// purchases. A summary field.
IntroPurchaseTerms string `json:"introPurchaseTerms,omitempty"`
// Issuer: Name of card issuer. A summary field.
Issuer string `json:"issuer,omitempty"`
// IssuerId: The Google Affiliate Network ID of the advertiser making
// this offer.
IssuerId string `json:"issuerId,omitempty"`
// IssuerWebsite: The generic link to the issuer's site.
IssuerWebsite string `json:"issuerWebsite,omitempty"`
// Kind: The kind for one credit card offer. A summary field.
Kind string `json:"kind,omitempty"`
// LandingPageUrl: The link to the issuer's page for this card. A
// summary field.
LandingPageUrl string `json:"landingPageUrl,omitempty"`
// LatePaymentFee: Text describing how much a late payment will cost, eg
// "up to $35." A summary field.
LatePaymentFee string `json:"latePaymentFee,omitempty"`
// LuggageInsurance: If you get coverage when you use the card for the
// given activity, this field describes it.
LuggageInsurance string `json:"luggageInsurance,omitempty"`
// MaxPurchaseRate: The highest interest rate the issuer charges on this
// card. Expressed as an absolute number, not as a percentage.
MaxPurchaseRate float64 `json:"maxPurchaseRate,omitempty"`
// MinPurchaseRate: The lowest interest rate the issuer charges on this
// card. Expressed as an absolute number, not as a percentage.
MinPurchaseRate float64 `json:"minPurchaseRate,omitempty"`
// MinimumFinanceCharge: Text describing how much missing the grace
// period will cost.
MinimumFinanceCharge string `json:"minimumFinanceCharge,omitempty"`
// Network: Which network (eg Visa) the card belongs to. A summary
// field.
Network string `json:"network,omitempty"`
// OfferId: This offer's ID. A summary field.
OfferId string `json:"offerId,omitempty"`
// OffersImmediateCashReward: Whether a cash reward program lets you get
// cash back sooner than end of year or other longish period.
OffersImmediateCashReward bool `json:"offersImmediateCashReward,omitempty"`
// OverLimitFee: Fee for exceeding the card's charge limit.
OverLimitFee string `json:"overLimitFee,omitempty"`
// ProhibitedCategories: Categories in which the issuer does not wish
// the card to be displayed. A summary field.
ProhibitedCategories []string `json:"prohibitedCategories,omitempty"`
// PurchaseRateAdditionalDetails: Text describing any additional details
// for the purchase rate. A summary field.
PurchaseRateAdditionalDetails string `json:"purchaseRateAdditionalDetails,omitempty"`
// PurchaseRateType: Fixed or variable.
PurchaseRateType string `json:"purchaseRateType,omitempty"`
// ReturnedPaymentFee: Text describing the fee for a payment that
// doesn't clear. A summary field.
ReturnedPaymentFee string `json:"returnedPaymentFee,omitempty"`
// RewardPartner: The company that redeems the rewards, if different
// from the issuer.
RewardPartner string `json:"rewardPartner,omitempty"`
// RewardUnit: For cards with rewards programs, the unit of reward. For
// example, miles, cash back, points.
RewardUnit string `json:"rewardUnit,omitempty"`
// Rewards: For cards with rewards programs, detailed rules about how
// the program works.
Rewards []*CcOfferRewards `json:"rewards,omitempty"`
// RewardsExpire: Whether accumulated rewards ever expire.
RewardsExpire bool `json:"rewardsExpire,omitempty"`
// RewardsHaveBlackoutDates: For airline miles rewards, tells whether
// blackout dates apply to the miles.
RewardsHaveBlackoutDates bool `json:"rewardsHaveBlackoutDates,omitempty"`
// StatementCopyFee: Fee for requesting a copy of your statement.
StatementCopyFee string `json:"statementCopyFee,omitempty"`
// TrackingUrl: The link to ping to register a click on this offer. A
// summary field.
TrackingUrl string `json:"trackingUrl,omitempty"`
// TravelInsurance: If you get coverage when you use the card for the
// given activity, this field describes it.
TravelInsurance string `json:"travelInsurance,omitempty"`
// VariableRatesLastUpdated: When variable rates were last updated.
VariableRatesLastUpdated string `json:"variableRatesLastUpdated,omitempty"`
// VariableRatesUpdateFrequency: How often variable rates are updated.
VariableRatesUpdateFrequency string `json:"variableRatesUpdateFrequency,omitempty"`
// ForceSendFields is a list of field names (e.g.
// "AdditionalCardBenefits") to unconditionally include in API requests.
// By default, fields with empty values are omitted from API requests.
// However, any non-pointer, non-interface field appearing in
// ForceSendFields will be sent to the server regardless of whether the
// field is empty or not. This may be used to include empty fields in
// Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *CcOffer) MarshalJSON() ([]byte, error) {
type noMethod CcOffer
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type CcOfferBonusRewards struct {
// Amount: How many units of reward will be granted.
Amount float64 `json:"amount,omitempty"`
// Details: The circumstances under which this rule applies, for
// example, booking a flight via Orbitz.
Details string `json:"details,omitempty"`
// ForceSendFields is a list of field names (e.g. "Amount") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *CcOfferBonusRewards) MarshalJSON() ([]byte, error) {
type noMethod CcOfferBonusRewards
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type CcOfferDefaultFees struct {
// Category: The type of charge, for example Purchases.
Category string `json:"category,omitempty"`
// MaxRate: The highest rate the issuer may charge for defaulting on
// debt in this category. Expressed as an absolute number, not as a
// percentage.
MaxRate float64 `json:"maxRate,omitempty"`
// MinRate: The lowest rate the issuer may charge for defaulting on debt
// in this category. Expressed as an absolute number, not as a
// percentage.
MinRate float64 `json:"minRate,omitempty"`
// RateType: Fixed or variable.
RateType string `json:"rateType,omitempty"`
// ForceSendFields is a list of field names (e.g. "Category") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *CcOfferDefaultFees) MarshalJSON() ([]byte, error) {
type noMethod CcOfferDefaultFees
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type CcOfferRewards struct {
// AdditionalDetails: Other limits, for example, if this rule only
// applies during an introductory period.
AdditionalDetails string `json:"additionalDetails,omitempty"`
// Amount: The number of units rewarded per purchase dollar.
Amount float64 `json:"amount,omitempty"`
// Category: The kind of purchases covered by this rule.
Category string `json:"category,omitempty"`
// ExpirationMonths: How long rewards granted by this rule last.
ExpirationMonths float64 `json:"expirationMonths,omitempty"`
// MaxRewardTier: The maximum purchase amount in the given category for
// this rule to apply.
MaxRewardTier float64 `json:"maxRewardTier,omitempty"`
// MinRewardTier: The minimum purchase amount in the given category
// before this rule applies.
MinRewardTier float64 `json:"minRewardTier,omitempty"`
// ForceSendFields is a list of field names (e.g. "AdditionalDetails")
// to unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *CcOfferRewards) MarshalJSON() ([]byte, error) {
type noMethod CcOfferRewards
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type CcOffers struct {
// Items: The credit card offers.
Items []*CcOffer `json:"items,omitempty"`
// Kind: The kind for a page of credit card offers.
Kind string `json:"kind,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Items") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *CcOffers) MarshalJSON() ([]byte, error) {
type noMethod CcOffers
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// Event: An EventResource.
type Event struct {
// AdvertiserId: The ID of advertiser for this event.
AdvertiserId int64 `json:"advertiserId,omitempty,string"`
// AdvertiserName: The name of the advertiser for this event.
AdvertiserName string `json:"advertiserName,omitempty"`
// ChargeId: The charge ID for this event. Only returned for charge
// events.
ChargeId string `json:"chargeId,omitempty"`
// ChargeType: Charge type of the event
// (other|slotting_fee|monthly_minimum|tier_bonus|debit|credit). Only
// returned for charge events.
ChargeType string `json:"chargeType,omitempty"`
// CommissionableSales: Amount of money exchanged during the
// transaction. Only returned for charge and conversion events.
CommissionableSales *Money `json:"commissionableSales,omitempty"`
// Earnings: Earnings by the publisher.
Earnings *Money `json:"earnings,omitempty"`
// EventDate: The date-time this event was initiated as a RFC 3339
// date-time value.
EventDate string `json:"eventDate,omitempty"`
// Kind: The kind for one event.
Kind string `json:"kind,omitempty"`
// MemberId: The ID of the member attached to this event. Only returned
// for conversion events.
MemberId string `json:"memberId,omitempty"`
// ModifyDate: The date-time this event was last modified as a RFC 3339
// date-time value.
ModifyDate string `json:"modifyDate,omitempty"`
// NetworkFee: Fee that the advertiser paid to the Google Affiliate
// Network.
NetworkFee *Money `json:"networkFee,omitempty"`
// OrderId: The order ID for this event. Only returned for conversion
// events.
OrderId string `json:"orderId,omitempty"`
// Products: Products associated with the event.
Products []*EventProducts `json:"products,omitempty"`
// PublisherFee: Fee that the advertiser paid to the publisher.
PublisherFee *Money `json:"publisherFee,omitempty"`
// PublisherId: The ID of the publisher for this event.
PublisherId int64 `json:"publisherId,omitempty,string"`
// PublisherName: The name of the publisher for this event.
PublisherName string `json:"publisherName,omitempty"`
// Status: Status of the event (active|canceled). Only returned for
// charge and conversion events.
Status string `json:"status,omitempty"`
// Type: Type of the event (action|transaction|charge).
Type string `json:"type,omitempty"`
// ForceSendFields is a list of field names (e.g. "AdvertiserId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Event) MarshalJSON() ([]byte, error) {
type noMethod Event
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type EventProducts struct {
// CategoryId: Id of the category this product belongs to.
CategoryId string `json:"categoryId,omitempty"`
// CategoryName: Name of the category this product belongs to.
CategoryName string `json:"categoryName,omitempty"`
// Earnings: Amount earned by the publisher on this product.
Earnings *Money `json:"earnings,omitempty"`
// NetworkFee: Fee that the advertiser paid to the Google Affiliate
// Network for this product.
NetworkFee *Money `json:"networkFee,omitempty"`
// PublisherFee: Fee that the advertiser paid to the publisehr for this
// product.
PublisherFee *Money `json:"publisherFee,omitempty"`
// Quantity: Quantity of this product bought/exchanged.
Quantity int64 `json:"quantity,omitempty,string"`
// Sku: Sku of this product.
Sku string `json:"sku,omitempty"`
// SkuName: Sku name of this product.
SkuName string `json:"skuName,omitempty"`
// UnitPrice: Price per unit of this product.
UnitPrice *Money `json:"unitPrice,omitempty"`
// ForceSendFields is a list of field names (e.g. "CategoryId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *EventProducts) MarshalJSON() ([]byte, error) {
type noMethod EventProducts
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type Events struct {
// Items: The event list.
Items []*Event `json:"items,omitempty"`
// Kind: The kind for a page of events.
Kind string `json:"kind,omitempty"`
// NextPageToken: The 'pageToken' to pass to the next request to get the
// next page, if there are more to retrieve.
NextPageToken string `json:"nextPageToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Items") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Events) MarshalJSON() ([]byte, error) {
type noMethod Events
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// Link: A LinkResource.
type Link struct {
// AdvertiserId: The advertiser id for the advertiser who owns this
// link.
AdvertiserId int64 `json:"advertiserId,omitempty,string"`
// Authorship: Authorship
Authorship string `json:"authorship,omitempty"`
// Availability: Availability.
Availability string `json:"availability,omitempty"`
// ClickTrackingUrl: Tracking url for clicks.
ClickTrackingUrl string `json:"clickTrackingUrl,omitempty"`
// CreateDate: Date that this link was created.
CreateDate string `json:"createDate,omitempty"`
// Description: Description.
Description string `json:"description,omitempty"`
// DestinationUrl: The destination URL for the link.
DestinationUrl string `json:"destinationUrl,omitempty"`
// Duration: Duration
Duration string `json:"duration,omitempty"`
// EndDate: Date that this link becomes inactive.
EndDate string `json:"endDate,omitempty"`
// EpcNinetyDayAverage: The sum of fees paid to publishers divided by
// the total number of clicks over the past three months on this link.
// This value should be multiplied by 100 at the time of display.
EpcNinetyDayAverage *Money `json:"epcNinetyDayAverage,omitempty"`
// EpcSevenDayAverage: The sum of fees paid to publishers divided by the
// total number of clicks over the past seven days on this link. This
// value should be multiplied by 100 at the time of display.
EpcSevenDayAverage *Money `json:"epcSevenDayAverage,omitempty"`
// Id: The ID of this link.
Id int64 `json:"id,omitempty,string"`
// ImageAltText: image alt text.
ImageAltText string `json:"imageAltText,omitempty"`
// ImpressionTrackingUrl: Tracking url for impressions.
ImpressionTrackingUrl string `json:"impressionTrackingUrl,omitempty"`
// IsActive: Flag for if this link is active.
IsActive bool `json:"isActive,omitempty"`
// Kind: The kind for one entity.
Kind string `json:"kind,omitempty"`
// LinkType: The link type.
LinkType string `json:"linkType,omitempty"`
// Name: The logical name for this link.
Name string `json:"name,omitempty"`
// PromotionType: Promotion Type
PromotionType string `json:"promotionType,omitempty"`
// SpecialOffers: Special offers on the link.
SpecialOffers *LinkSpecialOffers `json:"specialOffers,omitempty"`
// StartDate: Date that this link becomes active.
StartDate string `json:"startDate,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "AdvertiserId") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Link) MarshalJSON() ([]byte, error) {
type noMethod Link
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// LinkSpecialOffers: Special offers on the link.
type LinkSpecialOffers struct {
// FreeGift: Whether there is a free gift
FreeGift bool `json:"freeGift,omitempty"`
// FreeShipping: Whether there is free shipping
FreeShipping bool `json:"freeShipping,omitempty"`
// FreeShippingMin: Minimum purchase amount for free shipping promotion
FreeShippingMin *Money `json:"freeShippingMin,omitempty"`
// PercentOff: Percent off on the purchase
PercentOff float64 `json:"percentOff,omitempty"`
// PercentOffMin: Minimum purchase amount for percent off promotion
PercentOffMin *Money `json:"percentOffMin,omitempty"`
// PriceCut: Price cut on the purchase
PriceCut *Money `json:"priceCut,omitempty"`
// PriceCutMin: Minimum purchase amount for price cut promotion
PriceCutMin *Money `json:"priceCutMin,omitempty"`
// PromotionCodes: List of promotion code associated with the link
PromotionCodes []string `json:"promotionCodes,omitempty"`
// ForceSendFields is a list of field names (e.g. "FreeGift") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *LinkSpecialOffers) MarshalJSON() ([]byte, error) {
type noMethod LinkSpecialOffers
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type Links struct {
// Items: The links.
Items []*Link `json:"items,omitempty"`
// Kind: The kind for a page of links.
Kind string `json:"kind,omitempty"`
// NextPageToken: The next page token.
NextPageToken string `json:"nextPageToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Items") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Links) MarshalJSON() ([]byte, error) {
type noMethod Links
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// Money: An ApiMoneyProto.
type Money struct {
// Amount: The amount of money.
Amount float64 `json:"amount,omitempty"`
// CurrencyCode: The 3-letter code of the currency in question.
CurrencyCode string `json:"currencyCode,omitempty"`
// ForceSendFields is a list of field names (e.g. "Amount") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Money) MarshalJSON() ([]byte, error) {
type noMethod Money
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// Publisher: A PublisherResource.
type Publisher struct {
// Classification: Classification that this publisher belongs to. See
// this link for all publisher classifications:
// http://www.google.com/support/affiliatenetwork/advertiser/bin/answer.py?hl=en&answer=107625&ctx=cb&src=cb&cbid=-k5fihzthfaik&cbrank=4
Classification string `json:"classification,omitempty"`
// EpcNinetyDayAverage: The sum of fees paid to this publisher divided
// by the total number of clicks over the past three months. Values are
// multiplied by 100 for display purposes.
EpcNinetyDayAverage *Money `json:"epcNinetyDayAverage,omitempty"`
// EpcSevenDayAverage: The sum of fees paid to this publisher divided by
// the total number of clicks over the past seven days. Values are
// multiplied by 100 for display purposes.
EpcSevenDayAverage *Money `json:"epcSevenDayAverage,omitempty"`
// Id: The ID of this publisher.
Id int64 `json:"id,omitempty,string"`
// Item: The requested publisher.
Item *Publisher `json:"item,omitempty"`
// JoinDate: Date that this publisher was approved as a Google Affiliate
// Network publisher.
JoinDate string `json:"joinDate,omitempty"`
// Kind: The kind for a publisher.
Kind string `json:"kind,omitempty"`
// Name: The name of this publisher.
Name string `json:"name,omitempty"`
// PayoutRank: A rank based on commissions paid to this publisher over
// the past 90 days. A number between 1 and 4 where 4 means the top
// quartile (most money paid) and 1 means the bottom quartile (least
// money paid).
PayoutRank string `json:"payoutRank,omitempty"`
// Sites: Websites that this publisher uses to advertise.
Sites []string `json:"sites,omitempty"`
// Status: The status of the requesting advertiser's relationship with
// this publisher.
Status string `json:"status,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Classification") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Publisher) MarshalJSON() ([]byte, error) {
type noMethod Publisher
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
type Publishers struct {
// Items: The entity list.
Items []*Publisher `json:"items,omitempty"`
// Kind: The kind for a page of entities.
Kind string `json:"kind,omitempty"`
// NextPageToken: The 'pageToken' to pass to the next request to get the
// next page, if there are more to retrieve.
NextPageToken string `json:"nextPageToken,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "Items") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Publishers) MarshalJSON() ([]byte, error) {
type noMethod Publishers
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// Report: A ReportResource representing a report of a certain type
// either for an advertiser or publisher.
type Report struct {
// ColumnNames: The column names for the report
ColumnNames []string `json:"column_names,omitempty"`
// EndDate: The end of the date range for this report, exclusive.
EndDate string `json:"end_date,omitempty"`
// Kind: The kind for a report.
Kind string `json:"kind,omitempty"`
// MatchingRowCount: The number of matching rows before paging is
// applied.
MatchingRowCount int64 `json:"matching_row_count,omitempty,string"`
// Rows: The rows of data for the report
Rows [][]interface{} `json:"rows,omitempty"`
// StartDate: The start of the date range for this report, inclusive.
StartDate string `json:"start_date,omitempty"`
// TotalsRows: The totals rows for the report
TotalsRows [][]interface{} `json:"totals_rows,omitempty"`
// Type: The report type.
Type string `json:"type,omitempty"`
// ServerResponse contains the HTTP response code and headers from the
// server.
googleapi.ServerResponse `json:"-"`
// ForceSendFields is a list of field names (e.g. "ColumnNames") to
// unconditionally include in API requests. By default, fields with
// empty values are omitted from API requests. However, any non-pointer,
// non-interface field appearing in ForceSendFields will be sent to the
// server regardless of whether the field is empty or not. This may be
// used to include empty fields in Patch requests.
ForceSendFields []string `json:"-"`
}
func (s *Report) MarshalJSON() ([]byte, error) {
type noMethod Report
raw := noMethod(*s)
return internal.MarshalJSON(raw, s.ForceSendFields)
}
// method id "gan.advertisers.get":
type AdvertisersGetCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// Get: Retrieves data about a single advertiser if that the requesting
// advertiser/publisher has access to it. Only publishers can lookup
// advertisers. Advertisers can request information about themselves by
// omitting the advertiserId query parameter.
func (r *AdvertisersService) Get(role string, roleId string) *AdvertisersGetCall {
c := &AdvertisersGetCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// AdvertiserId sets the optional parameter "advertiserId": The ID of
// the advertiser to look up.
func (c *AdvertisersGetCall) AdvertiserId(advertiserId string) *AdvertisersGetCall {
c.opt_["advertiserId"] = advertiserId
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AdvertisersGetCall) Fields(s ...googleapi.Field) *AdvertisersGetCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *AdvertisersGetCall) IfNoneMatch(entityTag string) *AdvertisersGetCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *AdvertisersGetCall) Context(ctx context.Context) *AdvertisersGetCall {
c.ctx_ = ctx
return c
}
func (c *AdvertisersGetCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiserId"]; ok {
params.Set("advertiserId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/advertiser")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.advertisers.get" call.
// Exactly one of *Advertiser or error will be non-nil. Any non-2xx
// status code is an error. Response headers are in either
// *Advertiser.ServerResponse.Header or (if a response was returned at
// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
// to check whether the returned error was because
// http.StatusNotModified was returned.
func (c *AdvertisersGetCall) Do() (*Advertiser, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Advertiser{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves data about a single advertiser if that the requesting advertiser/publisher has access to it. Only publishers can lookup advertisers. Advertisers can request information about themselves by omitting the advertiserId query parameter.",
// "httpMethod": "GET",
// "id": "gan.advertisers.get",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "advertiserId": {
// "description": "The ID of the advertiser to look up. Optional.",
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/advertiser",
// "response": {
// "$ref": "Advertiser"
// }
// }
}
// method id "gan.advertisers.list":
type AdvertisersListCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// List: Retrieves data about all advertisers that the requesting
// advertiser/publisher has access to.
func (r *AdvertisersService) List(role string, roleId string) *AdvertisersListCall {
c := &AdvertisersListCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// AdvertiserCategory sets the optional parameter "advertiserCategory":
// Caret(^) delimted list of advertiser categories. Valid categories are
// defined here:
// http://www.google.com/support/affiliatenetwork/advertiser/bin/answer.py?hl=en&answer=107581. Filters out all advertisers not in one of the given advertiser
// categories.
func (c *AdvertisersListCall) AdvertiserCategory(advertiserCategory string) *AdvertisersListCall {
c.opt_["advertiserCategory"] = advertiserCategory
return c
}
// MaxResults sets the optional parameter "maxResults": Max number of
// items to return in this page. Defaults to 20.
func (c *AdvertisersListCall) MaxResults(maxResults int64) *AdvertisersListCall {
c.opt_["maxResults"] = maxResults
return c
}
// MinNinetyDayEpc sets the optional parameter "minNinetyDayEpc":
// Filters out all advertisers that have a ninety day EPC average lower
// than the given value (inclusive). Min value: 0.0.
func (c *AdvertisersListCall) MinNinetyDayEpc(minNinetyDayEpc float64) *AdvertisersListCall {
c.opt_["minNinetyDayEpc"] = minNinetyDayEpc
return c
}
// MinPayoutRank sets the optional parameter "minPayoutRank": A value
// between 1 and 4, where 1 represents the quartile of advertisers with
// the lowest ranks and 4 represents the quartile of advertisers with
// the highest ranks. Filters out all advertisers with a lower rank than
// the given quartile. For example if a 2 was given only advertisers
// with a payout rank of 25 or higher would be included.
func (c *AdvertisersListCall) MinPayoutRank(minPayoutRank int64) *AdvertisersListCall {
c.opt_["minPayoutRank"] = minPayoutRank
return c
}
// MinSevenDayEpc sets the optional parameter "minSevenDayEpc": Filters
// out all advertisers that have a seven day EPC average lower than the
// given value (inclusive). Min value: 0.0.
func (c *AdvertisersListCall) MinSevenDayEpc(minSevenDayEpc float64) *AdvertisersListCall {
c.opt_["minSevenDayEpc"] = minSevenDayEpc
return c
}
// PageToken sets the optional parameter "pageToken": The value of
// 'nextPageToken' from the previous page.
func (c *AdvertisersListCall) PageToken(pageToken string) *AdvertisersListCall {
c.opt_["pageToken"] = pageToken
return c
}
// RelationshipStatus sets the optional parameter "relationshipStatus":
// Filters out all advertisers for which do not have the given
// relationship status with the requesting publisher.
//
// Possible values:
// "approved" - An advertiser that has approved your application.
// "available" - An advertiser program that's accepting new
// publishers.
// "deactivated" - Deactivated means either the advertiser has removed
// you from their program, or it could also mean that you chose to
// remove yourself from the advertiser's program.
// "declined" - An advertiser that did not approve your application.
// "pending" - An advertiser program that you've already applied to,
// but they haven't yet decided to approve or decline your application.
func (c *AdvertisersListCall) RelationshipStatus(relationshipStatus string) *AdvertisersListCall {
c.opt_["relationshipStatus"] = relationshipStatus
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *AdvertisersListCall) Fields(s ...googleapi.Field) *AdvertisersListCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *AdvertisersListCall) IfNoneMatch(entityTag string) *AdvertisersListCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *AdvertisersListCall) Context(ctx context.Context) *AdvertisersListCall {
c.ctx_ = ctx
return c
}
func (c *AdvertisersListCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiserCategory"]; ok {
params.Set("advertiserCategory", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["maxResults"]; ok {
params.Set("maxResults", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minNinetyDayEpc"]; ok {
params.Set("minNinetyDayEpc", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minPayoutRank"]; ok {
params.Set("minPayoutRank", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minSevenDayEpc"]; ok {
params.Set("minSevenDayEpc", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["pageToken"]; ok {
params.Set("pageToken", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["relationshipStatus"]; ok {
params.Set("relationshipStatus", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/advertisers")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.advertisers.list" call.
// Exactly one of *Advertisers or error will be non-nil. Any non-2xx
// status code is an error. Response headers are in either
// *Advertisers.ServerResponse.Header or (if a response was returned at
// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
// to check whether the returned error was because
// http.StatusNotModified was returned.
func (c *AdvertisersListCall) Do() (*Advertisers, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Advertisers{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves data about all advertisers that the requesting advertiser/publisher has access to.",
// "httpMethod": "GET",
// "id": "gan.advertisers.list",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "advertiserCategory": {
// "description": "Caret(^) delimted list of advertiser categories. Valid categories are defined here: http://www.google.com/support/affiliatenetwork/advertiser/bin/answer.py?hl=en\u0026answer=107581. Filters out all advertisers not in one of the given advertiser categories. Optional.",
// "location": "query",
// "type": "string"
// },
// "maxResults": {
// "description": "Max number of items to return in this page. Optional. Defaults to 20.",
// "format": "uint32",
// "location": "query",
// "maximum": "100",
// "minimum": "0",
// "type": "integer"
// },
// "minNinetyDayEpc": {
// "description": "Filters out all advertisers that have a ninety day EPC average lower than the given value (inclusive). Min value: 0.0. Optional.",
// "format": "double",
// "location": "query",
// "type": "number"
// },
// "minPayoutRank": {
// "description": "A value between 1 and 4, where 1 represents the quartile of advertisers with the lowest ranks and 4 represents the quartile of advertisers with the highest ranks. Filters out all advertisers with a lower rank than the given quartile. For example if a 2 was given only advertisers with a payout rank of 25 or higher would be included. Optional.",
// "format": "int32",
// "location": "query",
// "maximum": "4",
// "minimum": "1",
// "type": "integer"
// },
// "minSevenDayEpc": {
// "description": "Filters out all advertisers that have a seven day EPC average lower than the given value (inclusive). Min value: 0.0. Optional.",
// "format": "double",
// "location": "query",
// "type": "number"
// },
// "pageToken": {
// "description": "The value of 'nextPageToken' from the previous page. Optional.",
// "location": "query",
// "type": "string"
// },
// "relationshipStatus": {
// "description": "Filters out all advertisers for which do not have the given relationship status with the requesting publisher.",
// "enum": [
// "approved",
// "available",
// "deactivated",
// "declined",
// "pending"
// ],
// "enumDescriptions": [
// "An advertiser that has approved your application.",
// "An advertiser program that's accepting new publishers.",
// "Deactivated means either the advertiser has removed you from their program, or it could also mean that you chose to remove yourself from the advertiser's program.",
// "An advertiser that did not approve your application.",
// "An advertiser program that you've already applied to, but they haven't yet decided to approve or decline your application."
// ],
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/advertisers",
// "response": {
// "$ref": "Advertisers"
// }
// }
}
// method id "gan.ccOffers.list":
type CcOffersListCall struct {
s *Service
publisher string
opt_ map[string]interface{}
ctx_ context.Context
}
// List: Retrieves credit card offers for the given publisher.
func (r *CcOffersService) List(publisher string) *CcOffersListCall {
c := &CcOffersListCall{s: r.s, opt_: make(map[string]interface{})}
c.publisher = publisher
return c
}
// Advertiser sets the optional parameter "advertiser": The advertiser
// ID of a card issuer whose offers to include. Optional, may be
// repeated.
func (c *CcOffersListCall) Advertiser(advertiser string) *CcOffersListCall {
c.opt_["advertiser"] = advertiser
return c
}
// Projection sets the optional parameter "projection": The set of
// fields to return.
//
// Possible values:
// "full" - Include all offer fields. This is the default.
// "summary" - Include only the basic fields needed to display an
// offer.
func (c *CcOffersListCall) Projection(projection string) *CcOffersListCall {
c.opt_["projection"] = projection
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *CcOffersListCall) Fields(s ...googleapi.Field) *CcOffersListCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *CcOffersListCall) IfNoneMatch(entityTag string) *CcOffersListCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *CcOffersListCall) Context(ctx context.Context) *CcOffersListCall {
c.ctx_ = ctx
return c
}
func (c *CcOffersListCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiser"]; ok {
params.Set("advertiser", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["projection"]; ok {
params.Set("projection", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "publishers/{publisher}/ccOffers")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"publisher": c.publisher,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.ccOffers.list" call.
// Exactly one of *CcOffers or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *CcOffers.ServerResponse.Header or (if a response was returned at
// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
// to check whether the returned error was because
// http.StatusNotModified was returned.
func (c *CcOffersListCall) Do() (*CcOffers, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &CcOffers{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves credit card offers for the given publisher.",
// "httpMethod": "GET",
// "id": "gan.ccOffers.list",
// "parameterOrder": [
// "publisher"
// ],
// "parameters": {
// "advertiser": {
// "description": "The advertiser ID of a card issuer whose offers to include. Optional, may be repeated.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "projection": {
// "description": "The set of fields to return.",
// "enum": [
// "full",
// "summary"
// ],
// "enumDescriptions": [
// "Include all offer fields. This is the default.",
// "Include only the basic fields needed to display an offer."
// ],
// "location": "query",
// "type": "string"
// },
// "publisher": {
// "description": "The ID of the publisher in question.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "publishers/{publisher}/ccOffers",
// "response": {
// "$ref": "CcOffers"
// }
// }
}
// method id "gan.events.list":
type EventsListCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// List: Retrieves event data for a given advertiser/publisher.
func (r *EventsService) List(role string, roleId string) *EventsListCall {
c := &EventsListCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// AdvertiserId sets the optional parameter "advertiserId": Caret(^)
// delimited list of advertiser IDs. Filters out all events that do not
// reference one of the given advertiser IDs. Only used when under
// publishers role.
func (c *EventsListCall) AdvertiserId(advertiserId string) *EventsListCall {
c.opt_["advertiserId"] = advertiserId
return c
}
// ChargeType sets the optional parameter "chargeType": Filters out all
// charge events that are not of the given charge type. Valid values:
// 'other', 'slotting_fee', 'monthly_minimum', 'tier_bonus', 'credit',
// 'debit'.
//
// Possible values:
// "credit" - A credit increases the publisher's payout amount and
// decreases the advertiser's invoice amount.
// "debit" - A debit reduces the publisher's payout and increases the
// advertiser's invoice amount.
// "monthly_minimum" - A payment made to Google by an advertiser as a
// minimum monthly network fee.
// "other" - Catch all. Default if unset
// "slotting_fee" - A one time payment made from an advertiser to a
// publisher.
// "tier_bonus" - A payment from an advertiser to a publisher for the
// publisher maintaining a high tier level
func (c *EventsListCall) ChargeType(chargeType string) *EventsListCall {
c.opt_["chargeType"] = chargeType
return c
}
// EventDateMax sets the optional parameter "eventDateMax": Filters out
// all events later than given date. Defaults to 24 hours after
// eventMin.
func (c *EventsListCall) EventDateMax(eventDateMax string) *EventsListCall {
c.opt_["eventDateMax"] = eventDateMax
return c
}
// EventDateMin sets the optional parameter "eventDateMin": Filters out
// all events earlier than given date. Defaults to 24 hours from
// current date/time.
func (c *EventsListCall) EventDateMin(eventDateMin string) *EventsListCall {
c.opt_["eventDateMin"] = eventDateMin
return c
}
// LinkId sets the optional parameter "linkId": Caret(^) delimited list
// of link IDs. Filters out all events that do not reference one of the
// given link IDs.
func (c *EventsListCall) LinkId(linkId string) *EventsListCall {
c.opt_["linkId"] = linkId
return c
}
// MaxResults sets the optional parameter "maxResults": Max number of
// offers to return in this page. Defaults to 20.
func (c *EventsListCall) MaxResults(maxResults int64) *EventsListCall {
c.opt_["maxResults"] = maxResults
return c
}
// MemberId sets the optional parameter "memberId": Caret(^) delimited
// list of member IDs. Filters out all events that do not reference one
// of the given member IDs.
func (c *EventsListCall) MemberId(memberId string) *EventsListCall {
c.opt_["memberId"] = memberId
return c
}
// ModifyDateMax sets the optional parameter "modifyDateMax": Filters
// out all events modified later than given date. Defaults to 24 hours
// after modifyDateMin, if modifyDateMin is explicitly set.
func (c *EventsListCall) ModifyDateMax(modifyDateMax string) *EventsListCall {
c.opt_["modifyDateMax"] = modifyDateMax
return c
}
// ModifyDateMin sets the optional parameter "modifyDateMin": Filters
// out all events modified earlier than given date. Defaults to 24
// hours before the current modifyDateMax, if modifyDateMax is
// explicitly set.
func (c *EventsListCall) ModifyDateMin(modifyDateMin string) *EventsListCall {
c.opt_["modifyDateMin"] = modifyDateMin
return c
}
// OrderId sets the optional parameter "orderId": Caret(^) delimited
// list of order IDs. Filters out all events that do not reference one
// of the given order IDs.
func (c *EventsListCall) OrderId(orderId string) *EventsListCall {
c.opt_["orderId"] = orderId
return c
}
// PageToken sets the optional parameter "pageToken": The value of
// 'nextPageToken' from the previous page.
func (c *EventsListCall) PageToken(pageToken string) *EventsListCall {
c.opt_["pageToken"] = pageToken
return c
}
// ProductCategory sets the optional parameter "productCategory":
// Caret(^) delimited list of product categories. Filters out all events
// that do not reference a product in one of the given product
// categories.
func (c *EventsListCall) ProductCategory(productCategory string) *EventsListCall {
c.opt_["productCategory"] = productCategory
return c
}
// PublisherId sets the optional parameter "publisherId": Caret(^)
// delimited list of publisher IDs. Filters out all events that do not
// reference one of the given publishers IDs. Only used when under
// advertiser role.
func (c *EventsListCall) PublisherId(publisherId string) *EventsListCall {
c.opt_["publisherId"] = publisherId
return c
}
// Sku sets the optional parameter "sku": Caret(^) delimited list of
// SKUs. Filters out all events that do not reference one of the given
// SKU.
func (c *EventsListCall) Sku(sku string) *EventsListCall {
c.opt_["sku"] = sku
return c
}
// Status sets the optional parameter "status": Filters out all events
// that do not have the given status. Valid values: 'active',
// 'canceled'.
//
// Possible values:
// "active" - Event is currently active.
// "canceled" - Event is currently canceled.
func (c *EventsListCall) Status(status string) *EventsListCall {
c.opt_["status"] = status
return c
}
// Type sets the optional parameter "type": Filters out all events that
// are not of the given type. Valid values: 'action', 'transaction',
// 'charge'.
//
// Possible values:
// "action" - The completion of an application, sign-up, or other
// process. For example, an action occurs if a user clicks an ad for a
// credit card and completes an application for that card.
// "charge" - A charge event is typically a payment between an
// advertiser, publisher or Google.
// "transaction" - A conversion event, typically an e-commerce
// transaction. Some advertisers use a transaction to record other types
// of events, such as magazine subscriptions.
func (c *EventsListCall) Type(type_ string) *EventsListCall {
c.opt_["type"] = type_
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *EventsListCall) Fields(s ...googleapi.Field) *EventsListCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *EventsListCall) IfNoneMatch(entityTag string) *EventsListCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *EventsListCall) Context(ctx context.Context) *EventsListCall {
c.ctx_ = ctx
return c
}
func (c *EventsListCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiserId"]; ok {
params.Set("advertiserId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["chargeType"]; ok {
params.Set("chargeType", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["eventDateMax"]; ok {
params.Set("eventDateMax", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["eventDateMin"]; ok {
params.Set("eventDateMin", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["linkId"]; ok {
params.Set("linkId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["maxResults"]; ok {
params.Set("maxResults", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["memberId"]; ok {
params.Set("memberId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["modifyDateMax"]; ok {
params.Set("modifyDateMax", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["modifyDateMin"]; ok {
params.Set("modifyDateMin", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["orderId"]; ok {
params.Set("orderId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["pageToken"]; ok {
params.Set("pageToken", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["productCategory"]; ok {
params.Set("productCategory", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["publisherId"]; ok {
params.Set("publisherId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["sku"]; ok {
params.Set("sku", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["status"]; ok {
params.Set("status", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["type"]; ok {
params.Set("type", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/events")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.events.list" call.
// Exactly one of *Events or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Events.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *EventsListCall) Do() (*Events, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Events{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves event data for a given advertiser/publisher.",
// "httpMethod": "GET",
// "id": "gan.events.list",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "advertiserId": {
// "description": "Caret(^) delimited list of advertiser IDs. Filters out all events that do not reference one of the given advertiser IDs. Only used when under publishers role. Optional.",
// "location": "query",
// "type": "string"
// },
// "chargeType": {
// "description": "Filters out all charge events that are not of the given charge type. Valid values: 'other', 'slotting_fee', 'monthly_minimum', 'tier_bonus', 'credit', 'debit'. Optional.",
// "enum": [
// "credit",
// "debit",
// "monthly_minimum",
// "other",
// "slotting_fee",
// "tier_bonus"
// ],
// "enumDescriptions": [
// "A credit increases the publisher's payout amount and decreases the advertiser's invoice amount.",
// "A debit reduces the publisher's payout and increases the advertiser's invoice amount.",
// "A payment made to Google by an advertiser as a minimum monthly network fee.",
// "Catch all. Default if unset",
// "A one time payment made from an advertiser to a publisher.",
// "A payment from an advertiser to a publisher for the publisher maintaining a high tier level"
// ],
// "location": "query",
// "type": "string"
// },
// "eventDateMax": {
// "description": "Filters out all events later than given date. Optional. Defaults to 24 hours after eventMin.",
// "location": "query",
// "type": "string"
// },
// "eventDateMin": {
// "description": "Filters out all events earlier than given date. Optional. Defaults to 24 hours from current date/time.",
// "location": "query",
// "type": "string"
// },
// "linkId": {
// "description": "Caret(^) delimited list of link IDs. Filters out all events that do not reference one of the given link IDs. Optional.",
// "location": "query",
// "type": "string"
// },
// "maxResults": {
// "description": "Max number of offers to return in this page. Optional. Defaults to 20.",
// "format": "uint32",
// "location": "query",
// "maximum": "100",
// "minimum": "0",
// "type": "integer"
// },
// "memberId": {
// "description": "Caret(^) delimited list of member IDs. Filters out all events that do not reference one of the given member IDs. Optional.",
// "location": "query",
// "type": "string"
// },
// "modifyDateMax": {
// "description": "Filters out all events modified later than given date. Optional. Defaults to 24 hours after modifyDateMin, if modifyDateMin is explicitly set.",
// "location": "query",
// "type": "string"
// },
// "modifyDateMin": {
// "description": "Filters out all events modified earlier than given date. Optional. Defaults to 24 hours before the current modifyDateMax, if modifyDateMax is explicitly set.",
// "location": "query",
// "type": "string"
// },
// "orderId": {
// "description": "Caret(^) delimited list of order IDs. Filters out all events that do not reference one of the given order IDs. Optional.",
// "location": "query",
// "type": "string"
// },
// "pageToken": {
// "description": "The value of 'nextPageToken' from the previous page. Optional.",
// "location": "query",
// "type": "string"
// },
// "productCategory": {
// "description": "Caret(^) delimited list of product categories. Filters out all events that do not reference a product in one of the given product categories. Optional.",
// "location": "query",
// "type": "string"
// },
// "publisherId": {
// "description": "Caret(^) delimited list of publisher IDs. Filters out all events that do not reference one of the given publishers IDs. Only used when under advertiser role. Optional.",
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "sku": {
// "description": "Caret(^) delimited list of SKUs. Filters out all events that do not reference one of the given SKU. Optional.",
// "location": "query",
// "type": "string"
// },
// "status": {
// "description": "Filters out all events that do not have the given status. Valid values: 'active', 'canceled'. Optional.",
// "enum": [
// "active",
// "canceled"
// ],
// "enumDescriptions": [
// "Event is currently active.",
// "Event is currently canceled."
// ],
// "location": "query",
// "type": "string"
// },
// "type": {
// "description": "Filters out all events that are not of the given type. Valid values: 'action', 'transaction', 'charge'. Optional.",
// "enum": [
// "action",
// "charge",
// "transaction"
// ],
// "enumDescriptions": [
// "The completion of an application, sign-up, or other process. For example, an action occurs if a user clicks an ad for a credit card and completes an application for that card.",
// "A charge event is typically a payment between an advertiser, publisher or Google.",
// "A conversion event, typically an e-commerce transaction. Some advertisers use a transaction to record other types of events, such as magazine subscriptions."
// ],
// "location": "query",
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/events",
// "response": {
// "$ref": "Events"
// }
// }
}
// method id "gan.links.get":
type LinksGetCall struct {
s *Service
role string
roleId string
linkId int64
opt_ map[string]interface{}
ctx_ context.Context
}
// Get: Retrieves data about a single link if the requesting
// advertiser/publisher has access to it. Advertisers can look up their
// own links. Publishers can look up visible links or links belonging to
// advertisers they are in a relationship with.
func (r *LinksService) Get(role string, roleId string, linkId int64) *LinksGetCall {
c := &LinksGetCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
c.linkId = linkId
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *LinksGetCall) Fields(s ...googleapi.Field) *LinksGetCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *LinksGetCall) IfNoneMatch(entityTag string) *LinksGetCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *LinksGetCall) Context(ctx context.Context) *LinksGetCall {
c.ctx_ = ctx
return c
}
func (c *LinksGetCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/link/{linkId}")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
"linkId": strconv.FormatInt(c.linkId, 10),
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.links.get" call.
// Exactly one of *Link or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Link.ServerResponse.Header or (if a response was returned at all) in
// error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check
// whether the returned error was because http.StatusNotModified was
// returned.
func (c *LinksGetCall) Do() (*Link, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Link{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves data about a single link if the requesting advertiser/publisher has access to it. Advertisers can look up their own links. Publishers can look up visible links or links belonging to advertisers they are in a relationship with.",
// "httpMethod": "GET",
// "id": "gan.links.get",
// "parameterOrder": [
// "role",
// "roleId",
// "linkId"
// ],
// "parameters": {
// "linkId": {
// "description": "The ID of the link to look up.",
// "format": "int64",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/link/{linkId}",
// "response": {
// "$ref": "Link"
// }
// }
}
// method id "gan.links.insert":
type LinksInsertCall struct {
s *Service
role string
roleId string
link *Link
opt_ map[string]interface{}
ctx_ context.Context
}
// Insert: Inserts a new link.
func (r *LinksService) Insert(role string, roleId string, link *Link) *LinksInsertCall {
c := &LinksInsertCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
c.link = link
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *LinksInsertCall) Fields(s ...googleapi.Field) *LinksInsertCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *LinksInsertCall) Context(ctx context.Context) *LinksInsertCall {
c.ctx_ = ctx
return c
}
func (c *LinksInsertCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
body, err := googleapi.WithoutDataWrapper.JSONReader(c.link)
if err != nil {
return nil, err
}
ctype := "application/json"
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/link")
urls += "?" + params.Encode()
req, _ := http.NewRequest("POST", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("Content-Type", ctype)
req.Header.Set("User-Agent", c.s.userAgent())
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.links.insert" call.
// Exactly one of *Link or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Link.ServerResponse.Header or (if a response was returned at all) in
// error.(*googleapi.Error).Header. Use googleapi.IsNotModified to check
// whether the returned error was because http.StatusNotModified was
// returned.
func (c *LinksInsertCall) Do() (*Link, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Link{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Inserts a new link.",
// "httpMethod": "POST",
// "id": "gan.links.insert",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/link",
// "request": {
// "$ref": "Link"
// },
// "response": {
// "$ref": "Link"
// }
// }
}
// method id "gan.links.list":
type LinksListCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// List: Retrieves all links that match the query parameters.
func (r *LinksService) List(role string, roleId string) *LinksListCall {
c := &LinksListCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// AdvertiserId sets the optional parameter "advertiserId": Limits the
// resulting links to the ones belonging to the listed advertisers.
func (c *LinksListCall) AdvertiserId(advertiserId int64) *LinksListCall {
c.opt_["advertiserId"] = advertiserId
return c
}
// AssetSize sets the optional parameter "assetSize": The size of the
// given asset.
func (c *LinksListCall) AssetSize(assetSize string) *LinksListCall {
c.opt_["assetSize"] = assetSize
return c
}
// Authorship sets the optional parameter "authorship": The role of the
// author of the link.
//
// Possible values:
// "advertiser"
// "publisher"
func (c *LinksListCall) Authorship(authorship string) *LinksListCall {
c.opt_["authorship"] = authorship
return c
}
// CreateDateMax sets the optional parameter "createDateMax": The end of
// the create date range.
func (c *LinksListCall) CreateDateMax(createDateMax string) *LinksListCall {
c.opt_["createDateMax"] = createDateMax
return c
}
// CreateDateMin sets the optional parameter "createDateMin": The
// beginning of the create date range.
func (c *LinksListCall) CreateDateMin(createDateMin string) *LinksListCall {
c.opt_["createDateMin"] = createDateMin
return c
}
// LinkType sets the optional parameter "linkType": The type of the
// link.
//
// Possible values:
// "banner"
// "text"
func (c *LinksListCall) LinkType(linkType string) *LinksListCall {
c.opt_["linkType"] = linkType
return c
}
// MaxResults sets the optional parameter "maxResults": Max number of
// items to return in this page. Defaults to 20.
func (c *LinksListCall) MaxResults(maxResults int64) *LinksListCall {
c.opt_["maxResults"] = maxResults
return c
}
// PageToken sets the optional parameter "pageToken": The value of
// 'nextPageToken' from the previous page.
func (c *LinksListCall) PageToken(pageToken string) *LinksListCall {
c.opt_["pageToken"] = pageToken
return c
}
// PromotionType sets the optional parameter "promotionType": The
// promotion type.
//
// Possible values:
// "coupon"
// "free_gift"
// "free_shipping"
// "percent_off"
// "price_cut"
func (c *LinksListCall) PromotionType(promotionType string) *LinksListCall {
c.opt_["promotionType"] = promotionType
return c
}
// RelationshipStatus sets the optional parameter "relationshipStatus":
// The status of the relationship.
//
// Possible values:
// "approved"
// "available"
func (c *LinksListCall) RelationshipStatus(relationshipStatus string) *LinksListCall {
c.opt_["relationshipStatus"] = relationshipStatus
return c
}
// SearchText sets the optional parameter "searchText": Field for full
// text search across title and merchandising text, supports link id
// search.
func (c *LinksListCall) SearchText(searchText string) *LinksListCall {
c.opt_["searchText"] = searchText
return c
}
// StartDateMax sets the optional parameter "startDateMax": The end of
// the start date range.
func (c *LinksListCall) StartDateMax(startDateMax string) *LinksListCall {
c.opt_["startDateMax"] = startDateMax
return c
}
// StartDateMin sets the optional parameter "startDateMin": The
// beginning of the start date range.
func (c *LinksListCall) StartDateMin(startDateMin string) *LinksListCall {
c.opt_["startDateMin"] = startDateMin
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *LinksListCall) Fields(s ...googleapi.Field) *LinksListCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *LinksListCall) IfNoneMatch(entityTag string) *LinksListCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *LinksListCall) Context(ctx context.Context) *LinksListCall {
c.ctx_ = ctx
return c
}
func (c *LinksListCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiserId"]; ok {
params.Set("advertiserId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["assetSize"]; ok {
params.Set("assetSize", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["authorship"]; ok {
params.Set("authorship", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["createDateMax"]; ok {
params.Set("createDateMax", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["createDateMin"]; ok {
params.Set("createDateMin", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["linkType"]; ok {
params.Set("linkType", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["maxResults"]; ok {
params.Set("maxResults", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["pageToken"]; ok {
params.Set("pageToken", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["promotionType"]; ok {
params.Set("promotionType", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["relationshipStatus"]; ok {
params.Set("relationshipStatus", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["searchText"]; ok {
params.Set("searchText", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["startDateMax"]; ok {
params.Set("startDateMax", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["startDateMin"]; ok {
params.Set("startDateMin", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/links")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.links.list" call.
// Exactly one of *Links or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Links.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *LinksListCall) Do() (*Links, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Links{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves all links that match the query parameters.",
// "httpMethod": "GET",
// "id": "gan.links.list",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "advertiserId": {
// "description": "Limits the resulting links to the ones belonging to the listed advertisers.",
// "format": "int64",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "assetSize": {
// "description": "The size of the given asset.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "authorship": {
// "description": "The role of the author of the link.",
// "enum": [
// "advertiser",
// "publisher"
// ],
// "enumDescriptions": [
// "",
// ""
// ],
// "location": "query",
// "type": "string"
// },
// "createDateMax": {
// "description": "The end of the create date range.",
// "location": "query",
// "type": "string"
// },
// "createDateMin": {
// "description": "The beginning of the create date range.",
// "location": "query",
// "type": "string"
// },
// "linkType": {
// "description": "The type of the link.",
// "enum": [
// "banner",
// "text"
// ],
// "enumDescriptions": [
// "",
// ""
// ],
// "location": "query",
// "type": "string"
// },
// "maxResults": {
// "description": "Max number of items to return in this page. Optional. Defaults to 20.",
// "format": "uint32",
// "location": "query",
// "maximum": "100",
// "minimum": "0",
// "type": "integer"
// },
// "pageToken": {
// "description": "The value of 'nextPageToken' from the previous page. Optional.",
// "location": "query",
// "type": "string"
// },
// "promotionType": {
// "description": "The promotion type.",
// "enum": [
// "coupon",
// "free_gift",
// "free_shipping",
// "percent_off",
// "price_cut"
// ],
// "enumDescriptions": [
// "",
// "",
// "",
// "",
// ""
// ],
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "relationshipStatus": {
// "description": "The status of the relationship.",
// "enum": [
// "approved",
// "available"
// ],
// "enumDescriptions": [
// "",
// ""
// ],
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "searchText": {
// "description": "Field for full text search across title and merchandising text, supports link id search.",
// "location": "query",
// "type": "string"
// },
// "startDateMax": {
// "description": "The end of the start date range.",
// "location": "query",
// "type": "string"
// },
// "startDateMin": {
// "description": "The beginning of the start date range.",
// "location": "query",
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/links",
// "response": {
// "$ref": "Links"
// }
// }
}
// method id "gan.publishers.get":
type PublishersGetCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// Get: Retrieves data about a single advertiser if that the requesting
// advertiser/publisher has access to it. Only advertisers can look up
// publishers. Publishers can request information about themselves by
// omitting the publisherId query parameter.
func (r *PublishersService) Get(role string, roleId string) *PublishersGetCall {
c := &PublishersGetCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// PublisherId sets the optional parameter "publisherId": The ID of the
// publisher to look up.
func (c *PublishersGetCall) PublisherId(publisherId string) *PublishersGetCall {
c.opt_["publisherId"] = publisherId
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *PublishersGetCall) Fields(s ...googleapi.Field) *PublishersGetCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *PublishersGetCall) IfNoneMatch(entityTag string) *PublishersGetCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *PublishersGetCall) Context(ctx context.Context) *PublishersGetCall {
c.ctx_ = ctx
return c
}
func (c *PublishersGetCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["publisherId"]; ok {
params.Set("publisherId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/publisher")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.publishers.get" call.
// Exactly one of *Publisher or error will be non-nil. Any non-2xx
// status code is an error. Response headers are in either
// *Publisher.ServerResponse.Header or (if a response was returned at
// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
// to check whether the returned error was because
// http.StatusNotModified was returned.
func (c *PublishersGetCall) Do() (*Publisher, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Publisher{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves data about a single advertiser if that the requesting advertiser/publisher has access to it. Only advertisers can look up publishers. Publishers can request information about themselves by omitting the publisherId query parameter.",
// "httpMethod": "GET",
// "id": "gan.publishers.get",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "publisherId": {
// "description": "The ID of the publisher to look up. Optional.",
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/publisher",
// "response": {
// "$ref": "Publisher"
// }
// }
}
// method id "gan.publishers.list":
type PublishersListCall struct {
s *Service
role string
roleId string
opt_ map[string]interface{}
ctx_ context.Context
}
// List: Retrieves data about all publishers that the requesting
// advertiser/publisher has access to.
func (r *PublishersService) List(role string, roleId string) *PublishersListCall {
c := &PublishersListCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
return c
}
// MaxResults sets the optional parameter "maxResults": Max number of
// items to return in this page. Defaults to 20.
func (c *PublishersListCall) MaxResults(maxResults int64) *PublishersListCall {
c.opt_["maxResults"] = maxResults
return c
}
// MinNinetyDayEpc sets the optional parameter "minNinetyDayEpc":
// Filters out all publishers that have a ninety day EPC average lower
// than the given value (inclusive). Min value: 0.0.
func (c *PublishersListCall) MinNinetyDayEpc(minNinetyDayEpc float64) *PublishersListCall {
c.opt_["minNinetyDayEpc"] = minNinetyDayEpc
return c
}
// MinPayoutRank sets the optional parameter "minPayoutRank": A value
// between 1 and 4, where 1 represents the quartile of publishers with
// the lowest ranks and 4 represents the quartile of publishers with the
// highest ranks. Filters out all publishers with a lower rank than the
// given quartile. For example if a 2 was given only publishers with a
// payout rank of 25 or higher would be included.
func (c *PublishersListCall) MinPayoutRank(minPayoutRank int64) *PublishersListCall {
c.opt_["minPayoutRank"] = minPayoutRank
return c
}
// MinSevenDayEpc sets the optional parameter "minSevenDayEpc": Filters
// out all publishers that have a seven day EPC average lower than the
// given value (inclusive). Min value 0.0.
func (c *PublishersListCall) MinSevenDayEpc(minSevenDayEpc float64) *PublishersListCall {
c.opt_["minSevenDayEpc"] = minSevenDayEpc
return c
}
// PageToken sets the optional parameter "pageToken": The value of
// 'nextPageToken' from the previous page.
func (c *PublishersListCall) PageToken(pageToken string) *PublishersListCall {
c.opt_["pageToken"] = pageToken
return c
}
// PublisherCategory sets the optional parameter "publisherCategory":
// Caret(^) delimted list of publisher categories. Valid categories:
// (unclassified|community_and_content|shopping_and_promotion|loyalty_and
// _rewards|network|search_specialist|comparison_shopping|email).
// Filters out all publishers not in one of the given advertiser
// categories.
func (c *PublishersListCall) PublisherCategory(publisherCategory string) *PublishersListCall {
c.opt_["publisherCategory"] = publisherCategory
return c
}
// RelationshipStatus sets the optional parameter "relationshipStatus":
// Filters out all publishers for which do not have the given
// relationship status with the requesting publisher.
//
// Possible values:
// "approved" - Publishers you've approved to your program.
// "available" - Publishers available for you to recruit.
// "deactivated" - A publisher that you terminated from your program.
// Publishers also have the ability to remove themselves from your
// program.
// "declined" - A publisher that you did not approve to your program.
// "pending" - Publishers that have applied to your program. We
// recommend reviewing and deciding on pending publishers on a weekly
// basis.
func (c *PublishersListCall) RelationshipStatus(relationshipStatus string) *PublishersListCall {
c.opt_["relationshipStatus"] = relationshipStatus
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *PublishersListCall) Fields(s ...googleapi.Field) *PublishersListCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *PublishersListCall) IfNoneMatch(entityTag string) *PublishersListCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *PublishersListCall) Context(ctx context.Context) *PublishersListCall {
c.ctx_ = ctx
return c
}
func (c *PublishersListCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["maxResults"]; ok {
params.Set("maxResults", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minNinetyDayEpc"]; ok {
params.Set("minNinetyDayEpc", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minPayoutRank"]; ok {
params.Set("minPayoutRank", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["minSevenDayEpc"]; ok {
params.Set("minSevenDayEpc", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["pageToken"]; ok {
params.Set("pageToken", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["publisherCategory"]; ok {
params.Set("publisherCategory", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["relationshipStatus"]; ok {
params.Set("relationshipStatus", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/publishers")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.publishers.list" call.
// Exactly one of *Publishers or error will be non-nil. Any non-2xx
// status code is an error. Response headers are in either
// *Publishers.ServerResponse.Header or (if a response was returned at
// all) in error.(*googleapi.Error).Header. Use googleapi.IsNotModified
// to check whether the returned error was because
// http.StatusNotModified was returned.
func (c *PublishersListCall) Do() (*Publishers, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Publishers{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves data about all publishers that the requesting advertiser/publisher has access to.",
// "httpMethod": "GET",
// "id": "gan.publishers.list",
// "parameterOrder": [
// "role",
// "roleId"
// ],
// "parameters": {
// "maxResults": {
// "description": "Max number of items to return in this page. Optional. Defaults to 20.",
// "format": "uint32",
// "location": "query",
// "maximum": "100",
// "minimum": "0",
// "type": "integer"
// },
// "minNinetyDayEpc": {
// "description": "Filters out all publishers that have a ninety day EPC average lower than the given value (inclusive). Min value: 0.0. Optional.",
// "format": "double",
// "location": "query",
// "type": "number"
// },
// "minPayoutRank": {
// "description": "A value between 1 and 4, where 1 represents the quartile of publishers with the lowest ranks and 4 represents the quartile of publishers with the highest ranks. Filters out all publishers with a lower rank than the given quartile. For example if a 2 was given only publishers with a payout rank of 25 or higher would be included. Optional.",
// "format": "int32",
// "location": "query",
// "maximum": "4",
// "minimum": "1",
// "type": "integer"
// },
// "minSevenDayEpc": {
// "description": "Filters out all publishers that have a seven day EPC average lower than the given value (inclusive). Min value 0.0. Optional.",
// "format": "double",
// "location": "query",
// "type": "number"
// },
// "pageToken": {
// "description": "The value of 'nextPageToken' from the previous page. Optional.",
// "location": "query",
// "type": "string"
// },
// "publisherCategory": {
// "description": "Caret(^) delimted list of publisher categories. Valid categories: (unclassified|community_and_content|shopping_and_promotion|loyalty_and_rewards|network|search_specialist|comparison_shopping|email). Filters out all publishers not in one of the given advertiser categories. Optional.",
// "location": "query",
// "type": "string"
// },
// "relationshipStatus": {
// "description": "Filters out all publishers for which do not have the given relationship status with the requesting publisher.",
// "enum": [
// "approved",
// "available",
// "deactivated",
// "declined",
// "pending"
// ],
// "enumDescriptions": [
// "Publishers you've approved to your program.",
// "Publishers available for you to recruit.",
// "A publisher that you terminated from your program. Publishers also have the ability to remove themselves from your program.",
// "A publisher that you did not approve to your program.",
// "Publishers that have applied to your program. We recommend reviewing and deciding on pending publishers on a weekly basis."
// ],
// "location": "query",
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/publishers",
// "response": {
// "$ref": "Publishers"
// }
// }
}
// method id "gan.reports.get":
type ReportsGetCall struct {
s *Service
role string
roleId string
reportType string
opt_ map[string]interface{}
ctx_ context.Context
}
// Get: Retrieves a report of the specified type.
func (r *ReportsService) Get(role string, roleId string, reportType string) *ReportsGetCall {
c := &ReportsGetCall{s: r.s, opt_: make(map[string]interface{})}
c.role = role
c.roleId = roleId
c.reportType = reportType
return c
}
// AdvertiserId sets the optional parameter "advertiserId": The IDs of
// the advertisers to look up, if applicable.
func (c *ReportsGetCall) AdvertiserId(advertiserId string) *ReportsGetCall {
c.opt_["advertiserId"] = advertiserId
return c
}
// CalculateTotals sets the optional parameter "calculateTotals":
// Whether or not to calculate totals rows.
func (c *ReportsGetCall) CalculateTotals(calculateTotals bool) *ReportsGetCall {
c.opt_["calculateTotals"] = calculateTotals
return c
}
// EndDate sets the optional parameter "endDate": The end date
// (exclusive), in RFC 3339 format, for the report data to be returned.
// Defaults to one day after startDate, if that is given, or today.
func (c *ReportsGetCall) EndDate(endDate string) *ReportsGetCall {
c.opt_["endDate"] = endDate
return c
}
// EventType sets the optional parameter "eventType": Filters out all
// events that are not of the given type. Valid values: 'action',
// 'transaction', or 'charge'.
//
// Possible values:
// "action" - Event type is action.
// "charge" - Event type is charge.
// "transaction" - Event type is transaction.
func (c *ReportsGetCall) EventType(eventType string) *ReportsGetCall {
c.opt_["eventType"] = eventType
return c
}
// LinkId sets the optional parameter "linkId": Filters to capture one
// of given link IDs.
func (c *ReportsGetCall) LinkId(linkId string) *ReportsGetCall {
c.opt_["linkId"] = linkId
return c
}
// MaxResults sets the optional parameter "maxResults": Max number of
// items to return in this page. Defaults to return all results.
func (c *ReportsGetCall) MaxResults(maxResults int64) *ReportsGetCall {
c.opt_["maxResults"] = maxResults
return c
}
// OrderId sets the optional parameter "orderId": Filters to capture one
// of the given order IDs.
func (c *ReportsGetCall) OrderId(orderId string) *ReportsGetCall {
c.opt_["orderId"] = orderId
return c
}
// PublisherId sets the optional parameter "publisherId": The IDs of the
// publishers to look up, if applicable.
func (c *ReportsGetCall) PublisherId(publisherId string) *ReportsGetCall {
c.opt_["publisherId"] = publisherId
return c
}
// StartDate sets the optional parameter "startDate": The start date
// (inclusive), in RFC 3339 format, for the report data to be returned.
// Defaults to one day before endDate, if that is given, or yesterday.
func (c *ReportsGetCall) StartDate(startDate string) *ReportsGetCall {
c.opt_["startDate"] = startDate
return c
}
// StartIndex sets the optional parameter "startIndex": Offset on which
// to return results when paging.
func (c *ReportsGetCall) StartIndex(startIndex int64) *ReportsGetCall {
c.opt_["startIndex"] = startIndex
return c
}
// Status sets the optional parameter "status": Filters out all events
// that do not have the given status. Valid values: 'active',
// 'canceled', or 'invalid'.
//
// Possible values:
// "active" - Event is currently active.
// "canceled" - Event is currently canceled.
// "invalid" - Event is currently invalid.
func (c *ReportsGetCall) Status(status string) *ReportsGetCall {
c.opt_["status"] = status
return c
}
// Fields allows partial responses to be retrieved.
// See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse
// for more information.
func (c *ReportsGetCall) Fields(s ...googleapi.Field) *ReportsGetCall {
c.opt_["fields"] = googleapi.CombineFields(s)
return c
}
// IfNoneMatch sets the optional parameter which makes the operation
// fail if the object's ETag matches the given value. This is useful for
// getting updates only after the object has changed since the last
// request. Use googleapi.IsNotModified to check whether the response
// error from Do is the result of In-None-Match.
func (c *ReportsGetCall) IfNoneMatch(entityTag string) *ReportsGetCall {
c.opt_["ifNoneMatch"] = entityTag
return c
}
// Context sets the context to be used in this call's Do method.
// Any pending HTTP request will be aborted if the provided context
// is canceled.
func (c *ReportsGetCall) Context(ctx context.Context) *ReportsGetCall {
c.ctx_ = ctx
return c
}
func (c *ReportsGetCall) doRequest(alt string) (*http.Response, error) {
var body io.Reader = nil
params := make(url.Values)
params.Set("alt", alt)
if v, ok := c.opt_["advertiserId"]; ok {
params.Set("advertiserId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["calculateTotals"]; ok {
params.Set("calculateTotals", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["endDate"]; ok {
params.Set("endDate", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["eventType"]; ok {
params.Set("eventType", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["linkId"]; ok {
params.Set("linkId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["maxResults"]; ok {
params.Set("maxResults", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["orderId"]; ok {
params.Set("orderId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["publisherId"]; ok {
params.Set("publisherId", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["startDate"]; ok {
params.Set("startDate", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["startIndex"]; ok {
params.Set("startIndex", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["status"]; ok {
params.Set("status", fmt.Sprintf("%v", v))
}
if v, ok := c.opt_["fields"]; ok {
params.Set("fields", fmt.Sprintf("%v", v))
}
urls := googleapi.ResolveRelative(c.s.BasePath, "{role}/{roleId}/report/{reportType}")
urls += "?" + params.Encode()
req, _ := http.NewRequest("GET", urls, body)
googleapi.Expand(req.URL, map[string]string{
"role": c.role,
"roleId": c.roleId,
"reportType": c.reportType,
})
req.Header.Set("User-Agent", c.s.userAgent())
if v, ok := c.opt_["ifNoneMatch"]; ok {
req.Header.Set("If-None-Match", fmt.Sprintf("%v", v))
}
if c.ctx_ != nil {
return ctxhttp.Do(c.ctx_, c.s.client, req)
}
return c.s.client.Do(req)
}
// Do executes the "gan.reports.get" call.
// Exactly one of *Report or error will be non-nil. Any non-2xx status
// code is an error. Response headers are in either
// *Report.ServerResponse.Header or (if a response was returned at all)
// in error.(*googleapi.Error).Header. Use googleapi.IsNotModified to
// check whether the returned error was because http.StatusNotModified
// was returned.
func (c *ReportsGetCall) Do() (*Report, error) {
res, err := c.doRequest("json")
if res != nil && res.StatusCode == http.StatusNotModified {
if res.Body != nil {
res.Body.Close()
}
return nil, &googleapi.Error{
Code: res.StatusCode,
Header: res.Header,
}
}
if err != nil {
return nil, err
}
defer googleapi.CloseBody(res)
if err := googleapi.CheckResponse(res); err != nil {
return nil, err
}
ret := &Report{
ServerResponse: googleapi.ServerResponse{
Header: res.Header,
HTTPStatusCode: res.StatusCode,
},
}
if err := json.NewDecoder(res.Body).Decode(&ret); err != nil {
return nil, err
}
return ret, nil
// {
// "description": "Retrieves a report of the specified type.",
// "httpMethod": "GET",
// "id": "gan.reports.get",
// "parameterOrder": [
// "role",
// "roleId",
// "reportType"
// ],
// "parameters": {
// "advertiserId": {
// "description": "The IDs of the advertisers to look up, if applicable.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "calculateTotals": {
// "description": "Whether or not to calculate totals rows. Optional.",
// "location": "query",
// "type": "boolean"
// },
// "endDate": {
// "description": "The end date (exclusive), in RFC 3339 format, for the report data to be returned. Defaults to one day after startDate, if that is given, or today. Optional.",
// "location": "query",
// "type": "string"
// },
// "eventType": {
// "description": "Filters out all events that are not of the given type. Valid values: 'action', 'transaction', or 'charge'. Optional.",
// "enum": [
// "action",
// "charge",
// "transaction"
// ],
// "enumDescriptions": [
// "Event type is action.",
// "Event type is charge.",
// "Event type is transaction."
// ],
// "location": "query",
// "type": "string"
// },
// "linkId": {
// "description": "Filters to capture one of given link IDs. Optional.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "maxResults": {
// "description": "Max number of items to return in this page. Optional. Defaults to return all results.",
// "format": "uint32",
// "location": "query",
// "minimum": "0",
// "type": "integer"
// },
// "orderId": {
// "description": "Filters to capture one of the given order IDs. Optional.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "publisherId": {
// "description": "The IDs of the publishers to look up, if applicable.",
// "location": "query",
// "repeated": true,
// "type": "string"
// },
// "reportType": {
// "description": "The type of report being requested. Valid values: 'order_delta'. Required.",
// "enum": [
// "order_delta"
// ],
// "enumDescriptions": [
// "The order delta report type."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "role": {
// "description": "The role of the requester. Valid values: 'advertisers' or 'publishers'.",
// "enum": [
// "advertisers",
// "publishers"
// ],
// "enumDescriptions": [
// "The requester is requesting as an advertiser.",
// "The requester is requesting as a publisher."
// ],
// "location": "path",
// "required": true,
// "type": "string"
// },
// "roleId": {
// "description": "The ID of the requesting advertiser or publisher.",
// "location": "path",
// "required": true,
// "type": "string"
// },
// "startDate": {
// "description": "The start date (inclusive), in RFC 3339 format, for the report data to be returned. Defaults to one day before endDate, if that is given, or yesterday. Optional.",
// "location": "query",
// "type": "string"
// },
// "startIndex": {
// "description": "Offset on which to return results when paging. Optional.",
// "format": "uint32",
// "location": "query",
// "minimum": "0",
// "type": "integer"
// },
// "status": {
// "description": "Filters out all events that do not have the given status. Valid values: 'active', 'canceled', or 'invalid'. Optional.",
// "enum": [
// "active",
// "canceled",
// "invalid"
// ],
// "enumDescriptions": [
// "Event is currently active.",
// "Event is currently canceled.",
// "Event is currently invalid."
// ],
// "location": "query",
// "type": "string"
// }
// },
// "path": "{role}/{roleId}/report/{reportType}",
// "response": {
// "$ref": "Report"
// }
// }
}