tier

package
v0.7.1 Latest Latest
Warning

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

Go to latest
Published: Jan 23, 2023 License: BSD-3-Clause Imports: 9 Imported by: 0

Documentation

Overview

Package tier contains the local client for interacting with the tier sidecar API.

For more information, please see https://tier.run/docs.

Index

Examples

Constants

View Source
const Inf = 1<<63 - 1

Variables

This section is empty.

Functions

This section is empty.

Types

type Answer added in v0.4.2

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

An Answer is the response to any question for Can. It can be used in a few forms to shorten the logic necessary to know if a program should proceed to perform a user request based on their entitlements.

func (Answer) Err added in v0.4.2

func (c Answer) Err() error

Err returns the error, if any, that occurred during the call to Can.

func (Answer) OK added in v0.4.2

func (c Answer) OK() bool

OK reports if the program should proceed with a user request or not. To prevent total failure if Can needed to reach the sidecar and was unable to, OK will fail optimistically and report true. If the opposite is desired, clients can check Err.

func (Answer) Report added in v0.4.2

func (c Answer) Report() error

Report is the same as calling ReportN(1).

func (Answer) ReportN added in v0.4.2

func (c Answer) ReportN(n int) error

ReportN reports usage of n units for the feature and org provided to Can.

type CheckoutParams added in v0.7.1

type CheckoutParams struct {
	TrialDays int
	Features  []string
	CancelURL string
}

type Client

type Client struct {
	BaseURL    string // the base URL of the tier sidecar; default is http://127.0.0.1:8080
	HTTPClient *http.Client
}
Example
package main

import (
	"io"
	"log"
	"net/http"

	"tier.run/client/tier"
)

func main() {
	c := &tier.Client{}

	m := http.NewServeMux()
	m.HandleFunc("/convert", func(w http.ResponseWriter, r *http.Request) {
		org := orgFromSession(r)
		ans := c.Can(r.Context(), org, "feature:convert")
		if ans.OK() {
			w.WriteHeader(http.StatusTooManyRequests)
			return
		}
		defer ans.Report()
		temp := convert(r.FormValue("temp"))
		io.WriteString(w, temp)
	})

	m.HandleFunc("/subscribe", func(w http.ResponseWriter, r *http.Request) {
		org := orgFromSession(r)
		plan := r.FormValue("plan")
		if err := c.Subscribe(r.Context(), org, plan); err != nil {
			w.WriteHeader(http.StatusInternalServerError)
			return
		}
	})

	log.Fatal(http.ListenAndServe(":https", m))
}

func orgFromSession(r *http.Request) string {
	return "org:example"
}

func convert(temp string) string {
	return "80F"
}
Output:

func FromEnv added in v0.7.0

func FromEnv() (*Client, error)

FromEnv returns a Client configured from the environment. The BaseURL is set to the value of the TIER_BASE_URL environment variable, or http://127.0.0.1:8080 if unset.

It returns an error if the TIER_BASE_URL environment variable is set to an invalid URL.

func (*Client) Can added in v0.4.2

func (c *Client) Can(ctx context.Context, org, feature string) Answer

Can is a convenience function for checking if an org has used more of a feature than they are entitled to and optionally reporting usage post check and consumption.

If reporting consumption is not required, it can be used in the form:

if c.Can(ctx, "org:acme", "feature:convert").OK() { ... }

reporting usage post consumption looks like:

ans := c.Can(ctx, "org:acme", "feature:convert")
if !ans.OK() {
  return ""
}
defer ans.Report() // or ReportN
return convert(temp)
Example (Basic)
package main

import (
	"context"

	"tier.run/client/tier"
)

func main() {
	c := &tier.Client{}

	// Check if the user can convert a temperature.
	if c.Can(context.Background(), "org:example", "feature:convert").OK() {
		// The user can convert a temperature.
	} else {
		// The user cannot convert a temperature.
	}
}
Output:

Example (Report)
package main

import (
	"context"
	"fmt"

	"tier.run/client/tier"
)

