Documentation ¶
Overview ¶
Package adapter contains the interfaces to be implemented by the database adapter
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Adapter ¶
type Adapter interface { Open(config string) error Close() error IsOpen() bool CheckDbVersion() error GetName() string CreateDb(reset bool) error // User management UserCreate(usr *t.User) error UserGet(id t.Uid) (*t.User, error) UserGetAll(ids ...t.Uid) ([]t.User, error) UserDelete(id t.Uid, soft bool) error UserUpdateLastSeen(uid t.Uid, userAgent string, when time.Time) error UserUpdate(uid t.Uid, update map[string]interface{}) error // Credential management CredAdd(cred *t.Credential) error CredIsConfirmed(uid t.Uid, metod string) (bool, error) CredDel(uid t.Uid, method string) error CredConfirm(uid t.Uid, method string) error CredFail(uid t.Uid, method string) error CredGet(uid t.Uid, method string) ([]*t.Credential, error) // Authentication management for the basic authentication scheme AuthGetRecord(unique string) (t.Uid, auth.Level, []byte, time.Time, error) AuthAddRecord(user t.Uid, authLvl auth.Level, unique string, secret []byte, expires time.Time) (bool, error) AuthDelRecord(user t.Uid, unique string) error AuthDelAllRecords(uid t.Uid) (int, error) AuthUpdRecord(unique string, authLvl auth.Level, secret []byte, expires time.Time) (int, error) // TopicCreate creates a topic TopicCreate(topic *t.Topic) error // TopicCreateP2P creates a p2p topic TopicCreateP2P(initiator, invited *t.Subscription) error // TopicGet loads a single topic by name, if it exists. If the topic does not exist the call returns (nil, nil) TopicGet(topic string) (*t.Topic, error) // TopicsForUser loads subscriptions for a given user. Reads public value. TopicsForUser(uid t.Uid, keepDeleted bool) ([]t.Subscription, error) // UsersForTopic loads users' subscriptions for a given topic UsersForTopic(topic string, keepDeleted bool) ([]t.Subscription, error) TopicDelete(topic string) error // Increment Topic's or User's SeqId value TopicUpdateOnMessage(topic string, msg *t.Message) error TopicUpdate(topic string, update map[string]interface{}) error // SubscriptionGet rads a subscription of a user to a topic SubscriptionGet(topic string, user t.Uid) (*t.Subscription, error) // SubsForUser gets a list of topics of interest for a given user. Does NOT read public value. SubsForUser(user t.Uid, keepDeleted bool) ([]t.Subscription, error) // SubsForTopic gets a list of subscriptions to a given topic SubsForTopic(topic string, keepDeleted bool) ([]t.Subscription, error) // SubsUpdate updates pasrt of a subscription object. Pass nil for fields which don't need to be updated SubsUpdate(topic string, user t.Uid, update map[string]interface{}) error // SubsDelete deletes a single subscription SubsDelete(topic string, user t.Uid) error // SubsDelForTopic soft-deletes all subscriptions to the given topic SubsDelForTopic(topic string) error // SubsDelForUser soft-deletes all subscriptions of the given user SubsDelForUser(user t.Uid) error // FindUsers searches for new contacts given a list of tags FindUsers(user t.Uid, tags []string) ([]t.Subscription, error) // FindTopics searches for group topics given a list of tags FindTopics(tags []string) ([]t.Subscription, error) // Messages MessageSave(msg *t.Message) error MessageGetAll(topic string, forUser t.Uid, opts *t.BrowseOpt) ([]t.Message, error) // Mark messages as deleted. Soft- or Hard- is defined by forUser value: forUSer.IsZero == true is hard. MessageDeleteList(topic string, toDel *t.DelMessage) error // Get a list of deleted message Ids MessageGetDeleted(topic string, forUser t.Uid, opts *t.BrowseOpt) ([]t.DelMessage, error) // Devices (for push notifications) DeviceUpsert(uid t.Uid, dev *t.DeviceDef) error DeviceGetAll(uid ...t.Uid) (map[t.Uid][]t.DeviceDef, int, error) DeviceDelete(uid t.Uid, deviceID string) error }
Adapter is the interface that must be implemented by a database adapter. The current schema supports a single connection by database type.
Click to show internal directories.
Click to hide internal directories.