Documentation ¶
Index ¶
- func GenerateCertificate(serviceName string, privateKey *rsa.PrivateKey, currentTime time.Time) (string, error)
- type AuditLog
- type AuditLogType
- type Email
- type Emails
- type Identities
- type Identity
- type Jwk
- type Operation
- type Passcode
- type PasswordCredential
- type PrimaryEmail
- type SamlCertificate
- type SamlState
- type Token
- type Transports
- type User
- type WebauthnCredential
- type WebauthnCredentialTransport
- type WebauthnSessionData
- type WebauthnSessionDataAllowedCredential
- type Webhook
- type WebhookEvent
- type WebhookEvents
- type Webhooks
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GenerateCertificate ¶ added in v0.9.0
Types ¶
type AuditLog ¶
type AuditLog struct { ID uuid.UUID `db:"id" json:"id"` Type AuditLogType `db:"type" json:"type"` Error *string `db:"error" json:"error,omitempty"` MetaHttpRequestId string `db:"meta_http_request_id" json:"meta_http_request_id"` MetaSourceIp string `db:"meta_source_ip" json:"meta_source_ip"` MetaUserAgent string `db:"meta_user_agent" json:"meta_user_agent"` ActorUserId *uuid.UUID `db:"actor_user_id" json:"actor_user_id,omitempty"` ActorEmail *string `db:"actor_email" json:"actor_email,omitempty"` CreatedAt time.Time `db:"created_at" json:"created_at"` UpdatedAt time.Time `db:"updated_at" json:"updated_at"` }
type AuditLogType ¶
type AuditLogType string
var ( AuditLogUserCreated AuditLogType = "user_created" AuditLogUserLoggedOut AuditLogType = "user_logged_out" AuditLogUserDeleted AuditLogType = "user_deleted" AuditLogPasswordSetSucceeded AuditLogType = "password_set_succeeded" AuditLogPasswordSetFailed AuditLogType = "password_set_failed" AuditLogPasswordLoginSucceeded AuditLogType = "password_login_succeeded" AuditLogPasswordLoginFailed AuditLogType = "password_login_failed" AuditLogPasscodeLoginInitSucceeded AuditLogType = "passcode_login_init_succeeded" AuditLogPasscodeLoginInitFailed AuditLogType = "passcode_login_init_failed" AuditLogPasscodeLoginFinalSucceeded AuditLogType = "passcode_login_final_succeeded" AuditLogPasscodeLoginFinalFailed AuditLogType = "passcode_login_final_failed" AuditLogWebAuthnRegistrationInitSucceeded AuditLogType = "webauthn_registration_init_succeeded" AuditLogWebAuthnRegistrationInitFailed AuditLogType = "webauthn_registration_init_failed" AuditLogWebAuthnRegistrationFinalSucceeded AuditLogType = "webauthn_registration_final_succeeded" AuditLogWebAuthnRegistrationFinalFailed AuditLogType = "webauthn_registration_final_failed" AuditLogWebAuthnAuthenticationInitSucceeded AuditLogType = "webauthn_authentication_init_succeeded" AuditLogWebAuthnAuthenticationInitFailed AuditLogType = "webauthn_authentication_init_failed" AuditLogWebAuthnAuthenticationFinalSucceeded AuditLogType = "webauthn_authentication_final_succeeded" AuditLogWebAuthnAuthenticationFinalFailed AuditLogType = "webauthn_authentication_final_failed" AuditLogWebAuthnCredentialUpdated AuditLogType = "webauthn_credential_updated" AuditLogWebAuthnCredentialDeleted AuditLogType = "webauthn_credential_deleted" AuditLogEmailCreated AuditLogType = "email_created" AuditLogEmailDeleted AuditLogType = "email_deleted" AuditLogEmailVerified AuditLogType = "email_verified" AuditLogPrimaryEmailChanged AuditLogType = "primary_email_changed" AuditLogThirdPartySignUpSucceeded AuditLogType = "thirdparty_signup_succeeded" AuditLogThirdPartySignInSucceeded AuditLogType = "thirdparty_signin_succeeded" AuditLogThirdPartyLinkingSucceeded AuditLogType = "thirdparty_linking_succeeded" AuditLogThirdPartySignInSignUpFailed AuditLogType = "thirdparty_signin_signup_failed" AuditLogTokenExchangeSucceeded AuditLogType = "token_exchange_succeeded" AuditLogTokenExchangeFailed AuditLogType = "token_exchange_failed" )
type Email ¶
type Email struct { ID uuid.UUID `db:"id" json:"id"` UserID *uuid.UUID `db:"user_id" json:"user_id,omitempty"` Address string `db:"address" json:"address"` Verified bool `db:"verified" json:"verified"` PrimaryEmail *PrimaryEmail `has_one:"primary_emails" json:"primary_emails,omitempty"` User *User `belongs_to:"user" json:"user,omitempty"` Identities Identities `has_many:"identities" json:"identity,omitempty"` CreatedAt time.Time `db:"created_at" json:"created_at"` UpdatedAt time.Time `db:"updated_at" json:"updated_at"` }
Email is used by pop to map your users database table to your go code.
type Emails ¶
type Emails []Email
func (Emails) GetEmailByAddress ¶ added in v0.10.0
func (Emails) GetEmailById ¶ added in v0.10.0
func (Emails) GetPrimary ¶
func (Emails) GetVerified ¶
func (Emails) SetPrimary ¶
func (emails Emails) SetPrimary(primary *PrimaryEmail)
type Identities ¶ added in v0.5.0
type Identities []Identity
func (Identities) GetIdentity ¶ added in v0.10.0
func (identities Identities) GetIdentity(providerName string, providerId string) *Identity
type Identity ¶ added in v0.5.0
type Identity struct { ID uuid.UUID `json:"id" db:"id"` ProviderID string `json:"provider_id" db:"provider_id"` ProviderName string `json:"provider_name" db:"provider_name"` Data slices.Map `json:"data" db:"data"` EmailID uuid.UUID `json:"email_id" db:"email_id"` Email *Email `json:"email,omitempty" belongs_to:"email"` CreatedAt time.Time `json:"created_at" db:"created_at"` UpdatedAt time.Time `json:"updated_at" db:"updated_at"` }
Identity is used by pop to map your identities database table to your go code.
func NewIdentity ¶ added in v0.5.0
type Jwk ¶
type Passcode ¶
type Passcode struct { ID uuid.UUID `db:"id"` UserId uuid.UUID `db:"user_id"` EmailID uuid.UUID `db:"email_id"` Ttl int `db:"ttl"` // in seconds Code string `db:"code"` TryCount int `db:"try_count"` CreatedAt time.Time `db:"created_at"` UpdatedAt time.Time `db:"updated_at"` Email Email `belongs_to:"email"` }
Passcode is used by pop to map your passcodes database table to your go code.
type PasswordCredential ¶
type PasswordCredential struct { ID uuid.UUID `db:"id"` UserId uuid.UUID `db:"user_id"` Password string `db:"password"` CreatedAt time.Time `db:"created_at"` UpdatedAt time.Time `db:"updated_at"` }
func (*PasswordCredential) Validate ¶
func (password *PasswordCredential) Validate(tx *pop.Connection) (*validate.Errors, error)
type PrimaryEmail ¶
type PrimaryEmail struct { ID uuid.UUID `db:"id" json:"id"` EmailID uuid.UUID `db:"email_id" json:"email_id"` UserID uuid.UUID `db:"user_id" json:"-"` Email *Email `belongs_to:"email" json:"email"` User *User `belongs_to:"user" json:"-"` CreatedAt time.Time `db:"created_at" json:"-"` UpdatedAt time.Time `db:"updated_at" json:"-"` }
func NewPrimaryEmail ¶
func NewPrimaryEmail(emailId uuid.UUID, userId uuid.UUID) *PrimaryEmail
func (*PrimaryEmail) Validate ¶
func (primaryEmail *PrimaryEmail) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method.
type SamlCertificate ¶ added in v0.9.0
type SamlCertificate struct { ID uuid.UUID `json:"id" db:"id"` CertData string `json:"cert_data" db:"cert_data"` CertKey string `json:"cert_key" db:"cert_key"` EncryptionKey string `json:"encryption_key" db:"encryption_key"` CreatedAt time.Time `json:"created_at" db:"created_at"` UpdatedAt time.Time `json:"updated_at" db:"updated_at"` }
SamlCertificate is used by pop to map your saml_certs database table to your go code.
func NewSamlCertificate ¶ added in v0.9.0
func NewSamlCertificate(serviceName string) (*SamlCertificate, error)
func (*SamlCertificate) DecryptCertKey ¶ added in v0.9.0
func (s *SamlCertificate) DecryptCertKey() ([]byte, error)
func (*SamlCertificate) Validate ¶ added in v0.9.0
func (s *SamlCertificate) Validate(_ *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method. This method is not required and may be deleted.
type SamlState ¶ added in v0.9.0
type Token ¶ added in v0.6.0
type Transports ¶
type Transports []WebauthnCredentialTransport
func (Transports) GetNames ¶
func (transports Transports) GetNames() []string
type User ¶
type User struct { ID uuid.UUID `db:"id" json:"id"` WebauthnCredentials []WebauthnCredential `has_many:"webauthn_credentials" json:"webauthn_credentials,omitempty"` Emails Emails `has_many:"emails" json:"-"` CreatedAt time.Time `db:"created_at" json:"created_at"` UpdatedAt time.Time `db:"updated_at" json:"updated_at"` }
User is used by pop to map your users database table to your go code.
func (*User) GetEmailByAddress ¶ added in v0.10.0
type WebauthnCredential ¶
type WebauthnCredential struct { ID string `db:"id" json:"id"` Name *string `db:"name" json:"-"` UserId uuid.UUID `db:"user_id" json:"-"` PublicKey string `db:"public_key" json:"-"` AttestationType string `db:"attestation_type" json:"-"` AAGUID uuid.UUID `db:"aaguid" json:"-"` SignCount int `db:"sign_count" json:"-"` LastUsedAt *time.Time `db:"last_used_at" json:"-"` CreatedAt time.Time `db:"created_at" json:"-"` UpdatedAt time.Time `db:"updated_at" json:"-"` Transports Transports `has_many:"webauthn_credential_transports" json:"-"` BackupEligible bool `db:"backup_eligible" json:"-"` BackupState bool `db:"backup_state" json:"-"` }
WebauthnCredential is used by pop to map your webauthn_credentials database table to your go code.
func (*WebauthnCredential) Validate ¶
func (credential *WebauthnCredential) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method.
type WebauthnCredentialTransport ¶
type WebauthnCredentialTransport struct { ID uuid.UUID `db:"id"` Name string `db:"name"` WebauthnCredentialID string `db:"webauthn_credential_id"` WebauthnCredential *WebauthnCredential `belongs_to:"webauthn_credential"` }
WebauthnCredentialTransport is used by pop to map your webauthn_credential_transport table to your go code.
func (*WebauthnCredentialTransport) Validate ¶
func (transport *WebauthnCredentialTransport) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method.
type WebauthnSessionData ¶
type WebauthnSessionData struct { ID uuid.UUID `db:"id"` Challenge string `db:"challenge"` UserId uuid.UUID `db:"user_id"` UserVerification string `db:"user_verification"` CreatedAt time.Time `db:"created_at"` UpdatedAt time.Time `db:"updated_at"` Operation Operation `db:"operation"` AllowedCredentials []WebauthnSessionDataAllowedCredential `has_many:"webauthn_session_data_allowed_credentials"` ExpiresAt nulls.Time `db:"expires_at"` }
WebauthnSessionData is used by pop to map your webauthn_session_data database table to your go code.
func (*WebauthnSessionData) Validate ¶
func (sd *WebauthnSessionData) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method.
type WebauthnSessionDataAllowedCredential ¶
type WebauthnSessionDataAllowedCredential struct { ID uuid.UUID `db:"id"` CredentialId string `db:"credential_id"` WebauthnSessionDataID uuid.UUID `db:"webauthn_session_data_id"` CreatedAt time.Time `db:"created_at"` UpdatedAt time.Time `db:"updated_at"` WebauthnSessionData *WebauthnSessionData `belongs_to:"webauthn_session_data"` }
WebauthnSessionDataAllowedCredential is used by pop to map your webauthn_session_data_allowed_credential database table to your go code.
func (*WebauthnSessionDataAllowedCredential) Validate ¶
func (credential *WebauthnSessionDataAllowedCredential) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method.
type Webhook ¶ added in v0.10.0
type Webhook struct { ID uuid.UUID `json:"id" db:"id"` Callback string `json:"callback" db:"callback"` Enabled bool `json:"enabled" db:"enabled"` Failures int `json:"failures" db:"failures"` ExpiresAt time.Time `json:"expires_at" db:"expires_at"` WebhookEvents WebhookEvents `json:"events" has_many:"webhook_events"` CreatedAt time.Time `json:"created_at" db:"created_at"` UpdatedAt time.Time `json:"updated_at" db:"updated_at"` }
Webhook is used by pop to map your webhooks database table to your go code.
type WebhookEvent ¶ added in v0.10.0
type WebhookEvent struct { ID uuid.UUID `json:"id" db:"id"` Webhook *Webhook `json:"-" belongs_to:"webhook"` WebhookID uuid.UUID `json:"-" db:"webhook_id"` Event string `json:"event" db:"event"` CreatedAt time.Time `json:"-" db:"created_at"` UpdatedAt time.Time `json:"-" db:"updated_at"` }
WebhookEvent is used by pop to map your webhook_events database table to your go code.
func (*WebhookEvent) Validate ¶ added in v0.10.0
func (w *WebhookEvent) Validate(tx *pop.Connection) (*validate.Errors, error)
Validate gets run every time you call a "pop.Validate*" (pop.ValidateAndSave, pop.ValidateAndCreate, pop.ValidateAndUpdate) method. This method is not required and may be deleted.
type WebhookEvents ¶ added in v0.10.0
type WebhookEvents []WebhookEvent
WebhookEvents is not required by pop and may be deleted