Documentation ¶
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client is the AppSync GraphQL API client
Example (Graphqlws_subscription) ¶
package main import ( "encoding/json" "fmt" "log" "strings" "github.com/modusCell/mo-appsync-client-go/internal/appsynctest" appsync "github.com/modusCell/mo-appsync-client-go" "github.com/modusCell/mo-appsync-client-go/graphql" ) func main() { server := appsynctest.NewAppSyncEchoServer() defer server.Close() client := appsync.NewClient(appsync.NewGraphQLClient(graphql.NewClient(server.URL))) subscription := `subscription SubscribeToEcho() { subscribeToEcho }` ch := make(chan *graphql.Response) subscriber := appsync.NewPureWebSocketSubscriber( strings.Replace(server.URL, "http", "ws", 1), graphql.PostRequest{ Query: subscription, }, func(r *graphql.Response) { ch <- r }, func(err error) { log.Println(err) }, ) if err := subscriber.Start(); err != nil { log.Fatalln(err) } defer subscriber.Stop() mutation := `mutation Echo($message: String!) { echo(message: $message) }` variables := json.RawMessage(fmt.Sprintf(`{ "message": "%s" }`, "Hi, AppSync!")) _, err := client.Post(graphql.PostRequest{ Query: mutation, Variables: &variables, }) if err != nil { log.Fatal(err) } response := <-ch data := new(string) if err := response.DataAs(data); err != nil { log.Fatalln(err, response) } fmt.Println(*data) }
Output: Hi, AppSync!
Example (Mqtt_subscription) ¶
package main import ( "encoding/json" "fmt" "log" "github.com/modusCell/mo-appsync-client-go/internal/appsynctest" appsync "github.com/modusCell/mo-appsync-client-go" "github.com/modusCell/mo-appsync-client-go/graphql" ) func main() { server := appsynctest.NewAppSyncEchoServer() defer server.Close() client := appsync.NewClient(appsync.NewGraphQLClient(graphql.NewClient(server.URL))) subscription := `subscription SubscribeToEcho() { subscribeToEcho }` response, err := client.Post(graphql.PostRequest{ Query: subscription, }) if err != nil { log.Fatal(err) } ext, err := appsync.NewExtensions(response) if err != nil { log.Fatalln(err) } ch := make(chan *graphql.Response) subscriber := appsync.NewSubscriber(*ext, func(r *graphql.Response) { ch <- r }, func(err error) { log.Println(err) }, ) if err := subscriber.Start(); err != nil { log.Fatalln(err) } defer subscriber.Stop() mutation := `mutation Echo($message: String!) { echo(message: $message) }` variables := json.RawMessage(fmt.Sprintf(`{ "message": "%s" }`, "Hi, AppSync!")) _, err = client.Post(graphql.PostRequest{ Query: mutation, Variables: &variables, }) if err != nil { log.Fatal(err) } response = <-ch data := new(string) if err := response.DataAs(data); err != nil { log.Fatalln(err, response) } fmt.Println(*data) }
Output: Hi, AppSync!
func NewClient ¶
func NewClient(graphql GraphQLClient, opts ...ClientOption) *Client
NewClient returns a Client instance.
func (*Client) Post ¶
Post is a synchronous AppSync GraphQL POST request.
Example (Mutation) ¶
package main import ( "encoding/json" "fmt" "log" "github.com/modusCell/mo-appsync-client-go/internal/appsynctest" appsync "github.com/modusCell/mo-appsync-client-go" "github.com/modusCell/mo-appsync-client-go/graphql" ) func main() { server := appsynctest.NewAppSyncEchoServer() defer server.Close() client := appsync.NewClient(appsync.NewGraphQLClient(graphql.NewClient(server.URL))) mutation := `mutation Echo($message: String!) { echo(message: $message) }` variables := json.RawMessage(fmt.Sprintf(`{ "message": "%s" }`, "Hi, AppSync!")) response, err := client.Post(graphql.PostRequest{ Query: mutation, Variables: &variables, }) if err != nil { log.Fatal(err) } data := new(string) if err := response.DataAs(data); err != nil { log.Fatalln(err, response) } fmt.Println(*data) }
Output: Hi, AppSync!
Example (Query) ¶
package main import ( "fmt" "log" "github.com/modusCell/mo-appsync-client-go/internal/appsynctest" appsync "github.com/modusCell/mo-appsync-client-go" "github.com/modusCell/mo-appsync-client-go/graphql" ) func main() { server := appsynctest.NewAppSyncEchoServer() defer server.Close() query := `query Message() { message }` client := appsync.NewClient(appsync.NewGraphQLClient(graphql.NewClient(server.URL))) response, err := client.Post(graphql.PostRequest{ Query: query, }) if err != nil { log.Fatal(err) } data := new(string) if err := response.DataAs(data); err != nil { log.Fatalln(err, response) } fmt.Println(*data) }
Output: Hello, AppSync!
type ClientOption ¶
type ClientOption func(*Client)
ClientOption represents options for an AppSync client.
func WithIAMAuthorization ¶
func WithIAMAuthorization(signer v4.Signer, region, host string) ClientOption
WithIAMAuthorization returns a ClientOption configured with the given signature version 4 signer.
func WithSubscriberID ¶
func WithSubscriberID(subscriberID string) ClientOption
WithSubscriberID returns a ClientOption configured with the given AppSync subscriber ID
type Extensions ¶
type Extensions struct { Subscription struct { Version string `json:"version"` MqttConnections []struct { URL string `json:"url"` Topics []string `json:"topics"` Client string `json:"client"` } `json:"mqttConnections"` NewSubscriptions map[string]Subscription `json:"newSubscriptions"` } `json:"subscription"` }
Extensions represents AWS AppSync subscription response extensions
func NewExtensions ¶
func NewExtensions(response *graphql.Response) (*Extensions, error)
NewExtensions returns Extensions instance
type GraphQLClient ¶
type GraphQLClient interface { Post(header http.Header, request graphql.PostRequest) (*graphql.Response, error) PostAsync(header http.Header, request graphql.PostRequest, callback func(*graphql.Response, error)) (context.CancelFunc, error) }
GraphQLClient is the interface to access GraphQL server.
func NewGraphQLClient ¶
func NewGraphQLClient(client *graphql.Client) GraphQLClient
NewGraphQLClient returns a GraphQLClient interface
type PureWebSocketSubscriber ¶
type PureWebSocketSubscriber struct {
// contains filtered or unexported fields
}
PureWebSocketSubscriber has pure WebSocket connections and subscription information.
func NewPureWebSocketSubscriber ¶
func NewPureWebSocketSubscriber(realtimeEndpoint string, request graphql.PostRequest, onReceive func(response *graphql.Response), onConnectionLost func(err error), opts ...PureWebSocketSubscriberOption) *PureWebSocketSubscriber
NewPureWebSocketSubscriber returns a PureWebSocketSubscriber instance.
func (*PureWebSocketSubscriber) Start ¶
func (p *PureWebSocketSubscriber) Start() error
Start starts a new subscription.
func (*PureWebSocketSubscriber) Stop ¶
func (p *PureWebSocketSubscriber) Stop()
Stop ends the subscription.
type PureWebSocketSubscriberOption ¶
type PureWebSocketSubscriberOption func(*PureWebSocketSubscriber)
PureWebSocketSubscriberOption represents options for an PureWebSocketSubscriber.
func WithAPIKey ¶
func WithAPIKey(host, apiKey string) PureWebSocketSubscriberOption
WithAPIKey returns a PureWebSocketSubscriberOption configured with the host for the AWS AppSync GraphQL endpoint and API key
func WithIAM ¶
func WithIAM(signer *v4.Signer, region, host string) PureWebSocketSubscriberOption
WithIAM returns a PureWebSocketSubscriberOption configured with the signature version 4 signer, the region and the host for the AWS AppSync GraphQL endpoint.
func WithLambda ¶
func WithLambda(host, lambdaToken string) PureWebSocketSubscriberOption
func WithOIDC ¶
func WithOIDC(host, jwt string) PureWebSocketSubscriberOption
WithOIDC returns a PureWebSocketSubscriberOption configured with the host for the AWS AppSync GraphQL endpoint and JWT Access Token.
type Subscriber ¶
type Subscriber struct {
// contains filtered or unexported fields
}
Subscriber has MQTT connections and subscription information.
func NewSubscriber ¶
func NewSubscriber(extensions Extensions, callback func(response *graphql.Response), onConnectionLost func(err error)) *Subscriber
NewSubscriber returns a new Subscriber instance.
type Subscription ¶
type Subscription struct { Topic string `json:"topic"` ExpireTime interface{} `json:"expireTime"` }
Subscription represents AWS AppSync subscription mqtt topic