2017-05-11 14:39:54 +00:00
// Copyright 2017, Google Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// AUTO-GENERATED CODE. DO NOT EDIT.
package language
import (
"time"
"cloud.google.com/go/internal/version"
gax "github.com/googleapis/gax-go"
"golang.org/x/net/context"
"google.golang.org/api/option"
"google.golang.org/api/transport"
languagepb "google.golang.org/genproto/googleapis/cloud/language/v1"
"google.golang.org/grpc"
"google.golang.org/grpc/codes"
)
// CallOptions contains the retry settings for each method of Client.
type CallOptions struct {
2017-09-30 14:27:27 +00:00
AnalyzeSentiment [ ] gax . CallOption
AnalyzeEntities [ ] gax . CallOption
AnalyzeEntitySentiment [ ] gax . CallOption
AnalyzeSyntax [ ] gax . CallOption
AnnotateText [ ] gax . CallOption
2017-05-11 14:39:54 +00:00
}
func defaultClientOptions ( ) [ ] option . ClientOption {
return [ ] option . ClientOption {
option . WithEndpoint ( "language.googleapis.com:443" ) ,
2017-07-23 07:51:42 +00:00
option . WithScopes ( DefaultAuthScopes ( ) ... ) ,
2017-05-11 14:39:54 +00:00
}
}
func defaultCallOptions ( ) * CallOptions {
retry := map [ [ 2 ] string ] [ ] gax . CallOption {
{ "default" , "idempotent" } : {
gax . WithRetry ( func ( ) gax . Retryer {
return gax . OnCodes ( [ ] codes . Code {
codes . DeadlineExceeded ,
codes . Unavailable ,
} , gax . Backoff {
Initial : 100 * time . Millisecond ,
Max : 60000 * time . Millisecond ,
Multiplier : 1.3 ,
} )
} ) ,
} ,
}
return & CallOptions {
2017-09-30 14:27:27 +00:00
AnalyzeSentiment : retry [ [ 2 ] string { "default" , "idempotent" } ] ,
AnalyzeEntities : retry [ [ 2 ] string { "default" , "idempotent" } ] ,
AnalyzeEntitySentiment : retry [ [ 2 ] string { "default" , "idempotent" } ] ,
AnalyzeSyntax : retry [ [ 2 ] string { "default" , "idempotent" } ] ,
AnnotateText : retry [ [ 2 ] string { "default" , "idempotent" } ] ,
2017-05-11 14:39:54 +00:00
}
}
// Client is a client for interacting with Google Cloud Natural Language API.
type Client struct {
// The connection to the service.
conn * grpc . ClientConn
// The gRPC API client.
client languagepb . LanguageServiceClient
// The call options for this service.
CallOptions * CallOptions
// The metadata to be sent with each request.
2017-07-23 07:51:42 +00:00
xGoogHeader [ ] string
2017-05-11 14:39:54 +00:00
}
// NewClient creates a new language service client.
//
// Provides text analysis operations such as sentiment analysis and entity
// recognition.
func NewClient ( ctx context . Context , opts ... option . ClientOption ) ( * Client , error ) {
conn , err := transport . DialGRPC ( ctx , append ( defaultClientOptions ( ) , opts ... ) ... )
if err != nil {
return nil , err
}
c := & Client {
conn : conn ,
CallOptions : defaultCallOptions ( ) ,
client : languagepb . NewLanguageServiceClient ( conn ) ,
}
2017-09-30 14:27:27 +00:00
c . setGoogleClientInfo ( )
2017-05-11 14:39:54 +00:00
return c , nil
}
// Connection returns the client's connection to the API service.
func ( c * Client ) Connection ( ) * grpc . ClientConn {
return c . conn
}
// Close closes the connection to the API service. The user should invoke this when
// the client is no longer required.
func ( c * Client ) Close ( ) error {
return c . conn . Close ( )
}
2017-09-30 14:27:27 +00:00
// setGoogleClientInfo sets the name and version of the application in
2017-05-11 14:39:54 +00:00
// the `x-goog-api-client` header passed on each request. Intended for
// use by Google-written clients.
2017-09-30 14:27:27 +00:00
func ( c * Client ) setGoogleClientInfo ( keyval ... string ) {
2017-05-11 14:39:54 +00:00
kv := append ( [ ] string { "gl-go" , version . Go ( ) } , keyval ... )
2017-07-23 07:51:42 +00:00
kv = append ( kv , "gapic" , version . Repo , "gax" , gax . Version , "grpc" , grpc . Version )
c . xGoogHeader = [ ] string { gax . XGoogHeader ( kv ... ) }
2017-05-11 14:39:54 +00:00
}
// AnalyzeSentiment analyzes the sentiment of the provided text.
2017-07-23 07:51:42 +00:00
func ( c * Client ) AnalyzeSentiment ( ctx context . Context , req * languagepb . AnalyzeSentimentRequest , opts ... gax . CallOption ) ( * languagepb . AnalyzeSentimentResponse , error ) {
2017-05-11 14:39:54 +00:00
ctx = insertXGoog ( ctx , c . xGoogHeader )
2017-07-23 07:51:42 +00:00
opts = append ( c . CallOptions . AnalyzeSentiment [ 0 : len ( c . CallOptions . AnalyzeSentiment ) : len ( c . CallOptions . AnalyzeSentiment ) ] , opts ... )
2017-05-11 14:39:54 +00:00
var resp * languagepb . AnalyzeSentimentResponse
2017-07-23 07:51:42 +00:00
err := gax . Invoke ( ctx , func ( ctx context . Context , settings gax . CallSettings ) error {
2017-05-11 14:39:54 +00:00
var err error
2017-07-23 07:51:42 +00:00
resp , err = c . client . AnalyzeSentiment ( ctx , req , settings . GRPC ... )
2017-05-11 14:39:54 +00:00
return err
2017-07-23 07:51:42 +00:00
} , opts ... )
2017-05-11 14:39:54 +00:00
if err != nil {
return nil , err
}
return resp , nil
}
2017-07-23 07:51:42 +00:00
// AnalyzeEntities finds named entities (currently proper names and common nouns) in the text
// along with entity types, salience, mentions for each entity, and
// other properties.
func ( c * Client ) AnalyzeEntities ( ctx context . Context , req * languagepb . AnalyzeEntitiesRequest , opts ... gax . CallOption ) ( * languagepb . AnalyzeEntitiesResponse , error ) {
2017-05-11 14:39:54 +00:00
ctx = insertXGoog ( ctx , c . xGoogHeader )
2017-07-23 07:51:42 +00:00
opts = append ( c . CallOptions . AnalyzeEntities [ 0 : len ( c . CallOptions . AnalyzeEntities ) : len ( c . CallOptions . AnalyzeEntities ) ] , opts ... )
2017-05-11 14:39:54 +00:00
var resp * languagepb . AnalyzeEntitiesResponse
2017-07-23 07:51:42 +00:00
err := gax . Invoke ( ctx , func ( ctx context . Context , settings gax . CallSettings ) error {
2017-05-11 14:39:54 +00:00
var err error
2017-07-23 07:51:42 +00:00
resp , err = c . client . AnalyzeEntities ( ctx , req , settings . GRPC ... )
2017-05-11 14:39:54 +00:00
return err
2017-07-23 07:51:42 +00:00
} , opts ... )
2017-05-11 14:39:54 +00:00
if err != nil {
return nil , err
}
return resp , nil
}
2017-09-30 14:27:27 +00:00
// AnalyzeEntitySentiment finds entities, similar to [AnalyzeEntities][google.cloud.language.v1.LanguageService.AnalyzeEntities] in the text and analyzes
// sentiment associated with each entity and its mentions.
func ( c * Client ) AnalyzeEntitySentiment ( ctx context . Context , req * languagepb . AnalyzeEntitySentimentRequest , opts ... gax . CallOption ) ( * languagepb . AnalyzeEntitySentimentResponse , error ) {
ctx = insertXGoog ( ctx , c . xGoogHeader )
opts = append ( c . CallOptions . AnalyzeEntitySentiment [ 0 : len ( c . CallOptions . AnalyzeEntitySentiment ) : len ( c . CallOptions . AnalyzeEntitySentiment ) ] , opts ... )
var resp * languagepb . AnalyzeEntitySentimentResponse
err := gax . Invoke ( ctx , func ( ctx context . Context , settings gax . CallSettings ) error {
var err error
resp , err = c . client . AnalyzeEntitySentiment ( ctx , req , settings . GRPC ... )
return err
} , opts ... )
if err != nil {
return nil , err
}
return resp , nil
}
2017-05-11 14:39:54 +00:00
// AnalyzeSyntax analyzes the syntax of the text and provides sentence boundaries and
// tokenization along with part of speech tags, dependency trees, and other
// properties.
2017-07-23 07:51:42 +00:00
func ( c * Client ) AnalyzeSyntax ( ctx context . Context , req * languagepb . AnalyzeSyntaxRequest , opts ... gax . CallOption ) ( * languagepb . AnalyzeSyntaxResponse , error ) {
2017-05-11 14:39:54 +00:00
ctx = insertXGoog ( ctx , c . xGoogHeader )
2017-07-23 07:51:42 +00:00
opts = append ( c . CallOptions . AnalyzeSyntax [ 0 : len ( c . CallOptions . AnalyzeSyntax ) : len ( c . CallOptions . AnalyzeSyntax ) ] , opts ... )
2017-05-11 14:39:54 +00:00
var resp * languagepb . AnalyzeSyntaxResponse
2017-07-23 07:51:42 +00:00
err := gax . Invoke ( ctx , func ( ctx context . Context , settings gax . CallSettings ) error {
2017-05-11 14:39:54 +00:00
var err error
2017-07-23 07:51:42 +00:00
resp , err = c . client . AnalyzeSyntax ( ctx , req , settings . GRPC ... )
2017-05-11 14:39:54 +00:00
return err
2017-07-23 07:51:42 +00:00
} , opts ... )
2017-05-11 14:39:54 +00:00
if err != nil {
return nil , err
}
return resp , nil
}
// AnnotateText a convenience method that provides all the features that analyzeSentiment,
// analyzeEntities, and analyzeSyntax provide in one call.
2017-07-23 07:51:42 +00:00
func ( c * Client ) AnnotateText ( ctx context . Context , req * languagepb . AnnotateTextRequest , opts ... gax . CallOption ) ( * languagepb . AnnotateTextResponse , error ) {
2017-05-11 14:39:54 +00:00
ctx = insertXGoog ( ctx , c . xGoogHeader )
2017-07-23 07:51:42 +00:00
opts = append ( c . CallOptions . AnnotateText [ 0 : len ( c . CallOptions . AnnotateText ) : len ( c . CallOptions . AnnotateText ) ] , opts ... )
2017-05-11 14:39:54 +00:00
var resp * languagepb . AnnotateTextResponse
2017-07-23 07:51:42 +00:00
err := gax . Invoke ( ctx , func ( ctx context . Context , settings gax . CallSettings ) error {
2017-05-11 14:39:54 +00:00
var err error
2017-07-23 07:51:42 +00:00
resp , err = c . client . AnnotateText ( ctx , req , settings . GRPC ... )
2017-05-11 14:39:54 +00:00
return err
2017-07-23 07:51:42 +00:00
} , opts ... )
2017-05-11 14:39:54 +00:00
if err != nil {
return nil , err
}
return resp , nil
}