aip

package module
v0.68.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 16, 2024 License: MIT Imports: 0 Imported by: 0

README

Go Reference

AIP Go

Go SDK for implementing Google API Improvement Proposals (AIP).

Generate AIP support code from proto

go install go.einride.tech/aip/cmd/protoc-gen-go-aip

Add to buf.gen.yaml:

version: v2
plugins:
  - local: protoc-gen-go-aip
    out: gen
    opt:
      - paths=source_relative

Run buf build to generate e.g. your_service_aip.go.

Library usage examples

go get -u go.einride.tech/aip
AIP-132 (Standard method: List)
  • Use pagination.PageToken to implement offset-based pagination.

    package examplelibrary
    
    import (
        "context"
    
        "go.einride.tech/aip/pagination"
        "google.golang.org/genproto/googleapis/example/library/v1"
        "google.golang.org/grpc/codes"
        "google.golang.org/grpc/status"
    )
    
    func (s *Server) ListShelves(
        ctx context.Context,
        request *library.ListShelvesRequest,
    ) (*library.ListShelvesResponse, error) {
        // Handle request constraints.
        const (
    §           maxPageSize     = 1000
            defaultPageSize = 100
        )
        switch {
        case request.PageSize < 0:
            return nil, status.Errorf(codes.InvalidArgument, "page size is negative")
        case request.PageSize == 0:
            request.PageSize = defaultPageSize
        case request.PageSize > maxPageSize:
            request.PageSize = maxPageSize
        }
        // Use pagination.PageToken for offset-based page tokens.
        pageToken, err := pagination.ParsePageToken(request)
        if err != nil {
            return nil, status.Errorf(codes.InvalidArgument, "invalid page token")
        }
        // Query the storage.
        result, err := s.Storage.ListShelves(ctx, &ListShelvesQuery{
            Offset:   pageToken.Offset,
            PageSize: request.GetPageSize(),
        })
        if err != nil {
            return nil, err
        }
        // Build the response.
        response := &library.ListShelvesResponse{
            Shelves: result.Shelves,
        }
        // Set the next page token.
        if result.HasNextPage {
            response.NextPageToken = pageToken.Next(request).String()
        }
        // Respond.
        return response, nil
    }
    

Documentation

Overview

Package aip provides primitives for implementing API Improvement Proposals (AIP).

Directories

Path Synopsis
cmd
protoc-gen-go-aip/internal/genaip
Package genaip provides a protobuf compiler plugin for resource-oriented gRPC APIs.
Package genaip provides a protobuf compiler plugin for resource-oriented gRPC APIs.
examples
Package fieldbehavior provides primitives for implementing AIP fieldbehavior annotations.
Package fieldbehavior provides primitives for implementing AIP fieldbehavior annotations.
Package fieldmask provides primitives for implementing AIP field mask functionality.
Package fieldmask provides primitives for implementing AIP field mask functionality.
Package filtering provides primitives for implementing AIP filtering.
Package filtering provides primitives for implementing AIP filtering.
exprs
Package exprs provides primitives for working with v1alpha1/expr values.
Package exprs provides primitives for working with v1alpha1/expr values.
Package ordering provides primitives for implementing AIP ordering.
Package ordering provides primitives for implementing AIP ordering.
Package pagination provides primitives for implementing AIP pagination.
Package pagination provides primitives for implementing AIP pagination.
proto
reflect
aipreflect
Package aipreflect provides primitives to manipulate AIP annotations and descriptors.
Package aipreflect provides primitives to manipulate AIP annotations and descriptors.
Package resourcename implements simple functions to manipulate UTF-8 encoded AIP resource names.
Package resourcename implements simple functions to manipulate UTF-8 encoded AIP resource names.
Package validation provides primitives for validating proto messages and gRPC requests.
Package validation provides primitives for validating proto messages and gRPC requests.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL