Documentation ¶
Index ¶
Constants ¶
View Source
const ( ColAmount = "amount" ColReferredBy = "referred_by" ColLevel = "level" ColCountry = "country" )
View Source
const ( ColReserved = "reserved" ColWithdrawn = "withdrawn" )
View Source
const DefaultCountryCode = "default"
DefaultCountryCode is the special code, where the default settings for countries are stored. When a user's country is not found, it must be added to DB with its own code and default settings.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type BalancesQ ¶
type BalancesQ interface { New() BalancesQ Insert(Balance) error Update(map[string]any) error Page(*pgdb.OffsetPageParams) BalancesQ Select() ([]Balance, error) Get() (*Balance, error) // GetWithRank returns balance with rank, filtered by nullifier. No other filters can be applied. GetWithRank(nullifier string) (*Balance, error) SelectWithRank() ([]Balance, error) // Filters not applied. Return balances which already have scanned passport, but there no fulfilled or claimed events for this WithoutPassportEvent() ([]WithoutPassportEventBalance, error) WithoutReferralEvent() ([]ReferredReferrer, error) FilterByNullifier(string) BalancesQ FilterDisabled() BalancesQ }
type CountriesQ ¶ added in v0.2.1
type CountriesQ interface { New() CountriesQ Insert(countries ...Country) error Update(map[string]any) error // UpdateMany updates only reserve_limit, reserve_allowed and withdrawal_allowed UpdateMany([]Country) error Select() ([]Country, error) Get() (*Country, error) FilterByCodes(codes ...string) CountriesQ }
type Event ¶
type Event struct { ID string `db:"id"` Nullifier string `db:"nullifier"` Type string `db:"type"` Status EventStatus `db:"status"` CreatedAt int32 `db:"created_at"` UpdatedAt int32 `db:"updated_at"` Meta Jsonb `db:"meta"` PointsAmount *int64 `db:"points_amount"` ExternalID sql.NullString `db:"external_id"` // hidden from client }
type EventStatus ¶
type EventStatus string
const ( EventOpen EventStatus = "open" EventFulfilled EventStatus = "fulfilled" EventClaimed EventStatus = "claimed" )
func (EventStatus) String ¶
func (s EventStatus) String() string
type EventsQ ¶
type EventsQ interface { New() EventsQ Insert(...Event) error Update(status EventStatus, meta json.RawMessage, points *int64) (*Event, error) Delete() (rowsAffected int64, err error) Transaction(func() error) error Page(*pgdb.OffsetPageParams) EventsQ Select() ([]Event, error) Get() (*Event, error) // Count returns the total number of events that match filters. Page is not // applied to this method. Count() (int, error) // SelectReopenable returns events matching criteria: there are no open or // fulfilled events of this type for a specific user. SelectReopenable() ([]ReopenableEvent, error) // SelectAbsentTypes returns events matching criteria: there are no events of // this type for a specific user. Filters are not applied to this selection. SelectAbsentTypes(allTypes ...string) ([]ReopenableEvent, error) FilterByID(...string) EventsQ FilterByNullifier(string) EventsQ FilterByStatus(...EventStatus) EventsQ FilterByType(...string) EventsQ FilterByUpdatedAtBefore(int64) EventsQ FilterByExternalID(string) EventsQ FilterInactiveNotClaimed(types ...string) EventsQ }
type ReferralsQ ¶
type ReferralsQ interface { New() ReferralsQ Insert(...Referral) error Consume(ids ...string) (consumedIDs []string, err error) ConsumeFirst(nullifier string, count uint64) error Select() ([]Referral, error) Get(id string) (*Referral, error) Count() (uint64, error) FilterByNullifier(string) ReferralsQ FilterConsumed() ReferralsQ }
type ReferredReferrer ¶ added in v0.2.1
type ReopenableEvent ¶
ReopenableEvent is a pair that is sufficient to build a new open event with a specific type for a user
type Withdrawal ¶
type WithdrawalsQ ¶
type WithdrawalsQ interface { New() WithdrawalsQ Insert(Withdrawal) (*Withdrawal, error) Page(*pgdb.CursorPageParams) WithdrawalsQ Select() ([]Withdrawal, error) FilterByNullifier(string) WithdrawalsQ }
type WithoutPassportEventBalance ¶ added in v0.2.1
Source Files ¶
Click to show internal directories.
Click to hide internal directories.