cryptowallets

package
v16.1.0 Latest Latest
Warning

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

Go to latest
Published: Jan 10, 2025 License: MIT Imports: 3 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type AuthenticateParams

type AuthenticateParams struct {
	// CryptoWalletType: The type of wallet to authenticate. Currently `ethereum` and `solana` are supported.
	// Wallets for any EVM-compatible chains (such as Polygon or BSC) are also supported and are grouped under
	// the `ethereum` type.
	CryptoWalletType string `json:"crypto_wallet_type,omitempty"`
	// CryptoWalletAddress: The crypto wallet address to authenticate.
	CryptoWalletAddress string `json:"crypto_wallet_address,omitempty"`
	// Signature: The signature from the message challenge.
	Signature string `json:"signature,omitempty"`
	// SessionToken: The `session_token` associated with a User's existing Session.
	SessionToken string `json:"session_token,omitempty"`
	// SessionDurationMinutes: Set the session lifetime to be this many minutes from now. This will start a new
	// session if one doesn't already exist,
	//   returning both an opaque `session_token` and `session_jwt` for this session. Remember that the
	// `session_jwt` will have a fixed lifetime of
	//   five minutes regardless of the underlying session duration, and will need to be refreshed over time.
	//
	//   This value must be a minimum of 5 and a maximum of 527040 minutes (366 days).
	//
	//   If a `session_token` or `session_jwt` is provided then a successful authentication will continue to
	// extend the session this many minutes.
	//
	//   If the `session_duration_minutes` parameter is not specified, a Stytch session will not be created.
	SessionDurationMinutes int32 `json:"session_duration_minutes,omitempty"`
	// SessionJWT: The `session_jwt` associated with a User's existing Session.
	SessionJWT string `json:"session_jwt,omitempty"`
	// SessionCustomClaims: Add a custom claims map to the Session being authenticated. Claims are only created
	// if a Session is initialized by providing a value in `session_duration_minutes`. Claims will be included
	// on the Session object and in the JWT. To update a key in an existing Session, supply a new value. To
	// delete a key, supply a null value.
	//
	//   Custom claims made with reserved claims ("iss", "sub", "aud", "exp", "nbf", "iat", "jti") will be
	// ignored. Total custom claims size cannot exceed four kilobytes.
	SessionCustomClaims map[string]any `json:"session_custom_claims,omitempty"`
}

AuthenticateParams: Request type for `CryptoWallets.Authenticate`.

type AuthenticateResponse

type AuthenticateResponse struct {
	// RequestID: Globally unique UUID that is returned with every API call. This value is important to log for
	// debugging purposes; we may ask for this value to help identify a specific API call when helping you
	// debug an issue.
	RequestID string `json:"request_id,omitempty"`
	// UserID: The unique ID of the affected User.
	UserID string `json:"user_id,omitempty"`
	// SessionToken: A secret token for a given Stytch Session.
	SessionToken string `json:"session_token,omitempty"`
	// SessionJWT: The JSON Web Token (JWT) for a given Stytch Session.
	SessionJWT string `json:"session_jwt,omitempty"`
	// User: The `user` object affected by this API call. See the
	// [Get user endpoint](https://stytch.com/docs/api/get-user) for complete response field details.
	User users.User `json:"user,omitempty"`
	// StatusCode: The HTTP status code of the response. Stytch follows standard HTTP response status code
	// patterns, e.g. 2XX values equate to success, 3XX values are redirects, 4XX are client errors, and 5XX
	// are server errors.
	StatusCode int32 `json:"status_code,omitempty"`
	// Session: If you initiate a Session, by including `session_duration_minutes` in your authenticate call,
	// you'll receive a full Session object in the response.
	//
	//   See [GET sessions](https://stytch.com/docs/api/session-get) for complete response fields.
	//
	Session *sessions.Session `json:"session,omitempty"`
	// SiweParams: The parameters of the Sign In With Ethereum (SIWE) message that was signed.
	SiweParams *SIWEParamsResponse `json:"siwe_params,omitempty"`
}

AuthenticateResponse: Response type for `CryptoWallets.Authenticate`.

type AuthenticateStartParams

type AuthenticateStartParams struct {
	// CryptoWalletType: The type of wallet to authenticate. Currently `ethereum` and `solana` are supported.
	// Wallets for any EVM-compatible chains (such as Polygon or BSC) are also supported and are grouped under
	// the `ethereum` type.
	CryptoWalletType string `json:"crypto_wallet_type,omitempty"`
	// CryptoWalletAddress: The crypto wallet address to authenticate.
	CryptoWalletAddress string `json:"crypto_wallet_address,omitempty"`
	// UserID: The unique ID of a specific User.
	UserID string `json:"user_id,omitempty"`
	// SessionToken: The `session_token` associated with a User's existing Session.
	SessionToken string `json:"session_token,omitempty"`
	// SessionJWT: The `session_jwt` associated with a User's existing Session.
	SessionJWT string `json:"session_jwt,omitempty"`
	// SiweParams: The parameters for a Sign In With Ethereum (SIWE) message. May only be passed if the
	// `crypto_wallet_type` is `ethereum`.
	SiweParams *SIWEParams `json:"siwe_params,omitempty"`
}