func main() {
	c := &tier.Client{}
	ans := c.Can(context.Background(), "org:example", "feature:convert")
	if !ans.OK() {
		// The user cannot convert a temperature.
		return
	}
	defer ans.Report() // report consumption after the conversion
	fmt.Println(convert(readInput()))
}

func convert(temp string) string {
	return "80F"
}

func readInput() string {
	return "30C"
}
Output:

func (*Client) Checkout added in v0.7.1

func (c *Client) Checkout(ctx context.Context, org string, successURL string, p *CheckoutParams) (*apitypes.CheckoutResponse, error)

Checkout creates a new checkout link for the provided org and features, if any; otherwise, if no features are specified, and payment setup link is returned instead.

func (*Client) LookupLimit added in v0.4.2

func (c *Client) LookupLimit(ctx context.Context, org, feature string) (limit, used int, err error)

LookupLimit reports the current usage and limits for the provided org and feature. If the feature is not currently available to the org, both limit and used are zero and no error is reported.

It reports an error if any.

func (*Client) LookupLimits added in v0.3.1

func (c *Client) LookupLimits(ctx context.Context, org string) (apitypes.UsageResponse, error)

LookupLimits reports the current usage and limits for the provided org.

func (*Client) LookupOrg added in v0.6.0

func (c *Client) LookupOrg(ctx context.Context, org string) (apitypes.WhoIsResponse, error)

LookupOrg reports all known information about the provided org. The information is not cached by the server. If only the Stripe customer ID is needed and speed is of concern, users should use WhoIs.

func (*Client) LookupPhase added in v0.4.2

func (c *Client) LookupPhase(ctx context.Context, org string) (apitypes.PhaseResponse, error)

LookupPhase reports information about the current phase the provided org is scheduled in.

func (*Client) Pull

func (c *Client) Pull(ctx context.Context) (apitypes.Model, error)

Pull fetches the complete pricing model from Stripe.

func (*Client) PullJSON added in v0.4.2

func (c *Client) PullJSON(ctx context.Context) ([]byte, error)

PullJSON fetches the complete pricing model from Stripe and returns the raw JSON response.

func (*Client) Push

Push pushes the provided pricing model to Stripe.

func (*Client) PushJSON added in v0.4.2

func (c *Client) PushJSON(ctx context.Context, m []byte) (apitypes.PushResponse, error)

func (*Client) Report added in v0.4.2

func (c *Client) Report(ctx context.Context, org, feature string, n int) error

Report reports a usage of n for the provided org and feature at the current time.

func (*Client) ReportUsage

func (c *Client) ReportUsage(ctx context.Context, org, feature string, n int, rp *ReportParams) error

ReportUsage reports usage based on the provided ReportRequest fields.

func (*Client) Schedule added in v0.6.0

func (c *Client) Schedule(ctx context.Context, org string, p *ScheduleParams) (*apitypes.ScheduleResponse, error)

func (*Client) Subscribe

func (c *Client) Subscribe(ctx context.Context, org string, featuresAndPlans ...string) error

Subscribe subscribes the provided org to the provided feature or plan, effective immediately.

Any in-progress scheduled is overwritten and the customer is billed with prorations immediately.

func (*Client) WhoAmI added in v0.5.0

func (c *Client) WhoAmI(ctx context.Context) (apitypes.WhoAmIResponse, error)

func (*Client) WhoIs

func (c *Client) WhoIs(ctx context.Context, org string) (apitypes.WhoIsResponse, error)

WhoIS reports the Stripe ID for the given organization.

type OrgInfo added in v0.6.0

type OrgInfo = apitypes.OrgInfo

type Phase

type Phase = apitypes.Phase

type ReportParams added in v0.7.0

type ReportParams struct {
	At      time.Time // default is time.Now()
	Clobber bool      // default is false
}

type ScheduleParams added in v0.6.0

type ScheduleParams struct {
	Info   *OrgInfo
	Phases []Phase
}

Jump to

Keyboard shortcuts

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