Documentation ¶
Overview ¶
Package firebaseml provides access to the Firebase ML API.
For product documentation, see: https://firebase.google.com
Library status ¶
These client libraries are officially supported by Google. However, this library is considered complete and is in maintenance mode. This means that we will address critical bugs and security issues but will not add any new features.
When possible, we recommend using our newer [Cloud Client Libraries for Go](https://pkg.go.dev/cloud.google.com/go) that are still actively being worked and iterated on.
Creating a client ¶
Usage example:
import "google.golang.org/api/firebaseml/v2beta" ... ctx := context.Background() firebasemlService, err := firebaseml.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 google.golang.org/api/option.WithAPIKey:
firebasemlService, err := firebaseml.NewService(ctx, option.WithAPIKey("AIza..."))
To use an OAuth token (e.g., a user token obtained via a three-legged OAuth flow, use google.golang.org/api/option.WithTokenSource:
config := &oauth2.Config{...} // ... token, err := config.Exchange(ctx, ...) firebasemlService, err := firebaseml.NewService(ctx, option.WithTokenSource(config.TokenSource(ctx, token)))
See google.golang.org/api/option.ClientOption for details on options.
Index ¶
- Constants
- type Blob
- type Candidate
- type Citation
- type CitationMetadata
- type Content
- type CountTokensRequest
- type CountTokensResponse
- type Date
- type FileData
- type FunctionCall
- type FunctionCallingConfig
- type FunctionDeclaration
- type FunctionResponse
- type GenerateContentRequest
- type GenerateContentResponse
- type GenerationConfig
- type GroundingMetadata
- type ModelOperationMetadata
- type Part
- type ProjectsLocationsPublishersModelsCountTokensCall
- func (c *ProjectsLocationsPublishersModelsCountTokensCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsCountTokensCall
- func (c *ProjectsLocationsPublishersModelsCountTokensCall) Do(opts ...googleapi.CallOption) (*CountTokensResponse, error)
- func (c *ProjectsLocationsPublishersModelsCountTokensCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsCountTokensCall
- func (c *ProjectsLocationsPublishersModelsCountTokensCall) Header() http.Header
- type ProjectsLocationsPublishersModelsGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Do(opts ...googleapi.CallOption) (*GenerateContentResponse, error)
- func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Header() http.Header
- type ProjectsLocationsPublishersModelsService
- func (r *ProjectsLocationsPublishersModelsService) CountTokens(endpoint string, counttokensrequest *CountTokensRequest) *ProjectsLocationsPublishersModelsCountTokensCall
- func (r *ProjectsLocationsPublishersModelsService) GenerateContent(model string, generatecontentrequest *GenerateContentRequest) *ProjectsLocationsPublishersModelsGenerateContentCall
- func (r *ProjectsLocationsPublishersModelsService) StreamGenerateContent(model string, generatecontentrequest *GenerateContentRequest) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
- type ProjectsLocationsPublishersModelsStreamGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Do(opts ...googleapi.CallOption) (*GenerateContentResponse, error)
- func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
- func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Header() http.Header
- type ProjectsLocationsPublishersService
- type ProjectsLocationsService
- type ProjectsService
- type PromptFeedback
- type Retrieval
- type SafetyRating
- type SafetySetting
- type Schema
- type Service
- type Tool
- type ToolConfig
- type UsageMetadata
- type VertexAISearch
- type VertexRagStore
- type VideoMetadata
Constants ¶
const ( // See, edit, configure, and delete your Google Cloud data and see the // email address for your Google Account. CloudPlatformScope = "https://www.googleapis.com/auth/cloud-platform" )
OAuth2 scopes used by this API.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Blob ¶
type Blob struct { // Data: Required. Raw bytes. Data string `json:"data,omitempty"` // MimeType: Required. The IANA standard MIME type of the source data. MimeType string `json:"mimeType,omitempty"` // ForceSendFields is a list of field names (e.g. "Data") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Data") 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:"-"` }
Blob: Content blob. It's preferred to send as text directly rather than raw bytes.
func (*Blob) MarshalJSON ¶
type Candidate ¶
type Candidate struct { // CitationMetadata: Output only. Source attribution of the generated // content. CitationMetadata *CitationMetadata `json:"citationMetadata,omitempty"` // Content: Output only. Content parts of the candidate. Content *Content `json:"content,omitempty"` // FinishMessage: Output only. Describes the reason the mode stopped // generating tokens in more detail. This is only filled when // `finish_reason` is set. FinishMessage string `json:"finishMessage,omitempty"` // FinishReason: Output only. The reason why the model stopped // generating tokens. If empty, the model has not stopped generating the // tokens. // // Possible values: // "FINISH_REASON_UNSPECIFIED" - The finish reason is unspecified. // "STOP" - Natural stop point of the model or provided stop sequence. // "MAX_TOKENS" - The maximum number of tokens as specified in the // request was reached. // "SAFETY" - The token generation was stopped as the response was // flagged for safety reasons. NOTE: When streaming the // Candidate.content will be empty if content filters blocked the // output. // "RECITATION" - The token generation was stopped as the response was // flagged for unauthorized citations. // "OTHER" - All other reasons that stopped the token generation // "BLOCKLIST" - The token generation was stopped as the response was // flagged for the terms which are included from the terminology // blocklist. // "PROHIBITED_CONTENT" - The token generation was stopped as the // response was flagged for the prohibited contents. // "SPII" - The token generation was stopped as the response was // flagged for Sensitive Personally Identifiable Information (SPII) // contents. FinishReason string `json:"finishReason,omitempty"` // GroundingMetadata: Output only. Metadata specifies sources used to // ground generated content. GroundingMetadata *GroundingMetadata `json:"groundingMetadata,omitempty"` // Index: Output only. Index of the candidate. Index int64 `json:"index,omitempty"` // SafetyRatings: Output only. List of ratings for the safety of a // response candidate. There is at most one rating per category. SafetyRatings []*SafetyRating `json:"safetyRatings,omitempty"` // ForceSendFields is a list of field names (e.g. "CitationMetadata") to // unconditionally include in API requests. By default, fields with // empty or default 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. "CitationMetadata") 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: A response candidate generated from the model.
func (*Candidate) MarshalJSON ¶
type Citation ¶
type Citation struct { // EndIndex: Output only. End index into the content. EndIndex int64 `json:"endIndex,omitempty"` // License: Output only. License of the attribution. License string `json:"license,omitempty"` // PublicationDate: Output only. Publication date of the attribution. PublicationDate *Date `json:"publicationDate,omitempty"` // StartIndex: Output only. Start index into the content. StartIndex int64 `json:"startIndex,omitempty"` // Title: Output only. Title of the attribution. Title string `json:"title,omitempty"` // Uri: Output only. Url reference of the attribution. Uri string `json:"uri,omitempty"` // ForceSendFields is a list of field names (e.g. "EndIndex") to // unconditionally include in API requests. By default, fields with // empty or default 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. "EndIndex") 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:"-"` }
Citation: Source attributions for content.
func (*Citation) MarshalJSON ¶
type CitationMetadata ¶
type CitationMetadata struct { // Citations: Output only. List of citations. Citations []*Citation `json:"citations,omitempty"` // ForceSendFields is a list of field names (e.g. "Citations") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Citations") 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:"-"` }
CitationMetadata: A collection of source attributions for a piece of content.
func (*CitationMetadata) MarshalJSON ¶
func (s *CitationMetadata) MarshalJSON() ([]byte, error)
type Content ¶
type Content struct { // Parts: Required. Ordered `Parts` that constitute a single message. // Parts may have different IANA MIME types. Parts []*Part `json:"parts,omitempty"` // Role: Optional. The producer of the content. Must be either 'user' or // 'model'. Useful to set for multi-turn conversations, otherwise can be // left blank or unset. Role string `json:"role,omitempty"` // ForceSendFields is a list of field names (e.g. "Parts") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Parts") 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:"-"` }
Content: The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.
func (*Content) MarshalJSON ¶
type CountTokensRequest ¶
type CountTokensRequest struct { // Contents: Required. Input content. Contents []*Content `json:"contents,omitempty"` // Instances: Required. The instances that are the input to token // counting call. Schema is identical to the prediction schema of the // underlying model. Instances []interface{} `json:"instances,omitempty"` // Model: Required. The name of the publisher model requested to serve // the prediction. Format: // `projects/{project}/locations/{location}/publishers/*/models/*` Model string `json:"model,omitempty"` // ForceSendFields is a list of field names (e.g. "Contents") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Contents") 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:"-"` }
CountTokensRequest: Request message for PredictionService.CountTokens.
func (*CountTokensRequest) MarshalJSON ¶
func (s *CountTokensRequest) MarshalJSON() ([]byte, error)
type CountTokensResponse ¶
type CountTokensResponse struct { // TotalBillableCharacters: The total number of billable characters // counted across all instances from the request. TotalBillableCharacters int64 `json:"totalBillableCharacters,omitempty"` // TotalTokens: The total number of tokens counted across all instances // from the request. TotalTokens int64 `json:"totalTokens,omitempty"` // ServerResponse contains the HTTP response code and headers from the // server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. // "TotalBillableCharacters") to unconditionally include in API // requests. By default, fields with empty or default 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. "TotalBillableCharacters") // 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:"-"` }
CountTokensResponse: Response message for PredictionService.CountTokens.
func (*CountTokensResponse) MarshalJSON ¶
func (s *CountTokensResponse) MarshalJSON() ([]byte, error)
type Date ¶
type Date struct { // Day: Day of a month. Must be from 1 to 31 and valid for the year and // month, or 0 to specify a year by itself or a year and month where the // day isn't significant. Day int64 `json:"day,omitempty"` // Month: Month of a year. Must be from 1 to 12, or 0 to specify a year // without a month and day. Month int64 `json:"month,omitempty"` // Year: Year of the date. Must be from 1 to 9999, or 0 to specify a // date without a year. Year int64 `json:"year,omitempty"` // ForceSendFields is a list of field names (e.g. "Day") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Day") 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:"-"` }
Date: Represents a whole or partial calendar date, such as a birthday. The time of day and time zone are either specified elsewhere or are insignificant. The date is relative to the Gregorian Calendar. This can represent one of the following: * A full date, with non-zero year, month, and day values. * A month and day, with a zero year (for example, an anniversary). * A year on its own, with a zero month and a zero day. * A year and month, with a zero day (for example, a credit card expiration date). Related types: * google.type.TimeOfDay * google.type.DateTime * google.protobuf.Timestamp
func (*Date) MarshalJSON ¶
type FileData ¶
type FileData struct { // FileUri: Required. URI. FileUri string `json:"fileUri,omitempty"` // MimeType: Required. The IANA standard MIME type of the source data. MimeType string `json:"mimeType,omitempty"` // ForceSendFields is a list of field names (e.g. "FileUri") to // unconditionally include in API requests. By default, fields with // empty or default 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. "FileUri") 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:"-"` }
FileData: URI based data.
func (*FileData) MarshalJSON ¶
type FunctionCall ¶
type FunctionCall struct { // Args: Optional. Required. The function parameters and values in JSON // object format. See [FunctionDeclaration.parameters] for parameter // details. Args googleapi.RawMessage `json:"args,omitempty"` // Name: Required. The name of the function to call. Matches // [FunctionDeclaration.name]. Name string `json:"name,omitempty"` // ForceSendFields is a list of field names (e.g. "Args") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Args") 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:"-"` }
FunctionCall: A predicted FunctionCall returned from the model that contains a string representing the [FunctionDeclaration.name] and a structured JSON object containing the parameters and their values.
func (*FunctionCall) MarshalJSON ¶
func (s *FunctionCall) MarshalJSON() ([]byte, error)
type FunctionCallingConfig ¶
type FunctionCallingConfig struct { // AllowedFunctionNames: Optional. Function names to call. Only set when // the Mode is ANY. Function names should match // [FunctionDeclaration.name]. With mode set to ANY, model will predict // a function call from the set of function names provided. AllowedFunctionNames []string `json:"allowedFunctionNames,omitempty"` // Mode: Optional. Function calling mode. // // Possible values: // "MODE_UNSPECIFIED" - Unspecified function calling mode. This value // should not be used. // "AUTO" - Default model behavior, model decides to predict either a // function call or a natural language repspose. // "ANY" - Model is constrained to always predicting a function call // only. If "allowed_function_names" are set, the predicted function // call will be limited to any one of "allowed_function_names", else the // predicted function call will be any one of the provided // "function_declarations". // "NONE" - Model will not predict any function call. Model behavior // is same as when not passing any function declarations. Mode string `json:"mode,omitempty"` // ForceSendFields is a list of field names (e.g. // "AllowedFunctionNames") to unconditionally include in API requests. // By default, fields with empty or default 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. "AllowedFunctionNames") 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:"-"` }
FunctionCallingConfig: Function calling config.
func (*FunctionCallingConfig) MarshalJSON ¶
func (s *FunctionCallingConfig) MarshalJSON() ([]byte, error)
type FunctionDeclaration ¶
type FunctionDeclaration struct { // Description: Optional. Description and purpose of the function. Model // uses it to decide how and whether to call the function. Description string `json:"description,omitempty"` // Name: Required. The name of the function to call. Must start with a // letter or an underscore. Must be a-z, A-Z, 0-9, or contain // underscores, dots and dashes, with a maximum length of 64. Name string `json:"name,omitempty"` // Parameters: Optional. Describes the parameters to this function in // JSON Schema Object format. Reflects the Open API 3.03 Parameter // Object. string Key: the name of the parameter. Parameter names are // case sensitive. Schema Value: the Schema defining the type used for // the parameter. For function with no parameters, this can be left // unset. Parameter names must start with a letter or an underscore and // must only contain chars a-z, A-Z, 0-9, or underscores with a maximum // length of 64. Example with 1 required and 1 optional parameter: type: // OBJECT properties: param1: type: STRING param2: type: INTEGER // required: - param1 Parameters *Schema `json:"parameters,omitempty"` // Response: Optional. Describes the output from this function in JSON // Schema format. Reflects the Open API 3.03 Response Object. The Schema // defines the type used for the response value of the function. Response *Schema `json:"response,omitempty"` // ForceSendFields is a list of field names (e.g. "Description") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Description") 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:"-"` }
FunctionDeclaration: Structured representation of a function declaration as defined by the OpenAPI 3.0 specification (https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client.
func (*FunctionDeclaration) MarshalJSON ¶
func (s *FunctionDeclaration) MarshalJSON() ([]byte, error)
type FunctionResponse ¶
type FunctionResponse struct { // Name: Required. The name of the function to call. Matches // [FunctionDeclaration.name] and [FunctionCall.name]. Name string `json:"name,omitempty"` // Response: Required. The function response in JSON object format. Response googleapi.RawMessage `json:"response,omitempty"` // ForceSendFields is a list of field names (e.g. "Name") to // unconditionally include in API requests. By default, fields with // empty or default 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:"-"` }
FunctionResponse: The result output from a FunctionCall that contains a string representing the [FunctionDeclaration.name] and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a FunctionCall made based on model prediction.
func (*FunctionResponse) MarshalJSON ¶
func (s *FunctionResponse) MarshalJSON() ([]byte, error)
type GenerateContentRequest ¶
type GenerateContentRequest struct { // Contents: Required. The content of the current conversation with the // model. For single-turn queries, this is a single instance. For // multi-turn queries, this is a repeated field that contains // conversation history + latest request. Contents []*Content `json:"contents,omitempty"` // GenerationConfig: Optional. Generation config. GenerationConfig *GenerationConfig `json:"generationConfig,omitempty"` // SafetySettings: Optional. Per request settings for blocking unsafe // content. Enforced on GenerateContentResponse.candidates. SafetySettings []*SafetySetting `json:"safetySettings,omitempty"` // SystemInstruction: Optional. The user provided system instructions // for the model. Note: only text should be used in parts and content in // each part will be in a separate paragraph. SystemInstruction *Content `json:"systemInstruction,omitempty"` // ToolConfig: Optional. Tool config. This config is shared for all // tools provided in the request. ToolConfig *ToolConfig `json:"toolConfig,omitempty"` // Tools: Optional. A list of `Tools` the model may use to generate the // next response. A `Tool` is a piece of code that enables the system to // interact with external systems to perform an action, or set of // actions, outside of knowledge and scope of the model. Tools []*Tool `json:"tools,omitempty"` // ForceSendFields is a list of field names (e.g. "Contents") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Contents") 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:"-"` }
GenerateContentRequest: Request message for [PredictionService.GenerateContent].
func (*GenerateContentRequest) MarshalJSON ¶
func (s *GenerateContentRequest) MarshalJSON() ([]byte, error)
type GenerateContentResponse ¶
type GenerateContentResponse struct { // Candidates: Output only. Generated candidates. Candidates []*Candidate `json:"candidates,omitempty"` // PromptFeedback: Output only. Content filter results for a prompt sent // in the request. Note: Sent only in the first stream chunk. Only // happens when no candidates were generated due to content violations. PromptFeedback *PromptFeedback `json:"promptFeedback,omitempty"` // UsageMetadata: Usage metadata about the response(s). UsageMetadata *UsageMetadata `json:"usageMetadata,omitempty"` // ServerResponse contains the HTTP response code and headers from the // server. googleapi.ServerResponse `json:"-"` // ForceSendFields is a list of field names (e.g. "Candidates") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Candidates") 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:"-"` }
GenerateContentResponse: Response message for [PredictionService.GenerateContent].
func (*GenerateContentResponse) MarshalJSON ¶
func (s *GenerateContentResponse) MarshalJSON() ([]byte, error)
type GenerationConfig ¶
type GenerationConfig struct { // CandidateCount: Optional. Number of candidates to generate. CandidateCount int64 `json:"candidateCount,omitempty"` // FrequencyPenalty: Optional. Frequency penalties. FrequencyPenalty float64 `json:"frequencyPenalty,omitempty"` // MaxOutputTokens: Optional. The maximum number of output tokens to // generate per message. MaxOutputTokens int64 `json:"maxOutputTokens,omitempty"` // PresencePenalty: Optional. Positive penalties. PresencePenalty float64 `json:"presencePenalty,omitempty"` // ResponseMimeType: Optional. Output response mimetype of the generated // candidate text. Supported mimetype: - `text/plain`: (default) Text // output. - `application/json`: JSON response in the candidates. The // model needs to be prompted to output the appropriate response type, // otherwise the behavior is undefined. This is a preview feature. ResponseMimeType string `json:"responseMimeType,omitempty"` // StopSequences: Optional. Stop sequences. StopSequences []string `json:"stopSequences,omitempty"` // Temperature: Optional. Controls the randomness of predictions. Temperature float64 `json:"temperature,omitempty"` // TopK: Optional. If specified, top-k sampling will be used. TopK float64 `json:"topK,omitempty"` // TopP: Optional. If specified, nucleus sampling will be used. TopP float64 `json:"topP,omitempty"` // ForceSendFields is a list of field names (e.g. "CandidateCount") to // unconditionally include in API requests. By default, fields with // empty or default 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. "CandidateCount") 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:"-"` }
GenerationConfig: Generation config.
func (*GenerationConfig) MarshalJSON ¶
func (s *GenerationConfig) MarshalJSON() ([]byte, error)
func (*GenerationConfig) UnmarshalJSON ¶
func (s *GenerationConfig) UnmarshalJSON(data []byte) error
type GroundingMetadata ¶
type GroundingMetadata struct { // RetrievalQueries: Optional. Queries executed by the retrieval tools. RetrievalQueries []string `json:"retrievalQueries,omitempty"` // WebSearchQueries: Optional. Web search queries for the following-up // web search. WebSearchQueries []string `json:"webSearchQueries,omitempty"` // ForceSendFields is a list of field names (e.g. "RetrievalQueries") to // unconditionally include in API requests. By default, fields with // empty or default 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. "RetrievalQueries") 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:"-"` }
GroundingMetadata: Metadata returned to client when grounding is enabled.
func (*GroundingMetadata) MarshalJSON ¶
func (s *GroundingMetadata) MarshalJSON() ([]byte, error)
type ModelOperationMetadata ¶
type ModelOperationMetadata struct { // Possible values: // "BASIC_OPERATION_STATUS_UNSPECIFIED" - The status is unspecified // "BASIC_OPERATION_STATUS_UPLOADING" - The model file is being // uploaded // "BASIC_OPERATION_STATUS_VERIFYING" - The model file is being // verified BasicOperationStatus string `json:"basicOperationStatus,omitempty"` // Name: The name of the model we are creating/updating The name must // have the form `projects/{project_id}/models/{model_id}` Name string `json:"name,omitempty"` // ForceSendFields is a list of field names (e.g. // "BasicOperationStatus") to unconditionally include in API requests. // By default, fields with empty or default 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. "BasicOperationStatus") 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:"-"` }
ModelOperationMetadata: This is returned in the longrunning operations for create/update.
func (*ModelOperationMetadata) MarshalJSON ¶
func (s *ModelOperationMetadata) MarshalJSON() ([]byte, error)
type Part ¶
type Part struct { // FileData: Optional. URI based data. FileData *FileData `json:"fileData,omitempty"` // FunctionCall: Optional. A predicted [FunctionCall] returned from the // model that contains a string representing the // [FunctionDeclaration.name] with the parameters and their values. FunctionCall *FunctionCall `json:"functionCall,omitempty"` // FunctionResponse: Optional. The result output of a [FunctionCall] // that contains a string representing the [FunctionDeclaration.name] // and a structured JSON object containing any output from the function // call. It is used as context to the model. FunctionResponse *FunctionResponse `json:"functionResponse,omitempty"` // InlineData: Optional. Inlined bytes data. InlineData *Blob `json:"inlineData,omitempty"` // Text: Optional. Text part (can be code). Text string `json:"text,omitempty"` // VideoMetadata: Optional. Video metadata. The metadata should only be // specified while the video data is presented in inline_data or // file_data. VideoMetadata *VideoMetadata `json:"videoMetadata,omitempty"` // ForceSendFields is a list of field names (e.g. "FileData") to // unconditionally include in API requests. By default, fields with // empty or default 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. "FileData") 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:"-"` }
Part: A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if `inline_data` or `file_data` field is filled with raw bytes.
func (*Part) MarshalJSON ¶
type ProjectsLocationsPublishersModelsCountTokensCall ¶
type ProjectsLocationsPublishersModelsCountTokensCall struct {
// contains filtered or unexported fields
}
func (*ProjectsLocationsPublishersModelsCountTokensCall) Context ¶
func (c *ProjectsLocationsPublishersModelsCountTokensCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsCountTokensCall
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 (*ProjectsLocationsPublishersModelsCountTokensCall) Do ¶
func (c *ProjectsLocationsPublishersModelsCountTokensCall) Do(opts ...googleapi.CallOption) (*CountTokensResponse, error)
Do executes the "firebaseml.projects.locations.publishers.models.countTokens" call. Exactly one of *CountTokensResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *CountTokensResponse.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 (*ProjectsLocationsPublishersModelsCountTokensCall) Fields ¶
func (c *ProjectsLocationsPublishersModelsCountTokensCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsCountTokensCall
Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.
func (*ProjectsLocationsPublishersModelsCountTokensCall) Header ¶
func (c *ProjectsLocationsPublishersModelsCountTokensCall) Header() http.Header
Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.
type ProjectsLocationsPublishersModelsGenerateContentCall ¶
type ProjectsLocationsPublishersModelsGenerateContentCall struct {
// contains filtered or unexported fields
}
func (*ProjectsLocationsPublishersModelsGenerateContentCall) Context ¶
func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsGenerateContentCall
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 (*ProjectsLocationsPublishersModelsGenerateContentCall) Do ¶
func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Do(opts ...googleapi.CallOption) (*GenerateContentResponse, error)
Do executes the "firebaseml.projects.locations.publishers.models.generateContent" call. Exactly one of *GenerateContentResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *GenerateContentResponse.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 (*ProjectsLocationsPublishersModelsGenerateContentCall) Fields ¶
func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsGenerateContentCall
Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.
func (*ProjectsLocationsPublishersModelsGenerateContentCall) Header ¶
func (c *ProjectsLocationsPublishersModelsGenerateContentCall) Header() http.Header
Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.
type ProjectsLocationsPublishersModelsService ¶
type ProjectsLocationsPublishersModelsService struct {
// contains filtered or unexported fields
}
func NewProjectsLocationsPublishersModelsService ¶
func NewProjectsLocationsPublishersModelsService(s *Service) *ProjectsLocationsPublishersModelsService
func (*ProjectsLocationsPublishersModelsService) CountTokens ¶
func (r *ProjectsLocationsPublishersModelsService) CountTokens(endpoint string, counttokensrequest *CountTokensRequest) *ProjectsLocationsPublishersModelsCountTokensCall
CountTokens: Perform a token counting.
- endpoint: The name of the Endpoint requested to perform token counting. Format: `projects/{project}/locations/{location}/endpoints/{endpoint}`.
func (*ProjectsLocationsPublishersModelsService) GenerateContent ¶
func (r *ProjectsLocationsPublishersModelsService) GenerateContent(model string, generatecontentrequest *GenerateContentRequest) *ProjectsLocationsPublishersModelsGenerateContentCall
GenerateContent: Generate content with multimodal inputs.
- model: The name of the publisher model requested to serve the prediction. Format: `projects/{project}/locations/{location}/publishers/*/models/*`.
func (*ProjectsLocationsPublishersModelsService) StreamGenerateContent ¶
func (r *ProjectsLocationsPublishersModelsService) StreamGenerateContent(model string, generatecontentrequest *GenerateContentRequest) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
StreamGenerateContent: Generate content with multimodal inputs with streaming support.
- model: The name of the publisher model requested to serve the prediction. Format: `projects/{project}/locations/{location}/publishers/*/models/*`.
type ProjectsLocationsPublishersModelsStreamGenerateContentCall ¶
type ProjectsLocationsPublishersModelsStreamGenerateContentCall struct {
// contains filtered or unexported fields
}
func (*ProjectsLocationsPublishersModelsStreamGenerateContentCall) Context ¶
func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Context(ctx context.Context) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
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 (*ProjectsLocationsPublishersModelsStreamGenerateContentCall) Do ¶
func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Do(opts ...googleapi.CallOption) (*GenerateContentResponse, error)
Do executes the "firebaseml.projects.locations.publishers.models.streamGenerateContent" call. Exactly one of *GenerateContentResponse or error will be non-nil. Any non-2xx status code is an error. Response headers are in either *GenerateContentResponse.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 (*ProjectsLocationsPublishersModelsStreamGenerateContentCall) Fields ¶
func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Fields(s ...googleapi.Field) *ProjectsLocationsPublishersModelsStreamGenerateContentCall
Fields allows partial responses to be retrieved. See https://developers.google.com/gdata/docs/2.0/basics#PartialResponse for more information.
func (*ProjectsLocationsPublishersModelsStreamGenerateContentCall) Header ¶
func (c *ProjectsLocationsPublishersModelsStreamGenerateContentCall) Header() http.Header
Header returns an http.Header that can be modified by the caller to add HTTP headers to the request.
type ProjectsLocationsPublishersService ¶
type ProjectsLocationsPublishersService struct { Models *ProjectsLocationsPublishersModelsService // contains filtered or unexported fields }
func NewProjectsLocationsPublishersService ¶
func NewProjectsLocationsPublishersService(s *Service) *ProjectsLocationsPublishersService
type ProjectsLocationsService ¶
type ProjectsLocationsService struct { Publishers *ProjectsLocationsPublishersService // contains filtered or unexported fields }
func NewProjectsLocationsService ¶
func NewProjectsLocationsService(s *Service) *ProjectsLocationsService
type ProjectsService ¶
type ProjectsService struct { Locations *ProjectsLocationsService // contains filtered or unexported fields }
func NewProjectsService ¶
func NewProjectsService(s *Service) *ProjectsService
type PromptFeedback ¶
type PromptFeedback struct { // BlockReason: Output only. Blocked reason. // // Possible values: // "BLOCKED_REASON_UNSPECIFIED" - Unspecified blocked reason. // "SAFETY" - Candidates blocked due to safety. // "OTHER" - Candidates blocked due to other reason. // "BLOCKLIST" - Candidates blocked due to the terms which are // included from the terminology blocklist. // "PROHIBITED_CONTENT" - Candidates blocked due to prohibited // content. BlockReason string `json:"blockReason,omitempty"` // BlockReasonMessage: Output only. A readable block reason message. BlockReasonMessage string `json:"blockReasonMessage,omitempty"` // SafetyRatings: Output only. Safety ratings. SafetyRatings []*SafetyRating `json:"safetyRatings,omitempty"` // ForceSendFields is a list of field names (e.g. "BlockReason") to // unconditionally include in API requests. By default, fields with // empty or default 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. "BlockReason") 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:"-"` }
PromptFeedback: Content filter results for a prompt sent in the request.
func (*PromptFeedback) MarshalJSON ¶
func (s *PromptFeedback) MarshalJSON() ([]byte, error)
type Retrieval ¶
type Retrieval struct { // DisableAttribution: Optional. Disable using the result from this tool // in detecting grounding attribution. This does not affect how the // result is given to the model for generation. DisableAttribution bool `json:"disableAttribution,omitempty"` // VertexAiSearch: Set to use data source powered by Vertex AI Search. VertexAiSearch *VertexAISearch `json:"vertexAiSearch,omitempty"` // VertexRagStore: Set to use data source powered by Vertex RAG store. // User data is uploaded via the VertexRagDataService. VertexRagStore *VertexRagStore `json:"vertexRagStore,omitempty"` // ForceSendFields is a list of field names (e.g. "DisableAttribution") // to unconditionally include in API requests. By default, fields with // empty or default 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. "DisableAttribution") 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:"-"` }
Retrieval: Defines a retrieval tool that model can call to access external knowledge.
func (*Retrieval) MarshalJSON ¶
type SafetyRating ¶
type SafetyRating struct { // Blocked: Output only. Indicates whether the content was filtered out // because of this rating. Blocked bool `json:"blocked,omitempty"` // Category: Output only. Harm category. // // Possible values: // "HARM_CATEGORY_UNSPECIFIED" - The harm category is unspecified. // "HARM_CATEGORY_HATE_SPEECH" - The harm category is hate speech. // "HARM_CATEGORY_DANGEROUS_CONTENT" - The harm category is dangerous // content. // "HARM_CATEGORY_HARASSMENT" - The harm category is harassment. // "HARM_CATEGORY_SEXUALLY_EXPLICIT" - The harm category is sexually // explicit content. Category string `json:"category,omitempty"` // Probability: Output only. Harm probability levels in the content. // // Possible values: // "HARM_PROBABILITY_UNSPECIFIED" - Harm probability unspecified. // "NEGLIGIBLE" - Negligible level of harm. // "LOW" - Low level of harm. // "MEDIUM" - Medium level of harm. // "HIGH" - High level of harm. Probability string `json:"probability,omitempty"` // ProbabilityScore: Output only. Harm probability score. ProbabilityScore float64 `json:"probabilityScore,omitempty"` // Severity: Output only. Harm severity levels in the content. // // Possible values: // "HARM_SEVERITY_UNSPECIFIED" - Harm severity unspecified. // "HARM_SEVERITY_NEGLIGIBLE" - Negligible level of harm severity. // "HARM_SEVERITY_LOW" - Low level of harm severity. // "HARM_SEVERITY_MEDIUM" - Medium level of harm severity. // "HARM_SEVERITY_HIGH" - High level of harm severity. Severity string `json:"severity,omitempty"` // SeverityScore: Output only. Harm severity score. SeverityScore float64 `json:"severityScore,omitempty"` // ForceSendFields is a list of field names (e.g. "Blocked") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Blocked") 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:"-"` }
SafetyRating: Safety rating corresponding to the generated content.
func (*SafetyRating) MarshalJSON ¶
func (s *SafetyRating) MarshalJSON() ([]byte, error)
func (*SafetyRating) UnmarshalJSON ¶
func (s *SafetyRating) UnmarshalJSON(data []byte) error
type SafetySetting ¶
type SafetySetting struct { // Category: Required. Harm category. // // Possible values: // "HARM_CATEGORY_UNSPECIFIED" - The harm category is unspecified. // "HARM_CATEGORY_HATE_SPEECH" - The harm category is hate speech. // "HARM_CATEGORY_DANGEROUS_CONTENT" - The harm category is dangerous // content. // "HARM_CATEGORY_HARASSMENT" - The harm category is harassment. // "HARM_CATEGORY_SEXUALLY_EXPLICIT" - The harm category is sexually // explicit content. Category string `json:"category,omitempty"` // Method: Optional. Specify if the threshold is used for probability or // severity score. If not specified, the threshold is used for // probability score. // // Possible values: // "HARM_BLOCK_METHOD_UNSPECIFIED" - The harm block method is // unspecified. // "SEVERITY" - The harm block method uses both probability and // severity scores. // "PROBABILITY" - The harm block method uses the probability score. Method string `json:"method,omitempty"` // Threshold: Required. The harm block threshold. // // Possible values: // "HARM_BLOCK_THRESHOLD_UNSPECIFIED" - Unspecified harm block // threshold. // "BLOCK_LOW_AND_ABOVE" - Block low threshold and above (i.e. block // more). // "BLOCK_MEDIUM_AND_ABOVE" - Block medium threshold and above. // "BLOCK_ONLY_HIGH" - Block only high threshold (i.e. block less). // "BLOCK_NONE" - Block none. Threshold string `json:"threshold,omitempty"` // ForceSendFields is a list of field names (e.g. "Category") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Category") 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:"-"` }
SafetySetting: Safety settings.
func (*SafetySetting) MarshalJSON ¶
func (s *SafetySetting) MarshalJSON() ([]byte, error)
type Schema ¶
type Schema struct { // Default: Optional. Default value of the data. Default interface{} `json:"default,omitempty"` // Description: Optional. The description of the data. Description string `json:"description,omitempty"` // Enum: Optional. Possible values of the element of Type.STRING with // enum format. For example we can define an Enum Direction as : // {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} Enum []string `json:"enum,omitempty"` // Example: Optional. Example of the object. Will only populated when // the object is the root. Example interface{} `json:"example,omitempty"` // Format: Optional. The format of the data. Supported formats: for // NUMBER type: "float", "double" for INTEGER type: "int32", "int64" for // STRING type: "email", "byte", etc Format string `json:"format,omitempty"` // Items: Optional. SCHEMA FIELDS FOR TYPE ARRAY Schema of the elements // of Type.ARRAY. Items *Schema `json:"items,omitempty"` // MaxItems: Optional. Maximum number of the elements for Type.ARRAY. MaxItems int64 `json:"maxItems,omitempty,string"` // MaxLength: Optional. Maximum length of the Type.STRING MaxLength int64 `json:"maxLength,omitempty,string"` // MaxProperties: Optional. Maximum number of the properties for // Type.OBJECT. MaxProperties int64 `json:"maxProperties,omitempty,string"` // Maximum: Optional. Maximum value of the Type.INTEGER and Type.NUMBER Maximum float64 `json:"maximum,omitempty"` // MinItems: Optional. Minimum number of the elements for Type.ARRAY. MinItems int64 `json:"minItems,omitempty,string"` // MinLength: Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of // the Type.STRING MinLength int64 `json:"minLength,omitempty,string"` // MinProperties: Optional. Minimum number of the properties for // Type.OBJECT. MinProperties int64 `json:"minProperties,omitempty,string"` // Minimum: Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum // value of the Type.INTEGER and Type.NUMBER Minimum float64 `json:"minimum,omitempty"` // Nullable: Optional. Indicates if the value may be null. Nullable bool `json:"nullable,omitempty"` // Pattern: Optional. Pattern of the Type.STRING to restrict a string to // a regular expression. Pattern string `json:"pattern,omitempty"` // Properties: Optional. SCHEMA FIELDS FOR TYPE OBJECT Properties of // Type.OBJECT. Properties map[string]Schema `json:"properties,omitempty"` // Required: Optional. Required properties of Type.OBJECT. Required []string `json:"required,omitempty"` // Title: Optional. The title of the Schema. Title string `json:"title,omitempty"` // Type: Optional. The type of the data. // // Possible values: // "TYPE_UNSPECIFIED" - Not specified, should not be used. // "STRING" - OpenAPI string type // "NUMBER" - OpenAPI number type // "INTEGER" - OpenAPI integer type // "BOOLEAN" - OpenAPI boolean type // "ARRAY" - OpenAPI array type // "OBJECT" - OpenAPI object type Type string `json:"type,omitempty"` // ForceSendFields is a list of field names (e.g. "Default") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Default") 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:"-"` }
Schema: Schema is used to define the format of input/output data. Represents a select subset of an OpenAPI 3.0 schema object (https://spec.openapis.org/oas/v3.0.3#schema). More fields may be added in the future as needed.
func (*Schema) MarshalJSON ¶
func (*Schema) UnmarshalJSON ¶
type Service ¶
type Service struct { BasePath string // API endpoint base URL UserAgent string // optional additional User-Agent fragment Projects *ProjectsService // contains filtered or unexported fields }
func New
deprecated
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 ¶
NewService creates a new Service.
type Tool ¶
type Tool struct { // FunctionDeclarations: Optional. Function tool type. One or more // function declarations to be passed to the model along with the // current user query. Model may decide to call a subset of these // functions by populating FunctionCall in the response. User should // provide a FunctionResponse for each function call in the next turn. // Based on the function responses, Model will generate the final // response back to the user. Maximum 64 function declarations can be // provided. FunctionDeclarations []*FunctionDeclaration `json:"functionDeclarations,omitempty"` // Retrieval: Optional. Retrieval tool type. System will always execute // the provided retrieval tool(s) to get external knowledge to answer // the prompt. Retrieval results are presented to the model for // generation. Retrieval *Retrieval `json:"retrieval,omitempty"` // ForceSendFields is a list of field names (e.g. // "FunctionDeclarations") to unconditionally include in API requests. // By default, fields with empty or default 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. "FunctionDeclarations") 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:"-"` }
Tool: Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. A Tool object should contain exactly one type of Tool (e.g FunctionDeclaration, Retrieval or GoogleSearchRetrieval).
func (*Tool) MarshalJSON ¶
type ToolConfig ¶
type ToolConfig struct { // FunctionCallingConfig: Optional. Function calling config. FunctionCallingConfig *FunctionCallingConfig `json:"functionCallingConfig,omitempty"` // ForceSendFields is a list of field names (e.g. // "FunctionCallingConfig") to unconditionally include in API requests. // By default, fields with empty or default 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. "FunctionCallingConfig") 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:"-"` }
ToolConfig: Tool config. This config is shared for all tools provided in the request.
func (*ToolConfig) MarshalJSON ¶
func (s *ToolConfig) MarshalJSON() ([]byte, error)
type UsageMetadata ¶
type UsageMetadata struct { // CandidatesTokenCount: Number of tokens in the response(s). CandidatesTokenCount int64 `json:"candidatesTokenCount,omitempty"` // PromptTokenCount: Number of tokens in the request. PromptTokenCount int64 `json:"promptTokenCount,omitempty"` TotalTokenCount int64 `json:"totalTokenCount,omitempty"` // ForceSendFields is a list of field names (e.g. // "CandidatesTokenCount") to unconditionally include in API requests. // By default, fields with empty or default 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. "CandidatesTokenCount") 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:"-"` }
UsageMetadata: Usage metadata about response(s).
func (*UsageMetadata) MarshalJSON ¶
func (s *UsageMetadata) MarshalJSON() ([]byte, error)
type VertexAISearch ¶
type VertexAISearch struct { // Datastore: Required. Fully-qualified Vertex AI Search's datastore // resource ID. Format: // `projects/{project}/locations/{location}/collections/{collection}/data // Stores/{dataStore}` Datastore string `json:"datastore,omitempty"` // ForceSendFields is a list of field names (e.g. "Datastore") to // unconditionally include in API requests. By default, fields with // empty or default 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. "Datastore") 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:"-"` }
VertexAISearch: Retrieve from Vertex AI Search datastore for grounding. See https://cloud.google.com/vertex-ai-search-and-conversation
func (*VertexAISearch) MarshalJSON ¶
func (s *VertexAISearch) MarshalJSON() ([]byte, error)
type VertexRagStore ¶
type VertexRagStore struct { // RagCorpora: Required. Vertex RAG Store corpus resource name: // `projects/{project}/locations/{location}/ragCorpora/{ragCorpus}` // Currently only one corpus is allowed. In the future we may open up // multiple corpora support. However, they should be from the same // project and location. RagCorpora []string `json:"ragCorpora,omitempty"` // SimilarityTopK: Optional. Number of top k results to return from the // selected corpora. SimilarityTopK int64 `json:"similarityTopK,omitempty"` // VectorDistanceThreshold: Optional. Only return results with vector // distance smaller than the threshold. VectorDistanceThreshold float64 `json:"vectorDistanceThreshold,omitempty"` // ForceSendFields is a list of field names (e.g. "RagCorpora") to // unconditionally include in API requests. By default, fields with // empty or default 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. "RagCorpora") 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:"-"` }
VertexRagStore: Retrieve from Vertex RAG Store for grounding.
func (*VertexRagStore) MarshalJSON ¶
func (s *VertexRagStore) MarshalJSON() ([]byte, error)
func (*VertexRagStore) UnmarshalJSON ¶
func (s *VertexRagStore) UnmarshalJSON(data []byte) error
type VideoMetadata ¶
type VideoMetadata struct { // EndOffset: Optional. The end offset of the video. EndOffset string `json:"endOffset,omitempty"` // StartOffset: Optional. The start offset of the video. StartOffset string `json:"startOffset,omitempty"` // ForceSendFields is a list of field names (e.g. "EndOffset") to // unconditionally include in API requests. By default, fields with // empty or default 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. "EndOffset") 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:"-"` }
VideoMetadata: Metadata describes the input video content.
func (*VideoMetadata) MarshalJSON ¶
func (s *VideoMetadata) MarshalJSON() ([]byte, error)