AuthenticateStartParams: Request type for `CryptoWallets.AuthenticateStart`.

type AuthenticateStartResponse

type AuthenticateStartResponse struct {
	// RequestID: Globally unique UUID that is returned with every API call. This value is important to log for
	// debugging purposes; we may ask for this value to help identify a specific API call when helping you
	// debug an issue.
	RequestID string `json:"request_id,omitempty"`
	// UserID: The unique ID of the affected User.
	UserID string `json:"user_id,omitempty"`
	// Challenge: A challenge string to be signed by the wallet in order to prove ownership.
	Challenge string `json:"challenge,omitempty"`
	// UserCreated: In `login_or_create` endpoints, this field indicates whether or not a User was just created.
	UserCreated bool `json:"user_created,omitempty"`
	// StatusCode: The HTTP status code of the response. Stytch follows standard HTTP response status code
	// patterns, e.g. 2XX values equate to success, 3XX values are redirects, 4XX are client errors, and 5XX
	// are server errors.
	StatusCode int32 `json:"status_code,omitempty"`
}

AuthenticateStartResponse: Response type for `CryptoWallets.AuthenticateStart`.

type SIWEParams

type SIWEParams struct {
	// Domain: Only required if `siwe_params` is passed. The domain that is requesting the crypto wallet
	// signature. Must be an RFC 3986 authority.
	Domain string `json:"domain,omitempty"`
	// URI: Only required if `siwe_params` is passed. An RFC 3986 URI referring to the resource that is the
	// subject of the signing.
	URI string `json:"uri,omitempty"`
	// Resources:  A list of information or references to information the user wishes to have resolved as part
	// of authentication. Every resource must be an RFC 3986 URI.
	Resources []string `json:"resources,omitempty"`
	// ChainID: The EIP-155 Chain ID to which the session is bound. Defaults to 1. Must be the string
	// representation of an integer between 1 and 9,223,372,036,854,775,771, inclusive.
	ChainID string `json:"chain_id,omitempty"`
	// Statement: A human-readable ASCII assertion that the user will sign. The statement may only include
	// reserved, unreserved, or space characters according to RFC 3986 definitions, and must not contain other
	// forms of whitespace such as newlines, tabs, and carriage returns.
	Statement string `json:"statement,omitempty"`
	// IssuedAt: The time when the message was generated. Defaults to the current time. All timestamps in our
	// API conform to the RFC 3339 standard and are expressed in UTC, e.g. `2021-12-29T12:33:09Z`.
	IssuedAt *time.Time `json:"issued_at,omitempty"`
	// NotBefore: The time when the signed authentication message will become valid. Defaults to the current
	// time. All timestamps in our API conform to the RFC 3339 standard and are expressed in UTC, e.g.
	// `2021-12-29T12:33:09Z`.
	NotBefore *time.Time `json:"not_before,omitempty"`
	// MessageRequestID: A system-specific identifier that may be used to uniquely refer to the sign-in
	// request. The `message_request_id` must be a valid pchar according to RFC 3986 definitions.
	MessageRequestID string `json:"message_request_id,omitempty"`
}

SIWEParams:

type SIWEParamsResponse

type SIWEParamsResponse struct {
	// Domain: The domain that requested the crypto wallet signature.
	Domain string `json:"domain,omitempty"`
	// URI: An RFC 3986 URI referring to the resource that is the subject of the signing.
	URI string `json:"uri,omitempty"`
	// ChainID: The EIP-155 Chain ID to which the session is bound.
	ChainID string `json:"chain_id,omitempty"`
	// Resources:  A list of information or references to information the user wishes to have resolved as part
	// of authentication. Every resource must be an RFC 3986 URI.
	Resources  []string `json:"resources,omitempty"`
	StatusCode int32    `json:"status_code,omitempty"`
	// IssuedAt: The time when the message was generated. All timestamps in our API conform to the RFC 3339
	// standard and are expressed in UTC, e.g. `2021-12-29T12:33:09Z`.
	IssuedAt *time.Time `json:"issued_at,omitempty"`
	// MessageRequestID: A system-specific identifier that may be used to uniquely refer to the sign-in request.
	MessageRequestID string `json:"message_request_id,omitempty"`
}

SIWEParamsResponse:

Jump to

Keyboard shortcuts

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