Documentation

Overview

Package civicinfo provides access to the Google Civic Information API.

For product documentation, see: https://developers.google.com/civic-information

Creating a client

Usage example:

import "google.golang.org/api/civicinfo/v2"
...
ctx := context.Background()
civicinfoService, err := civicinfo.NewService(ctx)

In this example, Google Application Default Credentials are used for authentication.

For information on how to create and obtain Application Default Credentials, see https://developers.google.com/identity/protocols/application-default-credentials.

Other authentication options

To use an API key for authentication (note: some APIs do not support API keys), use option.WithAPIKey:

civicinfoService, err := civicinfo.NewService(ctx, option.WithAPIKey("AIza..."))

To use an OAuth token (e.g., a user token obtained via a three-legged OAuth flow), use option.WithTokenSource:

config := &oauth2.Config{...}
// ...
token, err := config.Exchange(ctx, ...)
civicinfoService, err := civicinfo.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token)))

See https://godoc.org/google.golang.org/api/option/ for details on options.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type AdministrationRegion

type AdministrationRegion struct {
	// ElectionAdministrationBody: The election administration body for this
	// area.
	ElectionAdministrationBody *AdministrativeBody `json:"electionAdministrationBody,omitempty"`

	// Id: An ID for this object. IDs may change in future requests and
	// should not be cached. Access to this field requires special access
	// that can be requested from the Request more link on the Quotas page.
	Id string `json:"id,omitempty"`

	// LocalJurisdiction: The city or county that provides election
	// information for this voter. This object can have the same elements as
	// state.
	LocalJurisdiction *AdministrationRegion `json:"local_jurisdiction,omitempty"`

	// Name: The name of the jurisdiction.
	Name string `json:"name,omitempty"`

	// Sources: A list of sources for this area. If multiple sources are
	// listed the data has been aggregated from those sources.
	Sources []*Source `json:"sources,omitempty"`

	// ForceSendFields is a list of field names (e.g.
	// "ElectionAdministrationBody") 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:"-"`

	// NullFields is a list of field names (e.g.
	// "ElectionAdministrationBody") to include in API requests with the
	// JSON null value. By default, fields with empty values are omitted
	// from API requests. However, any field with an empty value appearing
	// in NullFields will be sent to the server as null. It is an error if a
	// field in this list has a non-empty value. This may be used to include
	// null fields in Patch requests.
	NullFields []string `json:"-"`
}

    AdministrationRegion: Describes information about a regional election administrative area.

    func (*AdministrationRegion) MarshalJSON

    func (s *AdministrationRegion) MarshalJSON() ([]byte, error)

    type AdministrativeBody

    type AdministrativeBody struct {
    	// AbsenteeVotingInfoUrl: A URL provided by this administrative body for
    	// information on absentee voting.
    	AbsenteeVotingInfoUrl string `json:"absenteeVotingInfoUrl,omitempty"`
    
    	AddressLines []string `json:"addressLines,omitempty"`
    
    	// BallotInfoUrl: A URL provided by this administrative body to give
    	// contest information to the voter.
    	BallotInfoUrl string `json:"ballotInfoUrl,omitempty"`
    
    	// CorrespondenceAddress: The mailing address of this administrative
    	// body.
    	CorrespondenceAddress *SimpleAddressType `json:"correspondenceAddress,omitempty"`
    
    	// ElectionInfoUrl: A URL provided by this administrative body for
    	// looking up general election information.
    	ElectionInfoUrl string `json:"electionInfoUrl,omitempty"`
    
    	// ElectionOfficials: The election officials for this election
    	// administrative body.
    	ElectionOfficials []*ElectionOfficial `json:"electionOfficials,omitempty"`
    
    	// ElectionRegistrationConfirmationUrl: A URL provided by this
    	// administrative body for confirming that the voter is registered to
    	// vote.
    	ElectionRegistrationConfirmationUrl string `json:"electionRegistrationConfirmationUrl,omitempty"`
    
    	// ElectionRegistrationUrl: A URL provided by this administrative body
    	// for looking up how to register to vote.
    	ElectionRegistrationUrl string `json:"electionRegistrationUrl,omitempty"`
    
    	// ElectionRulesUrl: A URL provided by this administrative body
    	// describing election rules to the voter.
    	ElectionRulesUrl string `json:"electionRulesUrl,omitempty"`
    
    	// HoursOfOperation: A description of the hours of operation for this
    	// administrative body.
    	HoursOfOperation string `json:"hoursOfOperation,omitempty"`
    
    	// Name: The name of this election administrative body.
    	Name string `json:"name,omitempty"`
    
    	// PhysicalAddress: The physical address of this administrative body.
    	PhysicalAddress *SimpleAddressType `json:"physicalAddress,omitempty"`
    
    	// VoterServices: A description of the services this administrative body
    	// may provide.
    	VoterServices []string `json:"voter_services,omitempty"`
    
    	// VotingLocationFinderUrl: A URL provided by this administrative body
    	// for looking up where to vote.
    	VotingLocationFinderUrl string `json:"votingLocationFinderUrl,omitempty"`
    
    	// ForceSendFields is a list of field names (e.g.
    	// "AbsenteeVotingInfoUrl") 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:"-"`
    
    	// NullFields is a list of field names (e.g. "AbsenteeVotingInfoUrl") to
    	// include in API requests with the JSON null value. By default, fields
    	// with empty values are omitted from API requests. However, any field
    	// with an empty value appearing in NullFields will be sent to the
    	// server as null. It is an error if a field in this list has a
    	// non-empty value. This may be used to include null fields in Patch
    	// requests.
    	NullFields []string `json:"-"`
    }

      AdministrativeBody: Information about an election administrative body (e.g. County Board of Elections).

      func (*AdministrativeBody) MarshalJSON

      func (s *AdministrativeBody) MarshalJSON() ([]byte, error)

      type Candidate

      type Candidate struct {
      	// CandidateUrl: The URL for the candidate's campaign web site.
      	CandidateUrl string `json:"candidateUrl,omitempty"`
      
      	// Channels: A list of known (social) media channels for this candidate.
      	Channels []*Channel `json:"channels,omitempty"`
      
      	// Email: The email address for the candidate's campaign.
      	Email string `json:"email,omitempty"`
      
      	// Name: The candidate's name. If this is a joint ticket it will
      	// indicate the name of the candidate at the top of a ticket followed by
      	// a / and that name of candidate at the bottom of the ticket. e.g.
      	// "Mitt Romney / Paul Ryan"
      	Name string `json:"name,omitempty"`
      
      	// OrderOnBallot: The order the candidate appears on the ballot for this
      	// contest.
      	OrderOnBallot int64 `json:"orderOnBallot,omitempty,string"`
      
      	// Party: The full name of the party the candidate is a member of.
      	Party string `json:"party,omitempty"`
      
      	// Phone: The voice phone number for the candidate's campaign office.
      	Phone string `json:"phone,omitempty"`
      
      	// PhotoUrl: A URL for a photo of the candidate.
      	PhotoUrl string `json:"photoUrl,omitempty"`
      
      	// ForceSendFields is a list of field names (e.g. "CandidateUrl") 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:"-"`
      
      	// NullFields is a list of field names (e.g. "CandidateUrl") to include
      	// in API requests with the JSON null value. By default, fields with
      	// empty values are omitted from API requests. However, any field with
      	// an empty value appearing in NullFields will be sent to the server as
      	// null. It is an error if a field in this list has a non-empty value.
      	// This may be used to include null fields in Patch requests.
      	NullFields []string `json:"-"`
      }

        Candidate: Information about a candidate running for elected office.

        func (*Candidate) MarshalJSON

        func (s *Candidate) MarshalJSON() ([]byte, error)

        type Channel

        type Channel struct {
        	// Id: The unique public identifier for the candidate's channel.
        	Id string `json:"id,omitempty"`
        
        	// Type: The type of channel. The following is a list of types of
        	// channels, but is not exhaustive. More channel types may be added at a
        	// later time. One of: GooglePlus, YouTube, Facebook, Twitter
        	Type string `json:"type,omitempty"`
        
        	// ForceSendFields is a list of field names (e.g. "Id") 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:"-"`
        
        	// NullFields is a list of field names (e.g. "Id") to include in API
        	// requests with the JSON null value. By default, fields with empty
        	// values are omitted from API requests. However, any field with an
        	// empty value appearing in NullFields will be sent to the server as
        	// null. It is an error if a field in this list has a non-empty value.
        	// This may be used to include null fields in Patch requests.
        	NullFields []string `json:"-"`
        }

          Channel: A social media or web channel for a candidate.

          func (*Channel) MarshalJSON

          func (s *Channel) MarshalJSON() ([]byte, error)

          type Contest

          type Contest struct {
          	// BallotPlacement: A number specifying the position of this contest on
          	// the voter's ballot.
          	BallotPlacement int64 `json:"ballotPlacement,omitempty,string"`
          
          	// BallotTitle: The official title on the ballot for this contest, only
          	// where available.
          	BallotTitle string `json:"ballotTitle,omitempty"`
          
          	// Candidates: The candidate choices for this contest.
          	Candidates []*Candidate `json:"candidates,omitempty"`
          
          	// District: Information about the electoral district that this contest
          	// is in.
          	District *ElectoralDistrict `json:"district,omitempty"`
          
          	// ElectorateSpecifications: A description of any additional eligibility
          	// requirements for voting in this contest.
          	ElectorateSpecifications string `json:"electorateSpecifications,omitempty"`
          
          	// Id: An ID for this object. IDs may change in future requests and
          	// should not be cached. Access to this field requires special access
          	// that can be requested from the Request more link on the Quotas page.
          	Id string `json:"id,omitempty"`
          
          	// Level: The levels of government of the office for this contest. There
          	// may be more than one in cases where a jurisdiction effectively acts
          	// at two different levels of government; for example, the mayor of the
          	// District of Columbia acts at "locality" level, but also effectively
          	// at both "administrative-area-2" and "administrative-area-1".
          	Level []string `json:"level,omitempty"`
          
          	// NumberElected: The number of candidates that will be elected to
          	// office in this contest.
          	NumberElected int64 `json:"numberElected,omitempty,string"`
          
          	// NumberVotingFor: The number of candidates that a voter may vote for
          	// in this contest.
          	NumberVotingFor int64 `json:"numberVotingFor,omitempty,string"`
          
          	// Office: The name of the office for this contest.
          	Office string `json:"office,omitempty"`
          
          	// PrimaryParty: If this is a partisan election, the name of the party
          	// it is for.
          	PrimaryParty string `json:"primaryParty,omitempty"`
          
          	// ReferendumBallotResponses: The set of ballot responses for the
          	// referendum. A ballot response represents a line on the ballot. Common
          	// examples might include "yes" or "no" for referenda. This field is
          	// only populated for contests of type 'Referendum'.
          	ReferendumBallotResponses []string `json:"referendumBallotResponses,omitempty"`
          
          	// ReferendumBrief: Specifies a short summary of the referendum that is
          	// typically on the ballot below the title but above the text. This
          	// field is only populated for contests of type 'Referendum'.
          	ReferendumBrief string `json:"referendumBrief,omitempty"`
          
          	// ReferendumConStatement: A statement in opposition to the referendum.
          	// It does not necessarily appear on the ballot. This field is only
          	// populated for contests of type 'Referendum'.
          	ReferendumConStatement string `json:"referendumConStatement,omitempty"`
          
          	// ReferendumEffectOfAbstain: Specifies what effect abstaining (not
          	// voting) on the proposition will have (i.e. whether abstaining is
          	// considered a vote against it). This field is only populated for
          	// contests of type 'Referendum'.
          	ReferendumEffectOfAbstain string `json:"referendumEffectOfAbstain,omitempty"`
          
          	// ReferendumPassageThreshold: The threshold of votes that the
          	// referendum needs in order to pass, e.g. "two-thirds". This field is
          	// only populated for contests of type 'Referendum'.
          	ReferendumPassageThreshold string `json:"referendumPassageThreshold,omitempty"`
          
          	// ReferendumProStatement: A statement in favor of the referendum. It
          	// does not necessarily appear on the ballot. This field is only
          	// populated for contests of type 'Referendum'.
          	ReferendumProStatement string `json:"referendumProStatement,omitempty"`
          
          	// ReferendumSubtitle: A brief description of the referendum. This field
          	// is only populated for contests of type 'Referendum'.
          	ReferendumSubtitle string `json:"referendumSubtitle,omitempty"`
          
          	// ReferendumText: The full text of the referendum. This field is only
          	// populated for contests of type 'Referendum'.
          	ReferendumText string `json:"referendumText,omitempty"`
          
          	// ReferendumTitle: The title of the referendum (e.g. 'Proposition 42').
          	// This field is only populated for contests of type 'Referendum'.
          	ReferendumTitle string `json:"referendumTitle,omitempty"`
          
          	// ReferendumUrl: A link to the referendum. This field is only populated
          	// for contests of type 'Referendum'.
          	ReferendumUrl string `json:"referendumUrl,omitempty"`
          
          	// Roles: The roles which this office fulfills.
          	Roles []string `json:"roles,omitempty"`
          
          	// Sources: A list of sources for this contest. If multiple sources are
          	// listed, the data has been aggregated from those sources.
          	Sources []*Source `json:"sources,omitempty"`
          
          	// Special: "Yes" or "No" depending on whether this a contest being held
          	// outside the normal election cycle.
          	Special string `json:"special,omitempty"`
          
          	// Type: The type of contest. Usually this will be 'General', 'Primary',
          	// or 'Run-off' for contests with candidates. For referenda this will be
          	// 'Referendum'. For Retention contests this will typically be
          	// 'Retention'.
          	Type string `json:"type,omitempty"`
          
          	// ForceSendFields is a list of field names (e.g. "BallotPlacement") 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:"-"`
          
          	// NullFields is a list of field names (e.g. "BallotPlacement") to
          	// include in API requests with the JSON null value. By default, fields
          	// with empty values are omitted from API requests. However, any field
          	// with an empty value appearing in NullFields will be sent to the
          	// server as null. It is an error if a field in this list has a
          	// non-empty value. This may be used to include null fields in Patch
          	// requests.
          	NullFields []string `json:"-"`
          }

            Contest: Information about a contest that appears on a voter's ballot.

            func (*Contest) MarshalJSON

            func (s *Contest) MarshalJSON() ([]byte, error)

            type ContextParams

            type ContextParams struct {
            	ClientProfile string `json:"clientProfile,omitempty"`
            
            	// ForceSendFields is a list of field names (e.g. "ClientProfile") 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:"-"`
            
            	// NullFields is a list of field names (e.g. "ClientProfile") to include
            	// in API requests with the JSON null value. By default, fields with
            	// empty values are omitted from API requests. However, any field with
            	// an empty value appearing in NullFields will be sent to the server as
            	// null. It is an error if a field in this list has a non-empty value.
            	// This may be used to include null fields in Patch requests.
            	NullFields []string `json:"-"`
            }

            func (*ContextParams) MarshalJSON

            func (s *ContextParams) MarshalJSON() ([]byte, error)

            type DivisionRepresentativeInfoRequest

            type DivisionRepresentativeInfoRequest struct {
            	ContextParams *ContextParams `json:"contextParams,omitempty"`
            
            	// ForceSendFields is a list of field names (e.g. "ContextParams") 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:"-"`
            
            	// NullFields is a list of field names (e.g. "ContextParams") to include
            	// in API requests with the JSON null value. By default, fields with
            	// empty values are omitted from API requests. However, any field with
            	// an empty value appearing in NullFields will be sent to the server as
            	// null. It is an error if a field in this list has a non-empty value.
            	// This may be used to include null fields in Patch requests.
            	NullFields []string `json:"-"`
            }

              DivisionRepresentativeInfoRequest: A request to look up representative information for a single division.

              func (*DivisionRepresentativeInfoRequest) MarshalJSON

              func (s *DivisionRepresentativeInfoRequest) MarshalJSON() ([]byte, error)

              type DivisionSearchRequest

              type DivisionSearchRequest struct {
              	ContextParams *ContextParams `json:"contextParams,omitempty"`
              
              	// ForceSendFields is a list of field names (e.g. "ContextParams") 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:"-"`
              
              	// NullFields is a list of field names (e.g. "ContextParams") to include
              	// in API requests with the JSON null value. By default, fields with
              	// empty values are omitted from API requests. However, any field with
              	// an empty value appearing in NullFields will be sent to the server as
              	// null. It is an error if a field in this list has a non-empty value.
              	// This may be used to include null fields in Patch requests.
              	NullFields []string `json:"-"`
              }

                DivisionSearchRequest: A search request for political geographies.

                func (*DivisionSearchRequest) MarshalJSON

                func (s *DivisionSearchRequest) MarshalJSON() ([]byte, error)

                type DivisionSearchResponse

                type DivisionSearchResponse struct {
                	// Kind: Identifies what kind of resource this is. Value: the fixed
                	// string "civicinfo#divisionSearchResponse".
                	Kind string `json:"kind,omitempty"`
                
                	Results []*DivisionSearchResult `json:"results,omitempty"`
                
                	// ServerResponse contains the HTTP response code and headers from the
                	// server.
                	googleapi.ServerResponse `json:"-"`
                
                	// ForceSendFields is a list of field names (e.g. "Kind") 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:"-"`
                
                	// NullFields is a list of field names (e.g. "Kind") to include in API
                	// requests with the JSON null value. By default, fields with empty
                	// values are omitted from API requests. However, any field with an
                	// empty value appearing in NullFields will be sent to the server as
                	// null. It is an error if a field in this list has a non-empty value.
                	// This may be used to include null fields in Patch requests.
                	NullFields []string `json:"-"`
                }

                  DivisionSearchResponse: The result of a division search query.

                  func (*DivisionSearchResponse) MarshalJSON

                  func (s *DivisionSearchResponse) MarshalJSON() ([]byte, error)

                  type DivisionSearchResult

                  type DivisionSearchResult struct {
                  	// Aliases: Other Open Civic Data identifiers that refer to the same
                  	// division -- for example, those that refer to other political
                  	// divisions whose boundaries are defined to be coterminous with this
                  	// one. For example, ocd-division/country:us/state:wy will include an
                  	// alias of ocd-division/country:us/state:wy/cd:1, since Wyoming has
                  	// only one Congressional district.
                  	Aliases []string `json:"aliases,omitempty"`
                  
                  	// Name: The name of the division.
                  	Name string `json:"name,omitempty"`
                  
                  	// OcdId: The unique Open Civic Data identifier for this division.
                  	OcdId string `json:"ocdId,omitempty"`
                  
                  	// ForceSendFields is a list of field names (e.g. "Aliases") 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:"-"`
                  
                  	// NullFields is a list of field names (e.g. "Aliases") to include in
                  	// API requests with the JSON null value. By default, fields with empty
                  	// values are omitted from API requests. However, any field with an
                  	// empty value appearing in NullFields will be sent to the server as
                  	// null. It is an error if a field in this list has a non-empty value.
                  	// This may be used to include null fields in Patch requests.
                  	NullFields []string `json:"-"`
                  }

                    DivisionSearchResult: Represents a political geographic division that matches the requested query.

                    func (*DivisionSearchResult) MarshalJSON

                    func (s *DivisionSearchResult) MarshalJSON() ([]byte, error)

                    type DivisionsSearchCall

                    type DivisionsSearchCall struct {
                    	// contains filtered or unexported fields
                    }

                    func (*DivisionsSearchCall) Context

                      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 (*DivisionsSearchCall) Do

                        Do executes the "civicinfo.divisions.search" call. Exactly one of *DivisionSearchResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *DivisionSearchResponse.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 (*DivisionsSearchCall) Fields

                          Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                          func (*DivisionsSearchCall) Header

                          func (c *DivisionsSearchCall) Header() http.Header

                            Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                            func (*DivisionsSearchCall) IfNoneMatch

                            func (c *DivisionsSearchCall) IfNoneMatch(entityTag string) *DivisionsSearchCall

                              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 (*DivisionsSearchCall) Query

                                Query sets the optional parameter "query": The search query. Queries can cover any parts of a OCD ID or a human readable division name. All words given in the query are treated as required patterns. In addition to that, most query operators of the Apache Lucene library are supported. See http://lucene.apache.org/core/2_9_4/queryparsersyntax.html

                                type DivisionsService

                                type DivisionsService struct {
                                	// contains filtered or unexported fields
                                }

                                func NewDivisionsService

                                func NewDivisionsService(s *Service) *DivisionsService

                                func (*DivisionsService) Search

                                func (r *DivisionsService) Search(divisionsearchrequest *DivisionSearchRequest) *DivisionsSearchCall

                                  Search: Searches for political divisions by their natural name or OCD ID.

                                  type Election

                                  type Election struct {
                                  	// ElectionDay: Day of the election in YYYY-MM-DD format.
                                  	ElectionDay string `json:"electionDay,omitempty"`
                                  
                                  	// Id: The unique ID of this election.
                                  	Id int64 `json:"id,omitempty,string"`
                                  
                                  	// Name: A displayable name for the election.
                                  	Name string `json:"name,omitempty"`
                                  
                                  	// OcdDivisionId: The political division of the election. Represented as
                                  	// an OCD Division ID. Voters within these political jurisdictions are
                                  	// covered by this election. This is typically a state such as
                                  	// ocd-division/country:us/state:ca or for the midterms or general
                                  	// election the entire US (i.e. ocd-division/country:us).
                                  	OcdDivisionId string `json:"ocdDivisionId,omitempty"`
                                  
                                  	// ForceSendFields is a list of field names (e.g. "ElectionDay") 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:"-"`
                                  
                                  	// NullFields is a list of field names (e.g. "ElectionDay") to include
                                  	// in API requests with the JSON null value. By default, fields with
                                  	// empty values are omitted from API requests. However, any field with
                                  	// an empty value appearing in NullFields will be sent to the server as
                                  	// null. It is an error if a field in this list has a non-empty value.
                                  	// This may be used to include null fields in Patch requests.
                                  	NullFields []string `json:"-"`
                                  }

                                    Election: Information about the election that was queried.

                                    func (*Election) MarshalJSON

                                    func (s *Election) MarshalJSON() ([]byte, error)

                                    type ElectionOfficial

                                    type ElectionOfficial struct {
                                    	// EmailAddress: The email address of the election official.
                                    	EmailAddress string `json:"emailAddress,omitempty"`
                                    
                                    	// FaxNumber: The fax number of the election official.
                                    	FaxNumber string `json:"faxNumber,omitempty"`
                                    
                                    	// Name: The full name of the election official.
                                    	Name string `json:"name,omitempty"`
                                    
                                    	// OfficePhoneNumber: The office phone number of the election official.
                                    	OfficePhoneNumber string `json:"officePhoneNumber,omitempty"`
                                    
                                    	// Title: The title of the election official.
                                    	Title string `json:"title,omitempty"`
                                    
                                    	// ForceSendFields is a list of field names (e.g. "EmailAddress") 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:"-"`
                                    
                                    	// NullFields is a list of field names (e.g. "EmailAddress") to include
                                    	// in API requests with the JSON null value. By default, fields with
                                    	// empty values are omitted from API requests. However, any field with
                                    	// an empty value appearing in NullFields will be sent to the server as
                                    	// null. It is an error if a field in this list has a non-empty value.
                                    	// This may be used to include null fields in Patch requests.
                                    	NullFields []string `json:"-"`
                                    }

                                      ElectionOfficial: Information about individual election officials.

                                      func (*ElectionOfficial) MarshalJSON

                                      func (s *ElectionOfficial) MarshalJSON() ([]byte, error)

                                      type ElectionsElectionQueryCall

                                      type ElectionsElectionQueryCall struct {
                                      	// contains filtered or unexported fields
                                      }

                                      func (*ElectionsElectionQueryCall) Context

                                        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 (*ElectionsElectionQueryCall) Do

                                          Do executes the "civicinfo.elections.electionQuery" call. Exactly one of *ElectionsQueryResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *ElectionsQueryResponse.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 (*ElectionsElectionQueryCall) Fields

                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                            func (*ElectionsElectionQueryCall) Header

                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                              func (*ElectionsElectionQueryCall) IfNoneMatch

                                                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.

                                                type ElectionsQueryRequest

                                                type ElectionsQueryRequest struct {
                                                	ContextParams *ContextParams `json:"contextParams,omitempty"`
                                                
                                                	// ForceSendFields is a list of field names (e.g. "ContextParams") 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:"-"`
                                                
                                                	// NullFields is a list of field names (e.g. "ContextParams") to include
                                                	// in API requests with the JSON null value. By default, fields with
                                                	// empty values are omitted from API requests. However, any field with
                                                	// an empty value appearing in NullFields will be sent to the server as
                                                	// null. It is an error if a field in this list has a non-empty value.
                                                	// This may be used to include null fields in Patch requests.
                                                	NullFields []string `json:"-"`
                                                }

                                                func (*ElectionsQueryRequest) MarshalJSON

                                                func (s *ElectionsQueryRequest) MarshalJSON() ([]byte, error)

                                                type ElectionsQueryResponse

                                                type ElectionsQueryResponse struct {
                                                	// Elections: A list of available elections
                                                	Elections []*Election `json:"elections,omitempty"`
                                                
                                                	// Kind: Identifies what kind of resource this is. Value: the fixed
                                                	// string "civicinfo#electionsQueryResponse".
                                                	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. "Elections") 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:"-"`
                                                
                                                	// NullFields is a list of field names (e.g. "Elections") to include in
                                                	// API requests with the JSON null value. By default, fields with empty
                                                	// values are omitted from API requests. However, any field with an
                                                	// empty value appearing in NullFields will be sent to the server as
                                                	// null. It is an error if a field in this list has a non-empty value.
                                                	// This may be used to include null fields in Patch requests.
                                                	NullFields []string `json:"-"`
                                                }

                                                  ElectionsQueryResponse: The list of elections available for this version of the API.

                                                  func (*ElectionsQueryResponse) MarshalJSON

                                                  func (s *ElectionsQueryResponse) MarshalJSON() ([]byte, error)

                                                  type ElectionsService

                                                  type ElectionsService struct {
                                                  	// contains filtered or unexported fields
                                                  }

                                                  func NewElectionsService

                                                  func NewElectionsService(s *Service) *ElectionsService

                                                  func (*ElectionsService) ElectionQuery

                                                  func (r *ElectionsService) ElectionQuery(electionsqueryrequest *ElectionsQueryRequest) *ElectionsElectionQueryCall

                                                    ElectionQuery: List of available elections to query.

                                                    func (*ElectionsService) VoterInfoQuery

                                                    func (r *ElectionsService) VoterInfoQuery(address string, voterinforequest *VoterInfoRequest) *ElectionsVoterInfoQueryCall

                                                      VoterInfoQuery: Looks up information relevant to a voter based on the voter's registered address.

                                                      type ElectionsVoterInfoQueryCall

                                                      type ElectionsVoterInfoQueryCall struct {
                                                      	// contains filtered or unexported fields
                                                      }

                                                      func (*ElectionsVoterInfoQueryCall) Context

                                                        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 (*ElectionsVoterInfoQueryCall) Do

                                                          Do executes the "civicinfo.elections.voterInfoQuery" call. Exactly one of *VoterInfoResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *VoterInfoResponse.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 (*ElectionsVoterInfoQueryCall) ElectionId

                                                            ElectionId sets the optional parameter "electionId": The unique ID of the election to look up. A list of election IDs can be obtained at https://www.googleapis.com/civicinfo/{version}/electionsIf no election ID is specified in the query and there is more than one election with data for the given voter, the additional elections are provided in the otherElections response field.

                                                            func (*ElectionsVoterInfoQueryCall) Fields

                                                              Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                              func (*ElectionsVoterInfoQueryCall) Header

                                                                Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                func (*ElectionsVoterInfoQueryCall) IfNoneMatch

                                                                  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 (*ElectionsVoterInfoQueryCall) OfficialOnly

                                                                  func (c *ElectionsVoterInfoQueryCall) OfficialOnly(officialOnly bool) *ElectionsVoterInfoQueryCall

                                                                    OfficialOnly sets the optional parameter "officialOnly": If set to true, only data from official state sources will be returned.

                                                                    func (*ElectionsVoterInfoQueryCall) ReturnAllAvailableData

                                                                    func (c *ElectionsVoterInfoQueryCall) ReturnAllAvailableData(returnAllAvailableData bool) *ElectionsVoterInfoQueryCall

                                                                      ReturnAllAvailableData sets the optional parameter "returnAllAvailableData": If set to true, the query will return the success codeand include any partial information when it is unable to determine a matching address or unable to determine the election for electionId=0 queries.

                                                                      type ElectoralDistrict

                                                                      type ElectoralDistrict struct {
                                                                      	// Id: An identifier for this district, relative to its scope. For
                                                                      	// example, the 34th State Senate district would have id "34" and a
                                                                      	// scope of stateUpper.
                                                                      	Id string `json:"id,omitempty"`
                                                                      
                                                                      	KgForeignKey string `json:"kgForeignKey,omitempty"`
                                                                      
                                                                      	// Name: The name of the district.
                                                                      	Name string `json:"name,omitempty"`
                                                                      
                                                                      	// Scope: The geographic scope of this district. If unspecified the
                                                                      	// district's geography is not known. One of: national, statewide,
                                                                      	// congressional, stateUpper, stateLower, countywide, judicial,
                                                                      	// schoolBoard, cityWide, township, countyCouncil, cityCouncil, ward,
                                                                      	// special
                                                                      	Scope string `json:"scope,omitempty"`
                                                                      
                                                                      	// ForceSendFields is a list of field names (e.g. "Id") 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:"-"`
                                                                      
                                                                      	// NullFields is a list of field names (e.g. "Id") to include in API
                                                                      	// requests with the JSON null value. By default, fields with empty
                                                                      	// values are omitted from API requests. However, any field with an
                                                                      	// empty value appearing in NullFields will be sent to the server as
                                                                      	// null. It is an error if a field in this list has a non-empty value.
                                                                      	// This may be used to include null fields in Patch requests.
                                                                      	NullFields []string `json:"-"`
                                                                      }

                                                                        ElectoralDistrict: Describes the geographic scope of a contest.

                                                                        func (*ElectoralDistrict) MarshalJSON

                                                                        func (s *ElectoralDistrict) MarshalJSON() ([]byte, error)

                                                                        type FieldMetadataProto

                                                                        type FieldMetadataProto struct {
                                                                        	Internal *InternalFieldMetadataProto `json:"internal,omitempty"`
                                                                        
                                                                        	// ForceSendFields is a list of field names (e.g. "Internal") 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:"-"`
                                                                        
                                                                        	// NullFields is a list of field names (e.g. "Internal") to include in
                                                                        	// API requests with the JSON null value. By default, fields with empty
                                                                        	// values are omitted from API requests. However, any field with an
                                                                        	// empty value appearing in NullFields will be sent to the server as
                                                                        	// null. It is an error if a field in this list has a non-empty value.
                                                                        	// This may be used to include null fields in Patch requests.
                                                                        	NullFields []string `json:"-"`
                                                                        }

                                                                        func (*FieldMetadataProto) MarshalJSON

                                                                        func (s *FieldMetadataProto) MarshalJSON() ([]byte, error)

                                                                        type GeographicDivision

                                                                        type GeographicDivision struct {
                                                                        	// AlsoKnownAs: Any other valid OCD IDs that refer to the same
                                                                        	// division.
                                                                        	//
                                                                        	// Because OCD IDs are meant to be human-readable and at least somewhat
                                                                        	// predictable, there are occasionally several identifiers for a single
                                                                        	// division. These identifiers are defined to be equivalent to one
                                                                        	// another, and one is always indicated as the primary identifier. The
                                                                        	// primary identifier will be returned in ocd_id above, and any other
                                                                        	// equivalent valid identifiers will be returned in this list.
                                                                        	//
                                                                        	// For example, if this division's OCD ID is
                                                                        	// ocd-division/country:us/district:dc, this will contain
                                                                        	// ocd-division/country:us/state:dc.
                                                                        	AlsoKnownAs []string `json:"alsoKnownAs,omitempty"`
                                                                        
                                                                        	// Name: The name of the division.
                                                                        	Name string `json:"name,omitempty"`
                                                                        
                                                                        	// OfficeIndices: List of indices in the offices array, one for each
                                                                        	// office elected from this division. Will only be present if
                                                                        	// includeOffices was true (or absent) in the request.
                                                                        	OfficeIndices []int64 `json:"officeIndices,omitempty"`
                                                                        
                                                                        	// ForceSendFields is a list of field names (e.g. "AlsoKnownAs") 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:"-"`
                                                                        
                                                                        	// NullFields is a list of field names (e.g. "AlsoKnownAs") to include
                                                                        	// in API requests with the JSON null value. By default, fields with
                                                                        	// empty values are omitted from API requests. However, any field with
                                                                        	// an empty value appearing in NullFields will be sent to the server as
                                                                        	// null. It is an error if a field in this list has a non-empty value.
                                                                        	// This may be used to include null fields in Patch requests.
                                                                        	NullFields []string `json:"-"`
                                                                        }

                                                                          GeographicDivision: Describes a political geography.

                                                                          func (*GeographicDivision) MarshalJSON

                                                                          func (s *GeographicDivision) MarshalJSON() ([]byte, error)

                                                                          type InternalFieldMetadataProto

                                                                          type InternalFieldMetadataProto struct {
                                                                          	IsAuto bool `json:"isAuto,omitempty"`
                                                                          
                                                                          	SourceSummary *InternalSourceSummaryProto `json:"sourceSummary,omitempty"`
                                                                          
                                                                          	// ForceSendFields is a list of field names (e.g. "IsAuto") 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:"-"`
                                                                          
                                                                          	// NullFields is a list of field names (e.g. "IsAuto") to include in API
                                                                          	// requests with the JSON null value. By default, fields with empty
                                                                          	// values are omitted from API requests. However, any field with an
                                                                          	// empty value appearing in NullFields will be sent to the server as
                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                          	// This may be used to include null fields in Patch requests.
                                                                          	NullFields []string `json:"-"`
                                                                          }

                                                                          func (*InternalFieldMetadataProto) MarshalJSON

                                                                          func (s *InternalFieldMetadataProto) MarshalJSON() ([]byte, error)

                                                                          type InternalSourceSummaryProto

                                                                          type InternalSourceSummaryProto struct {
                                                                          	Dataset string `json:"dataset,omitempty"`
                                                                          
                                                                          	Provider string `json:"provider,omitempty"`
                                                                          
                                                                          	// ForceSendFields is a list of field names (e.g. "Dataset") 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:"-"`
                                                                          
                                                                          	// NullFields is a list of field names (e.g. "Dataset") to include in
                                                                          	// API requests with the JSON null value. By default, fields with empty
                                                                          	// values are omitted from API requests. However, any field with an
                                                                          	// empty value appearing in NullFields will be sent to the server as
                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                          	// This may be used to include null fields in Patch requests.
                                                                          	NullFields []string `json:"-"`
                                                                          }

                                                                          func (*InternalSourceSummaryProto) MarshalJSON

                                                                          func (s *InternalSourceSummaryProto) MarshalJSON() ([]byte, error)

                                                                          type Office

                                                                          type Office struct {
                                                                          	// DivisionId: The OCD ID of the division with which this office is
                                                                          	// associated.
                                                                          	DivisionId string `json:"divisionId,omitempty"`
                                                                          
                                                                          	// Levels: The levels of government of which this office is part. There
                                                                          	// may be more than one in cases where a jurisdiction effectively acts
                                                                          	// at two different levels of government; for example, the mayor of the
                                                                          	// District of Columbia acts at "locality" level, but also effectively
                                                                          	// at both "administrative-area-2" and "administrative-area-1".
                                                                          	Levels []string `json:"levels,omitempty"`
                                                                          
                                                                          	// Name: The human-readable name of the office.
                                                                          	Name string `json:"name,omitempty"`
                                                                          
                                                                          	// OfficialIndices: List of indices in the officials array of people who
                                                                          	// presently hold this office.
                                                                          	OfficialIndices []int64 `json:"officialIndices,omitempty"`
                                                                          
                                                                          	// Roles: The roles which this office fulfills. Roles are not meant to
                                                                          	// be exhaustive, or to exactly specify the entire set of
                                                                          	// responsibilities of a given office, but are meant to be rough
                                                                          	// categories that are useful for general selection from or sorting of a
                                                                          	// list of offices.
                                                                          	Roles []string `json:"roles,omitempty"`
                                                                          
                                                                          	// Sources: A list of sources for this office. If multiple sources are
                                                                          	// listed, the data has been aggregated from those sources.
                                                                          	Sources []*Source `json:"sources,omitempty"`
                                                                          
                                                                          	// ForceSendFields is a list of field names (e.g. "DivisionId") 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:"-"`
                                                                          
                                                                          	// NullFields is a list of field names (e.g. "DivisionId") to include in
                                                                          	// API requests with the JSON null value. By default, fields with empty
                                                                          	// values are omitted from API requests. However, any field with an
                                                                          	// empty value appearing in NullFields will be sent to the server as
                                                                          	// null. It is an error if a field in this list has a non-empty value.
                                                                          	// This may be used to include null fields in Patch requests.
                                                                          	NullFields []string `json:"-"`
                                                                          }

                                                                            Office: Information about an Office held by one or more Officials.

                                                                            func (*Office) MarshalJSON

                                                                            func (s *Office) MarshalJSON() ([]byte, error)

                                                                            type Official

                                                                            type Official struct {
                                                                            	// Address: Addresses at which to contact the official.
                                                                            	Address []*SimpleAddressType `json:"address,omitempty"`
                                                                            
                                                                            	// Channels: A list of known (social) media channels for this official.
                                                                            	Channels []*Channel `json:"channels,omitempty"`
                                                                            
                                                                            	// Emails: The direct email addresses for the official.
                                                                            	Emails []string `json:"emails,omitempty"`
                                                                            
                                                                            	// Name: The official's name.
                                                                            	Name string `json:"name,omitempty"`
                                                                            
                                                                            	// Party: The full name of the party the official belongs to.
                                                                            	Party string `json:"party,omitempty"`
                                                                            
                                                                            	// Phones: The official's public contact phone numbers.
                                                                            	Phones []string `json:"phones,omitempty"`
                                                                            
                                                                            	// PhotoUrl: A URL for a photo of the official.
                                                                            	PhotoUrl string `json:"photoUrl,omitempty"`
                                                                            
                                                                            	// Urls: The official's public website URLs.
                                                                            	Urls []string `json:"urls,omitempty"`
                                                                            
                                                                            	// ForceSendFields is a list of field names (e.g. "Address") 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:"-"`
                                                                            
                                                                            	// NullFields is a list of field names (e.g. "Address") to include in
                                                                            	// API requests with the JSON null value. By default, fields with empty
                                                                            	// values are omitted from API requests. However, any field with an
                                                                            	// empty value appearing in NullFields will be sent to the server as
                                                                            	// null. It is an error if a field in this list has a non-empty value.
                                                                            	// This may be used to include null fields in Patch requests.
                                                                            	NullFields []string `json:"-"`
                                                                            }

                                                                              Official: Information about a person holding an elected office.

                                                                              func (*Official) MarshalJSON

                                                                              func (s *Official) MarshalJSON() ([]byte, error)

                                                                              type PointProto

                                                                              type PointProto struct {
                                                                              	LatE7 int64 `json:"latE7,omitempty"`
                                                                              
                                                                              	LngE7 int64 `json:"lngE7,omitempty"`
                                                                              
                                                                              	Metadata *FieldMetadataProto `json:"metadata,omitempty"`
                                                                              
                                                                              	// ForceSendFields is a list of field names (e.g. "LatE7") 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:"-"`
                                                                              
                                                                              	// NullFields is a list of field names (e.g. "LatE7") to include in API
                                                                              	// requests with the JSON null value. By default, fields with empty
                                                                              	// values are omitted from API requests. However, any field with an
                                                                              	// empty value appearing in NullFields will be sent to the server as
                                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                                              	// This may be used to include null fields in Patch requests.
                                                                              	NullFields []string `json:"-"`
                                                                              }

                                                                              func (*PointProto) MarshalJSON

                                                                              func (s *PointProto) MarshalJSON() ([]byte, error)

                                                                              type PollingLocation

                                                                              type PollingLocation struct {
                                                                              	// Address: The address of the location.
                                                                              	Address *SimpleAddressType `json:"address,omitempty"`
                                                                              
                                                                              	// EndDate: The last date that this early vote site or drop off location
                                                                              	// may be used. This field is not populated for polling locations.
                                                                              	EndDate string `json:"endDate,omitempty"`
                                                                              
                                                                              	// Id: An ID for this object. IDs may change in future requests and
                                                                              	// should not be cached. Access to this field requires special access
                                                                              	// that can be requested from the Request more link on the Quotas page.
                                                                              	Id string `json:"id,omitempty"`
                                                                              
                                                                              	// Latitude: Latitude of the location, in degrees north of the equator.
                                                                              	// Only some locations -- generally, ballot drop boxes for vote-by-mail
                                                                              	// elections -- will have this set; for others, use a geocoding service
                                                                              	// like the Google Maps API to resolve the address to a geographic
                                                                              	// point.
                                                                              	Latitude float64 `json:"latitude,omitempty"`
                                                                              
                                                                              	// Longitude: Longitude of the location, in degrees east of the Prime
                                                                              	// Meridian. Only some locations -- generally, ballot drop boxes for
                                                                              	// vote-by-mail elections -- will have this set; for others, use a
                                                                              	// geocoding service like the Google Maps API to resolve the address to
                                                                              	// a geographic point.
                                                                              	Longitude float64 `json:"longitude,omitempty"`
                                                                              
                                                                              	// Name: The name of the early vote site or drop off location. This
                                                                              	// field is not populated for polling locations.
                                                                              	Name string `json:"name,omitempty"`
                                                                              
                                                                              	// Notes: Notes about this location (e.g. accessibility ramp or entrance
                                                                              	// to use).
                                                                              	Notes string `json:"notes,omitempty"`
                                                                              
                                                                              	// PollingHours: A description of when this location is open.
                                                                              	PollingHours string `json:"pollingHours,omitempty"`
                                                                              
                                                                              	// Sources: A list of sources for this location. If multiple sources are
                                                                              	// listed the data has been aggregated from those sources.
                                                                              	Sources []*Source `json:"sources,omitempty"`
                                                                              
                                                                              	// StartDate: The first date that this early vote site or drop off
                                                                              	// location may be used. This field is not populated for polling
                                                                              	// locations.
                                                                              	StartDate string `json:"startDate,omitempty"`
                                                                              
                                                                              	// VoterServices: The services provided by this early vote site or drop
                                                                              	// off location. This field is not populated for polling locations.
                                                                              	VoterServices string `json:"voterServices,omitempty"`
                                                                              
                                                                              	// ForceSendFields is a list of field names (e.g. "Address") 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:"-"`
                                                                              
                                                                              	// NullFields is a list of field names (e.g. "Address") to include in
                                                                              	// API requests with the JSON null value. By default, fields with empty
                                                                              	// values are omitted from API requests. However, any field with an
                                                                              	// empty value appearing in NullFields will be sent to the server as
                                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                                              	// This may be used to include null fields in Patch requests.
                                                                              	NullFields []string `json:"-"`
                                                                              }

                                                                                PollingLocation: A location where a voter can vote. This may be an early vote site, an election day voting location, or a drop off location for a completed ballot.

                                                                                func (*PollingLocation) MarshalJSON

                                                                                func (s *PollingLocation) MarshalJSON() ([]byte, error)

                                                                                func (*PollingLocation) UnmarshalJSON

                                                                                func (s *PollingLocation) UnmarshalJSON(data []byte) error

                                                                                type PostalAddress

                                                                                type PostalAddress struct {
                                                                                	AddressLines []string `json:"addressLines,omitempty"`
                                                                                
                                                                                	AdministrativeAreaName string `json:"administrativeAreaName,omitempty"`
                                                                                
                                                                                	CountryName string `json:"countryName,omitempty"`
                                                                                
                                                                                	CountryNameCode string `json:"countryNameCode,omitempty"`
                                                                                
                                                                                	DependentLocalityName string `json:"dependentLocalityName,omitempty"`
                                                                                
                                                                                	DependentThoroughfareName string `json:"dependentThoroughfareName,omitempty"`
                                                                                
                                                                                	FirmName string `json:"firmName,omitempty"`
                                                                                
                                                                                	IsDisputed bool `json:"isDisputed,omitempty"`
                                                                                
                                                                                	LanguageCode string `json:"languageCode,omitempty"`
                                                                                
                                                                                	LocalityName string `json:"localityName,omitempty"`
                                                                                
                                                                                	PostBoxNumber string `json:"postBoxNumber,omitempty"`
                                                                                
                                                                                	PostalCodeNumber string `json:"postalCodeNumber,omitempty"`
                                                                                
                                                                                	PostalCodeNumberExtension string `json:"postalCodeNumberExtension,omitempty"`
                                                                                
                                                                                	PremiseName string `json:"premiseName,omitempty"`
                                                                                
                                                                                	RecipientName string `json:"recipientName,omitempty"`
                                                                                
                                                                                	SortingCode string `json:"sortingCode,omitempty"`
                                                                                
                                                                                	SubAdministrativeAreaName string `json:"subAdministrativeAreaName,omitempty"`
                                                                                
                                                                                	SubPremiseName string `json:"subPremiseName,omitempty"`
                                                                                
                                                                                	ThoroughfareName string `json:"thoroughfareName,omitempty"`
                                                                                
                                                                                	ThoroughfareNumber string `json:"thoroughfareNumber,omitempty"`
                                                                                
                                                                                	// ForceSendFields is a list of field names (e.g. "AddressLines") 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:"-"`
                                                                                
                                                                                	// NullFields is a list of field names (e.g. "AddressLines") to include
                                                                                	// in API requests with the JSON null value. By default, fields with
                                                                                	// empty values are omitted from API requests. However, any field with
                                                                                	// an empty value appearing in NullFields will be sent to the server as
                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                	// This may be used to include null fields in Patch requests.
                                                                                	NullFields []string `json:"-"`
                                                                                }

                                                                                func (*PostalAddress) MarshalJSON

                                                                                func (s *PostalAddress) MarshalJSON() ([]byte, error)

                                                                                type Provenance

                                                                                type Provenance struct {
                                                                                	CollidedSegmentSource *StreetSegmentList `json:"collidedSegmentSource,omitempty"`
                                                                                
                                                                                	CtclContestUuid string `json:"ctclContestUuid,omitempty"`
                                                                                
                                                                                	CtclOfficeUuid string `json:"ctclOfficeUuid,omitempty"`
                                                                                
                                                                                	DatasetId int64 `json:"datasetId,omitempty,string"`
                                                                                
                                                                                	PrecinctId int64 `json:"precinctId,omitempty,string"`
                                                                                
                                                                                	PrecinctSplitId int64 `json:"precinctSplitId,omitempty,string"`
                                                                                
                                                                                	TsStreetSegmentId string `json:"tsStreetSegmentId,omitempty"`
                                                                                
                                                                                	Vip5PrecinctId string `json:"vip5PrecinctId,omitempty"`
                                                                                
                                                                                	Vip5StreetSegmentId string `json:"vip5StreetSegmentId,omitempty"`
                                                                                
                                                                                	VipStreetSegmentId int64 `json:"vipStreetSegmentId,omitempty,string"`
                                                                                
                                                                                	// ForceSendFields is a list of field names (e.g.
                                                                                	// "CollidedSegmentSource") 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:"-"`
                                                                                
                                                                                	// NullFields is a list of field names (e.g. "CollidedSegmentSource") to
                                                                                	// include in API requests with the JSON null value. By default, fields
                                                                                	// with empty values are omitted from API requests. However, any field
                                                                                	// with an empty value appearing in NullFields will be sent to the
                                                                                	// server as null. It is an error if a field in this list has a
                                                                                	// non-empty value. This may be used to include null fields in Patch
                                                                                	// requests.
                                                                                	NullFields []string `json:"-"`
                                                                                }

                                                                                func (*Provenance) MarshalJSON

                                                                                func (s *Provenance) MarshalJSON() ([]byte, error)

                                                                                type RepresentativeInfoData

                                                                                type RepresentativeInfoData struct {
                                                                                	// Divisions: Political geographic divisions that contain the requested
                                                                                	// address.
                                                                                	Divisions map[string]GeographicDivision `json:"divisions,omitempty"`
                                                                                
                                                                                	// Offices: Elected offices referenced by the divisions listed above.
                                                                                	// Will only be present if includeOffices was true in the request.
                                                                                	Offices []*Office `json:"offices,omitempty"`
                                                                                
                                                                                	// Officials: Officials holding the offices listed above. Will only be
                                                                                	// present if includeOffices was true in the request.
                                                                                	Officials []*Official `json:"officials,omitempty"`
                                                                                
                                                                                	// ServerResponse contains the HTTP response code and headers from the
                                                                                	// server.
                                                                                	googleapi.ServerResponse `json:"-"`
                                                                                
                                                                                	// ForceSendFields is a list of field names (e.g. "Divisions") 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:"-"`
                                                                                
                                                                                	// NullFields is a list of field names (e.g. "Divisions") to include in
                                                                                	// API requests with the JSON null value. By default, fields with empty
                                                                                	// values are omitted from API requests. However, any field with an
                                                                                	// empty value appearing in NullFields will be sent to the server as
                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                	// This may be used to include null fields in Patch requests.
                                                                                	NullFields []string `json:"-"`
                                                                                }

                                                                                func (*RepresentativeInfoData) MarshalJSON

                                                                                func (s *RepresentativeInfoData) MarshalJSON() ([]byte, error)

                                                                                type RepresentativeInfoRequest

                                                                                type RepresentativeInfoRequest struct {
                                                                                	ContextParams *ContextParams `json:"contextParams,omitempty"`
                                                                                
                                                                                	// ForceSendFields is a list of field names (e.g. "ContextParams") 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:"-"`
                                                                                
                                                                                	// NullFields is a list of field names (e.g. "ContextParams") to include
                                                                                	// in API requests with the JSON null value. By default, fields with
                                                                                	// empty values are omitted from API requests. However, any field with
                                                                                	// an empty value appearing in NullFields will be sent to the server as
                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                	// This may be used to include null fields in Patch requests.
                                                                                	NullFields []string `json:"-"`
                                                                                }

                                                                                  RepresentativeInfoRequest: A request for political geography and representative information for an address.

                                                                                  func (*RepresentativeInfoRequest) MarshalJSON

                                                                                  func (s *RepresentativeInfoRequest) MarshalJSON() ([]byte, error)

                                                                                  type RepresentativeInfoResponse

                                                                                  type RepresentativeInfoResponse struct {
                                                                                  	// Divisions: Political geographic divisions that contain the requested
                                                                                  	// address.
                                                                                  	Divisions map[string]GeographicDivision `json:"divisions,omitempty"`
                                                                                  
                                                                                  	// Kind: Identifies what kind of resource this is. Value: the fixed
                                                                                  	// string "civicinfo#representativeInfoResponse".
                                                                                  	Kind string `json:"kind,omitempty"`
                                                                                  
                                                                                  	// NormalizedInput: The normalized version of the requested address
                                                                                  	NormalizedInput *SimpleAddressType `json:"normalizedInput,omitempty"`
                                                                                  
                                                                                  	// Offices: Elected offices referenced by the divisions listed above.
                                                                                  	// Will only be present if includeOffices was true in the request.
                                                                                  	Offices []*Office `json:"offices,omitempty"`
                                                                                  
                                                                                  	// Officials: Officials holding the offices listed above. Will only be
                                                                                  	// present if includeOffices was true in the request.
                                                                                  	Officials []*Official `json:"officials,omitempty"`
                                                                                  
                                                                                  	// ServerResponse contains the HTTP response code and headers from the
                                                                                  	// server.
                                                                                  	googleapi.ServerResponse `json:"-"`
                                                                                  
                                                                                  	// ForceSendFields is a list of field names (e.g. "Divisions") 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:"-"`
                                                                                  
                                                                                  	// NullFields is a list of field names (e.g. "Divisions") to include in
                                                                                  	// API requests with the JSON null value. By default, fields with empty
                                                                                  	// values are omitted from API requests. However, any field with an
                                                                                  	// empty value appearing in NullFields will be sent to the server as
                                                                                  	// null. It is an error if a field in this list has a non-empty value.
                                                                                  	// This may be used to include null fields in Patch requests.
                                                                                  	NullFields []string `json:"-"`
                                                                                  }

                                                                                    RepresentativeInfoResponse: The result of a representative info lookup query.

                                                                                    func (*RepresentativeInfoResponse) MarshalJSON

                                                                                    func (s *RepresentativeInfoResponse) MarshalJSON() ([]byte, error)

                                                                                    type RepresentativesRepresentativeInfoByAddressCall

                                                                                    type RepresentativesRepresentativeInfoByAddressCall struct {
                                                                                    	// contains filtered or unexported fields
                                                                                    }

                                                                                    func (*RepresentativesRepresentativeInfoByAddressCall) Address

                                                                                      Address sets the optional parameter "address": The address to look up. May only be specified if the field ocdId is not given in the URL.

                                                                                      func (*RepresentativesRepresentativeInfoByAddressCall) Context

                                                                                        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 (*RepresentativesRepresentativeInfoByAddressCall) Do

                                                                                          Do executes the "civicinfo.representatives.representativeInfoByAddress" call. Exactly one of *RepresentativeInfoResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *RepresentativeInfoResponse.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 (*RepresentativesRepresentativeInfoByAddressCall) Fields

                                                                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                            func (*RepresentativesRepresentativeInfoByAddressCall) Header

                                                                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                              func (*RepresentativesRepresentativeInfoByAddressCall) IfNoneMatch

                                                                                                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 (*RepresentativesRepresentativeInfoByAddressCall) IncludeOffices

                                                                                                  IncludeOffices sets the optional parameter "includeOffices": Whether to return information about offices and officials. If false, only the top-level district information will be returned.

                                                                                                  func (*RepresentativesRepresentativeInfoByAddressCall) Levels

                                                                                                    Levels sets the optional parameter "levels": A list of office levels to filter by. Only offices that serve at least one of these levels will be returned. Divisions that don't contain a matching office will not be returned.

                                                                                                    Possible values:

                                                                                                    "administrativeArea1"
                                                                                                    "administrativeArea2"
                                                                                                    "country"
                                                                                                    "international"
                                                                                                    "locality"
                                                                                                    "regional"
                                                                                                    "special"
                                                                                                    "subLocality1"
                                                                                                    "subLocality2"
                                                                                                    

                                                                                                    func (*RepresentativesRepresentativeInfoByAddressCall) Roles

                                                                                                      Roles sets the optional parameter "roles": A list of office roles to filter by. Only offices fulfilling one of these roles will be returned. Divisions that don't contain a matching office will not be returned.

                                                                                                      Possible values:

                                                                                                      "deputyHeadOfGovernment"
                                                                                                      "executiveCouncil"
                                                                                                      "governmentOfficer"
                                                                                                      "headOfGovernment"
                                                                                                      "headOfState"
                                                                                                      "highestCourtJudge"
                                                                                                      "judge"
                                                                                                      "legislatorLowerBody"
                                                                                                      "legislatorUpperBody"
                                                                                                      "schoolBoard"
                                                                                                      "specialPurposeOfficer"
                                                                                                      

                                                                                                      type RepresentativesRepresentativeInfoByDivisionCall

                                                                                                      type RepresentativesRepresentativeInfoByDivisionCall struct {
                                                                                                      	// contains filtered or unexported fields
                                                                                                      }

                                                                                                      func (*RepresentativesRepresentativeInfoByDivisionCall) Context

                                                                                                        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 (*RepresentativesRepresentativeInfoByDivisionCall) Do

                                                                                                          Do executes the "civicinfo.representatives.representativeInfoByDivision" call. Exactly one of *RepresentativeInfoData or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *RepresentativeInfoData.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 (*RepresentativesRepresentativeInfoByDivisionCall) Fields

                                                                                                            Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.

                                                                                                            func (*RepresentativesRepresentativeInfoByDivisionCall) Header

                                                                                                              Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.

                                                                                                              func (*RepresentativesRepresentativeInfoByDivisionCall) IfNoneMatch

                                                                                                                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 (*RepresentativesRepresentativeInfoByDivisionCall) Levels

                                                                                                                  Levels sets the optional parameter "levels": A list of office levels to filter by. Only offices that serve at least one of these levels will be returned. Divisions that don't contain a matching office will not be returned.

                                                                                                                  Possible values:

                                                                                                                  "administrativeArea1"
                                                                                                                  "administrativeArea2"
                                                                                                                  "country"
                                                                                                                  "international"
                                                                                                                  "locality"
                                                                                                                  "regional"
                                                                                                                  "special"
                                                                                                                  "subLocality1"
                                                                                                                  "subLocality2"
                                                                                                                  

                                                                                                                  func (*RepresentativesRepresentativeInfoByDivisionCall) Recursive

                                                                                                                    Recursive sets the optional parameter "recursive": If true, information about all divisions contained in the division requested will be included as well. For example, if querying ocd-division/country:us/district:dc, this would also return all DC's wards and ANCs.

                                                                                                                    func (*RepresentativesRepresentativeInfoByDivisionCall) Roles

                                                                                                                      Roles sets the optional parameter "roles": A list of office roles to filter by. Only offices fulfilling one of these roles will be returned. Divisions that don't contain a matching office will not be returned.

                                                                                                                      Possible values:

                                                                                                                      "deputyHeadOfGovernment"
                                                                                                                      "executiveCouncil"
                                                                                                                      "governmentOfficer"
                                                                                                                      "headOfGovernment"
                                                                                                                      "headOfState"
                                                                                                                      "highestCourtJudge"
                                                                                                                      "judge"
                                                                                                                      "legislatorLowerBody"
                                                                                                                      "legislatorUpperBody"
                                                                                                                      "schoolBoard"
                                                                                                                      "specialPurposeOfficer"
                                                                                                                      

                                                                                                                      type RepresentativesService

                                                                                                                      type RepresentativesService struct {
                                                                                                                      	// contains filtered or unexported fields
                                                                                                                      }

                                                                                                                      func NewRepresentativesService

                                                                                                                      func NewRepresentativesService(s *Service) *RepresentativesService

                                                                                                                      func (*RepresentativesService) RepresentativeInfoByAddress

                                                                                                                      func (r *RepresentativesService) RepresentativeInfoByAddress(representativeinforequest *RepresentativeInfoRequest) *RepresentativesRepresentativeInfoByAddressCall

                                                                                                                        RepresentativeInfoByAddress: Looks up political geography and representative information for a single address.

                                                                                                                        func (*RepresentativesService) RepresentativeInfoByDivision

                                                                                                                        func (r *RepresentativesService) RepresentativeInfoByDivision(ocdId string, divisionrepresentativeinforequest *DivisionRepresentativeInfoRequest) *RepresentativesRepresentativeInfoByDivisionCall

                                                                                                                          RepresentativeInfoByDivision: Looks up representative information for a single geographic division.

                                                                                                                          type Service

                                                                                                                          type Service struct {
                                                                                                                          	BasePath  string // API endpoint base URL
                                                                                                                          	UserAgent string // optional additional User-Agent fragment
                                                                                                                          
                                                                                                                          	Divisions *DivisionsService
                                                                                                                          
                                                                                                                          	Elections *ElectionsService
                                                                                                                          
                                                                                                                          	Representatives *RepresentativesService
                                                                                                                          	// contains filtered or unexported fields
                                                                                                                          }

                                                                                                                          func New

                                                                                                                          func New(client *http.Client) (*Service, error)

                                                                                                                            New creates a new Service. It uses the provided http.Client for requests.

                                                                                                                            Deprecated: please use NewService instead. To provide a custom HTTP client, use option.WithHTTPClient. If you are using google.golang.org/api/googleapis/transport.APIKey, use option.WithAPIKey with NewService instead.

                                                                                                                            func NewService

                                                                                                                            func NewService(ctx context.Context, opts ...option.ClientOption) (*Service, error)

                                                                                                                              NewService creates a new Service.

                                                                                                                              type SimpleAddressType

                                                                                                                              type SimpleAddressType struct {
                                                                                                                              	// City: The city or town for the address.
                                                                                                                              	City string `json:"city,omitempty"`
                                                                                                                              
                                                                                                                              	// Line1: The street name and number of this address.
                                                                                                                              	Line1 string `json:"line1,omitempty"`
                                                                                                                              
                                                                                                                              	// Line2: The second line the address, if needed.
                                                                                                                              	Line2 string `json:"line2,omitempty"`
                                                                                                                              
                                                                                                                              	// Line3: The third line of the address, if needed.
                                                                                                                              	Line3 string `json:"line3,omitempty"`
                                                                                                                              
                                                                                                                              	// LocationName: The name of the location.
                                                                                                                              	LocationName string `json:"locationName,omitempty"`
                                                                                                                              
                                                                                                                              	// State: The US two letter state abbreviation of the address.
                                                                                                                              	State string `json:"state,omitempty"`
                                                                                                                              
                                                                                                                              	// Zip: The US Postal Zip Code of the address.
                                                                                                                              	Zip string `json:"zip,omitempty"`
                                                                                                                              
                                                                                                                              	// ForceSendFields is a list of field names (e.g. "City") 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:"-"`
                                                                                                                              
                                                                                                                              	// NullFields is a list of field names (e.g. "City") to include in API
                                                                                                                              	// requests with the JSON null value. By default, fields with empty
                                                                                                                              	// values are omitted from API requests. However, any field with an
                                                                                                                              	// empty value appearing in NullFields will be sent to the server as
                                                                                                                              	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                              	// This may be used to include null fields in Patch requests.
                                                                                                                              	NullFields []string `json:"-"`
                                                                                                                              }

                                                                                                                                SimpleAddressType: A simple representation of an address.

                                                                                                                                func (*SimpleAddressType) MarshalJSON

                                                                                                                                func (s *SimpleAddressType) MarshalJSON() ([]byte, error)

                                                                                                                                type Source

                                                                                                                                type Source struct {
                                                                                                                                	// Name: The name of the data source.
                                                                                                                                	Name string `json:"name,omitempty"`
                                                                                                                                
                                                                                                                                	// Official: Whether this data comes from an official government source.
                                                                                                                                	Official bool `json:"official,omitempty"`
                                                                                                                                
                                                                                                                                	// ForceSendFields is a list of field names (e.g. "Name") 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:"-"`
                                                                                                                                
                                                                                                                                	// NullFields is a list of field names (e.g. "Name") to include in API
                                                                                                                                	// requests with the JSON null value. By default, fields with empty
                                                                                                                                	// values are omitted from API requests. However, any field with an
                                                                                                                                	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                	// This may be used to include null fields in Patch requests.
                                                                                                                                	NullFields []string `json:"-"`
                                                                                                                                }

                                                                                                                                  Source: Contains information about the data source for the element containing it.

                                                                                                                                  func (*Source) MarshalJSON

                                                                                                                                  func (s *Source) MarshalJSON() ([]byte, error)

                                                                                                                                  type StreetSegment

                                                                                                                                  type StreetSegment struct {
                                                                                                                                  	AdministrationRegionIds []string `json:"administrationRegionIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	BeforeGeocodeId string `json:"beforeGeocodeId,omitempty"`
                                                                                                                                  
                                                                                                                                  	CatalistUniquePrecinctCode string `json:"catalistUniquePrecinctCode,omitempty"`
                                                                                                                                  
                                                                                                                                  	City string `json:"city,omitempty"`
                                                                                                                                  
                                                                                                                                  	CityCouncilDistrict string `json:"cityCouncilDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	CongressionalDistrict string `json:"congressionalDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	ContestIds []string `json:"contestIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	CountyCouncilDistrict string `json:"countyCouncilDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	CountyFips string `json:"countyFips,omitempty"`
                                                                                                                                  
                                                                                                                                  	DatasetId int64 `json:"datasetId,omitempty,string"`
                                                                                                                                  
                                                                                                                                  	EarlyVoteSiteByIds []string `json:"earlyVoteSiteByIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	EndHouseNumber int64 `json:"endHouseNumber,omitempty,string"`
                                                                                                                                  
                                                                                                                                  	GeocodedPoint *PointProto `json:"geocodedPoint,omitempty"`
                                                                                                                                  
                                                                                                                                  	GeographicDivisionOcdIds []string `json:"geographicDivisionOcdIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	Id string `json:"id,omitempty"`
                                                                                                                                  
                                                                                                                                  	JudicialDistrict string `json:"judicialDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	MailOnly bool `json:"mailOnly,omitempty"`
                                                                                                                                  
                                                                                                                                  	MunicipalDistrict string `json:"municipalDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	NcoaAddress string `json:"ncoaAddress,omitempty"`
                                                                                                                                  
                                                                                                                                  	OddOrEvens []string `json:"oddOrEvens,omitempty"`
                                                                                                                                  
                                                                                                                                  	OriginalId string `json:"originalId,omitempty"`
                                                                                                                                  
                                                                                                                                  	PollinglocationByIds []string `json:"pollinglocationByIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	PrecinctName string `json:"precinctName,omitempty"`
                                                                                                                                  
                                                                                                                                  	PrecinctOcdId string `json:"precinctOcdId,omitempty"`
                                                                                                                                  
                                                                                                                                  	Provenances []*Provenance `json:"provenances,omitempty"`
                                                                                                                                  
                                                                                                                                  	Published bool `json:"published,omitempty"`
                                                                                                                                  
                                                                                                                                  	SchoolDistrict string `json:"schoolDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	StartHouseNumber int64 `json:"startHouseNumber,omitempty,string"`
                                                                                                                                  
                                                                                                                                  	StartLatE7 int64 `json:"startLatE7,omitempty"`
                                                                                                                                  
                                                                                                                                  	StartLngE7 int64 `json:"startLngE7,omitempty"`
                                                                                                                                  
                                                                                                                                  	State string `json:"state,omitempty"`
                                                                                                                                  
                                                                                                                                  	StateHouseDistrict string `json:"stateHouseDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	StateSenateDistrict string `json:"stateSenateDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	StreetName string `json:"streetName,omitempty"`
                                                                                                                                  
                                                                                                                                  	SubAdministrativeAreaName string `json:"subAdministrativeAreaName,omitempty"`
                                                                                                                                  
                                                                                                                                  	SurrogateId int64 `json:"surrogateId,omitempty,string"`
                                                                                                                                  
                                                                                                                                  	TargetsmartUniquePrecinctCode string `json:"targetsmartUniquePrecinctCode,omitempty"`
                                                                                                                                  
                                                                                                                                  	TownshipDistrict string `json:"townshipDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	UnitNumber string `json:"unitNumber,omitempty"`
                                                                                                                                  
                                                                                                                                  	UnitType string `json:"unitType,omitempty"`
                                                                                                                                  
                                                                                                                                  	VanPrecinctCode string `json:"vanPrecinctCode,omitempty"`
                                                                                                                                  
                                                                                                                                  	VoterGeographicDivisionOcdIds []string `json:"voterGeographicDivisionOcdIds,omitempty"`
                                                                                                                                  
                                                                                                                                  	WardDistrict string `json:"wardDistrict,omitempty"`
                                                                                                                                  
                                                                                                                                  	Wildcard bool `json:"wildcard,omitempty"`
                                                                                                                                  
                                                                                                                                  	Zip string `json:"zip,omitempty"`
                                                                                                                                  
                                                                                                                                  	// ForceSendFields is a list of field names (e.g.
                                                                                                                                  	// "AdministrationRegionIds") 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:"-"`
                                                                                                                                  
                                                                                                                                  	// NullFields is a list of field names (e.g. "AdministrationRegionIds")
                                                                                                                                  	// to include in API requests with the JSON null value. By default,
                                                                                                                                  	// fields with empty values are omitted from API requests. However, any
                                                                                                                                  	// field with an empty value appearing in NullFields will be sent to the
                                                                                                                                  	// server as null. It is an error if a field in this list has a
                                                                                                                                  	// non-empty value. This may be used to include null fields in Patch
                                                                                                                                  	// requests.
                                                                                                                                  	NullFields []string `json:"-"`
                                                                                                                                  }

                                                                                                                                  func (*StreetSegment) MarshalJSON

                                                                                                                                  func (s *StreetSegment) MarshalJSON() ([]byte, error)

                                                                                                                                  type StreetSegmentList

                                                                                                                                  type StreetSegmentList struct {
                                                                                                                                  	Segments []*StreetSegment `json:"segments,omitempty"`
                                                                                                                                  
                                                                                                                                  	// ForceSendFields is a list of field names (e.g. "Segments") 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:"-"`
                                                                                                                                  
                                                                                                                                  	// NullFields is a list of field names (e.g. "Segments") to include in
                                                                                                                                  	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                  	// values are omitted from API requests. However, any field with an
                                                                                                                                  	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                  	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                  	// This may be used to include null fields in Patch requests.
                                                                                                                                  	NullFields []string `json:"-"`
                                                                                                                                  }

                                                                                                                                  func (*StreetSegmentList) MarshalJSON

                                                                                                                                  func (s *StreetSegmentList) MarshalJSON() ([]byte, error)

                                                                                                                                  type VoterInfoRequest

                                                                                                                                  type VoterInfoRequest struct {
                                                                                                                                  	ContextParams *ContextParams `json:"contextParams,omitempty"`
                                                                                                                                  
                                                                                                                                  	VoterInfoSegmentResult *VoterInfoSegmentResult `json:"voterInfoSegmentResult,omitempty"`
                                                                                                                                  
                                                                                                                                  	// ForceSendFields is a list of field names (e.g. "ContextParams") 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:"-"`
                                                                                                                                  
                                                                                                                                  	// NullFields is a list of field names (e.g. "ContextParams") to include
                                                                                                                                  	// in API requests with the JSON null value. By default, fields with
                                                                                                                                  	// empty values are omitted from API requests. However, any field with
                                                                                                                                  	// an empty value appearing in NullFields will be sent to the server as
                                                                                                                                  	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                  	// This may be used to include null fields in Patch requests.
                                                                                                                                  	NullFields []string `json:"-"`
                                                                                                                                  }

                                                                                                                                    VoterInfoRequest: A request for information about a voter.

                                                                                                                                    func (*VoterInfoRequest) MarshalJSON

                                                                                                                                    func (s *VoterInfoRequest) MarshalJSON() ([]byte, error)

                                                                                                                                    type VoterInfoResponse

                                                                                                                                    type VoterInfoResponse struct {
                                                                                                                                    	// Contests: Contests that will appear on the voter's ballot.
                                                                                                                                    	Contests []*Contest `json:"contests,omitempty"`
                                                                                                                                    
                                                                                                                                    	// DropOffLocations: Locations where a voter is eligible to drop off a
                                                                                                                                    	// completed ballot. The voter must have received and completed a ballot
                                                                                                                                    	// prior to arriving at the location. The location may not have ballots
                                                                                                                                    	// available on the premises. These locations could be open on or before
                                                                                                                                    	// election day as indicated in the pollingHours field.
                                                                                                                                    	DropOffLocations []*PollingLocation `json:"dropOffLocations,omitempty"`
                                                                                                                                    
                                                                                                                                    	// EarlyVoteSites: Locations where the voter is eligible to vote early,
                                                                                                                                    	// prior to election day.
                                                                                                                                    	EarlyVoteSites []*PollingLocation `json:"earlyVoteSites,omitempty"`
                                                                                                                                    
                                                                                                                                    	// Election: The election that was queried.
                                                                                                                                    	Election *Election `json:"election,omitempty"`
                                                                                                                                    
                                                                                                                                    	// Kind: Identifies what kind of resource this is. Value: the fixed
                                                                                                                                    	// string "civicinfo#voterInfoResponse".
                                                                                                                                    	Kind string `json:"kind,omitempty"`
                                                                                                                                    
                                                                                                                                    	// MailOnly: Specifies whether voters in the precinct vote only by
                                                                                                                                    	// mailing their ballots (with the possible option of dropping off their
                                                                                                                                    	// ballots as well).
                                                                                                                                    	MailOnly bool `json:"mailOnly,omitempty"`
                                                                                                                                    
                                                                                                                                    	// NormalizedInput: The normalized version of the requested address
                                                                                                                                    	NormalizedInput *SimpleAddressType `json:"normalizedInput,omitempty"`
                                                                                                                                    
                                                                                                                                    	// OtherElections: When there are multiple elections for a voter
                                                                                                                                    	// address, the otherElections field is populated in the API response
                                                                                                                                    	// and there are two possibilities: 1. If the earliest election is not
                                                                                                                                    	// the intended election, specify the election ID of the desired
                                                                                                                                    	// election in a second API request using the electionId field. 2. If
                                                                                                                                    	// these elections occur on the same day, the API doesn?t return any
                                                                                                                                    	// polling location, contest, or election official information to ensure
                                                                                                                                    	// that an additional query is made. For user-facing applications, we
                                                                                                                                    	// recommend displaying these elections to the user to disambiguate. A
                                                                                                                                    	// second API request using the electionId field should be made for the
                                                                                                                                    	// election that is relevant to the user.
                                                                                                                                    	OtherElections []*Election `json:"otherElections,omitempty"`
                                                                                                                                    
                                                                                                                                    	// PollingLocations: Locations where the voter is eligible to vote on
                                                                                                                                    	// election day.
                                                                                                                                    	PollingLocations []*PollingLocation `json:"pollingLocations,omitempty"`
                                                                                                                                    
                                                                                                                                    	PrecinctId string `json:"precinctId,omitempty"`
                                                                                                                                    
                                                                                                                                    	Segments []*StreetSegment `json:"segments,omitempty"`
                                                                                                                                    
                                                                                                                                    	// State: Local Election Information for the state that the voter votes
                                                                                                                                    	// in. For the US, there will only be one element in this array.
                                                                                                                                    	State []*AdministrationRegion `json:"state,omitempty"`
                                                                                                                                    
                                                                                                                                    	// ServerResponse contains the HTTP response code and headers from the
                                                                                                                                    	// server.
                                                                                                                                    	googleapi.ServerResponse `json:"-"`
                                                                                                                                    
                                                                                                                                    	// ForceSendFields is a list of field names (e.g. "Contests") 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:"-"`
                                                                                                                                    
                                                                                                                                    	// NullFields is a list of field names (e.g. "Contests") to include in
                                                                                                                                    	// API requests with the JSON null value. By default, fields with empty
                                                                                                                                    	// values are omitted from API requests. However, any field with an
                                                                                                                                    	// empty value appearing in NullFields will be sent to the server as
                                                                                                                                    	// null. It is an error if a field in this list has a non-empty value.
                                                                                                                                    	// This may be used to include null fields in Patch requests.
                                                                                                                                    	NullFields []string `json:"-"`
                                                                                                                                    }

                                                                                                                                      VoterInfoResponse: The result of a voter info lookup query.

                                                                                                                                      func (*VoterInfoResponse) MarshalJSON

                                                                                                                                      func (s *VoterInfoResponse) MarshalJSON() ([]byte, error)

                                                                                                                                      type VoterInfoSegmentResult

                                                                                                                                      type VoterInfoSegmentResult struct {
                                                                                                                                      	GeneratedMillis int64 `json:"generatedMillis,omitempty,string"`
                                                                                                                                      
                                                                                                                                      	PostalAddress *PostalAddress `json:"postalAddress,omitempty"`
                                                                                                                                      
                                                                                                                                      	Request *VoterInfoRequest `json:"request,omitempty"`
                                                                                                                                      
                                                                                                                                      	Response *VoterInfoResponse `json:"response,omitempty"`
                                                                                                                                      
                                                                                                                                      	// ForceSendFields is a list of field names (e.g. "GeneratedMillis") 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:"-"`
                                                                                                                                      
                                                                                                                                      	// NullFields is a list of field names (e.g. "GeneratedMillis") to
                                                                                                                                      	// include in API requests with the JSON null value. By default, fields
                                                                                                                                      	// with empty values are omitted from API requests. However, any field
                                                                                                                                      	// with an empty value appearing in NullFields will be sent to the
                                                                                                                                      	// server as null. It is an error if a field in this list has a
                                                                                                                                      	// non-empty value. This may be used to include null fields in Patch
                                                                                                                                      	// requests.
                                                                                                                                      	NullFields []string `json:"-"`
                                                                                                                                      }

                                                                                                                                      func (*VoterInfoSegmentResult) MarshalJSON

                                                                                                                                      func (s *VoterInfoSegmentResult) MarshalJSON() ([]byte, error)