mirror of
https://github.com/pocketbase/pocketbase.git
synced 2025-01-10 00:43:36 +02:00
441 lines
19 KiB
Go
441 lines
19 KiB
Go
// Package core is the backbone of PocketBase.
|
|
//
|
|
// It defines the main PocketBase App interface and its base implementation.
|
|
package core
|
|
|
|
import (
|
|
"github.com/pocketbase/dbx"
|
|
"github.com/pocketbase/pocketbase/daos"
|
|
"github.com/pocketbase/pocketbase/tools/filesystem"
|
|
"github.com/pocketbase/pocketbase/tools/hook"
|
|
"github.com/pocketbase/pocketbase/tools/mailer"
|
|
"github.com/pocketbase/pocketbase/tools/store"
|
|
"github.com/pocketbase/pocketbase/tools/subscriptions"
|
|
)
|
|
|
|
// App defines the main PocketBase app interface.
|
|
type App interface {
|
|
// DB returns the default app database instance.
|
|
DB() *dbx.DB
|
|
|
|
// Dao returns the default app Dao instance.
|
|
//
|
|
// This Dao could operate only on the tables and models
|
|
// associated with the default app database. For example,
|
|
// trying to access the request logs table will result in error.
|
|
Dao() *daos.Dao
|
|
|
|
// LogsDB returns the app logs database instance.
|
|
LogsDB() *dbx.DB
|
|
|
|
// LogsDao returns the app logs Dao instance.
|
|
//
|
|
// This Dao could operate only on the tables and models
|
|
// associated with the logs database. For example, trying to access
|
|
// the users table from LogsDao will result in error.
|
|
LogsDao() *daos.Dao
|
|
|
|
// DataDir returns the app data directory path.
|
|
DataDir() string
|
|
|
|
// EncryptionEnv returns the name of the app secret env key
|
|
// (used for settings encryption).
|
|
EncryptionEnv() string
|
|
|
|
// IsDebug returns whether the app is in debug mode
|
|
// (showing more detailed error logs, executed sql statements, etc.).
|
|
IsDebug() bool
|
|
|
|
// Settings returns the loaded app settings.
|
|
Settings() *Settings
|
|
|
|
// Cache returns the app internal cache store.
|
|
Cache() *store.Store[any]
|
|
|
|
// SubscriptionsBroker returns the app realtime subscriptions broker instance.
|
|
SubscriptionsBroker() *subscriptions.Broker
|
|
|
|
// NewMailClient creates and returns a configured app mail client.
|
|
NewMailClient() mailer.Mailer
|
|
|
|
// NewFilesystem creates and returns a configured filesystem.System instance.
|
|
//
|
|
// NB! Make sure to call `Close()` on the returned result
|
|
// after you are done working with it.
|
|
NewFilesystem() (*filesystem.System, error)
|
|
|
|
// RefreshSettings reinitializes and reloads the stored application settings.
|
|
RefreshSettings() error
|
|
|
|
// Bootstrap takes care for initializing the application
|
|
// (open db connections, load settings, etc.)
|
|
Bootstrap() error
|
|
|
|
// ResetBootstrapState takes care for releasing initialized app resources
|
|
// (eg. closing db connections).
|
|
ResetBootstrapState() error
|
|
|
|
// ---------------------------------------------------------------
|
|
// App event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnBeforeServe hook is triggered before serving the internal router (echo),
|
|
// allowing you to adjust its options and attach new routes.
|
|
OnBeforeServe() *hook.Hook[*ServeEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Dao event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnModelBeforeCreate hook is triggered before inserting a new
|
|
// entry in the DB, allowing you to modify or validate the stored data.
|
|
OnModelBeforeCreate() *hook.Hook[*ModelEvent]
|
|
|
|
// OnModelAfterCreate hook is triggered after successfully
|
|
// inserting a new entry in the DB.
|
|
OnModelAfterCreate() *hook.Hook[*ModelEvent]
|
|
|
|
// OnModelBeforeUpdate hook is triggered before updating existing
|
|
// entry in the DB, allowing you to modify or validate the stored data.
|
|
OnModelBeforeUpdate() *hook.Hook[*ModelEvent]
|
|
|
|
// OnModelAfterUpdate hook is triggered after successfully updating
|
|
// existing entry in the DB.
|
|
OnModelAfterUpdate() *hook.Hook[*ModelEvent]
|
|
|
|
// OnModelBeforeDelete hook is triggered before deleting an
|
|
// existing entry from the DB.
|
|
OnModelBeforeDelete() *hook.Hook[*ModelEvent]
|
|
|
|
// OnModelAfterDelete is triggered after successfully deleting an
|
|
// existing entry from the DB.
|
|
OnModelAfterDelete() *hook.Hook[*ModelEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Mailer event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnMailerBeforeAdminResetPasswordSend hook is triggered right before
|
|
// sending a password reset email to an admin.
|
|
//
|
|
// Could be used to send your own custom email template if
|
|
// [hook.StopPropagation] is returned in one of its listeners.
|
|
OnMailerBeforeAdminResetPasswordSend() *hook.Hook[*MailerAdminEvent]
|
|
|
|
// OnMailerAfterAdminResetPasswordSend hook is triggered after
|
|
// admin password reset email was successfully sent.
|
|
OnMailerAfterAdminResetPasswordSend() *hook.Hook[*MailerAdminEvent]
|
|
|
|
// OnMailerBeforeUserResetPasswordSend hook is triggered right before
|
|
// sending a password reset email to a user.
|
|
//
|
|
// Could be used to send your own custom email template if
|
|
// [hook.StopPropagation] is returned in one of its listeners.
|
|
OnMailerBeforeUserResetPasswordSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// OnMailerAfterUserResetPasswordSend hook is triggered after
|
|
// a user password reset email was successfully sent.
|
|
OnMailerAfterUserResetPasswordSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// OnMailerBeforeUserVerificationSend hook is triggered right before
|
|
// sending a verification email to a user.
|
|
//
|
|
// Could be used to send your own custom email template if
|
|
// [hook.StopPropagation] is returned in one of its listeners.
|
|
OnMailerBeforeUserVerificationSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// OnMailerAfterUserVerificationSend hook is triggered after a user
|
|
// verification email was successfully sent.
|
|
OnMailerAfterUserVerificationSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// OnMailerBeforeUserChangeEmailSend hook is triggered right before
|
|
// sending a confirmation new address email to a a user.
|
|
//
|
|
// Could be used to send your own custom email template if
|
|
// [hook.StopPropagation] is returned in one of its listeners.
|
|
OnMailerBeforeUserChangeEmailSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// OnMailerAfterUserChangeEmailSend hook is triggered after a user
|
|
// change address email was successfully sent.
|
|
OnMailerAfterUserChangeEmailSend() *hook.Hook[*MailerUserEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Realtime API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnRealtimeConnectRequest hook is triggered right before establishing
|
|
// the SSE client connection.
|
|
OnRealtimeConnectRequest() *hook.Hook[*RealtimeConnectEvent]
|
|
|
|
// OnRealtimeBeforeSubscribeRequest hook is triggered before changing
|
|
// the client subscriptions, allowing you to further validate and
|
|
// modify the submitted change.
|
|
OnRealtimeBeforeSubscribeRequest() *hook.Hook[*RealtimeSubscribeEvent]
|
|
|
|
// OnRealtimeAfterSubscribeRequest hook is triggered after the client
|
|
// subscriptions were successfully changed.
|
|
OnRealtimeAfterSubscribeRequest() *hook.Hook[*RealtimeSubscribeEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Settings API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnSettingsListRequest hook is triggered on each successful
|
|
// API Settings list request.
|
|
//
|
|
// Could be used to validate or modify the response before
|
|
// returning it to the client.
|
|
OnSettingsListRequest() *hook.Hook[*SettingsListEvent]
|
|
|
|
// OnSettingsBeforeUpdateRequest hook is triggered before each API
|
|
// Settings update request (after request data load and before settings persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or
|
|
// implement completely different persistence behavior
|
|
// (returning [hook.StopPropagation]).
|
|
OnSettingsBeforeUpdateRequest() *hook.Hook[*SettingsUpdateEvent]
|
|
|
|
// OnSettingsAfterUpdateRequest hook is triggered after each
|
|
// successful API Settings update request.
|
|
OnSettingsAfterUpdateRequest() *hook.Hook[*SettingsUpdateEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// File API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnFileDownloadRequest hook is triggered before each API File download request.
|
|
//
|
|
// Could be used to validate or modify the file response before
|
|
// returning it to the client.
|
|
OnFileDownloadRequest() *hook.Hook[*FileDownloadEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Admin API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnAdminsListRequest hook is triggered on each API Admins list request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnAdminsListRequest() *hook.Hook[*AdminsListEvent]
|
|
|
|
// OnAdminViewRequest hook is triggered on each API Admin view request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnAdminViewRequest() *hook.Hook[*AdminViewEvent]
|
|
|
|
// OnAdminBeforeCreateRequest hook is triggered before each API
|
|
// Admin create request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnAdminBeforeCreateRequest() *hook.Hook[*AdminCreateEvent]
|
|
|
|
// OnAdminAfterCreateRequest hook is triggered after each
|
|
// successful API Admin create request.
|
|
OnAdminAfterCreateRequest() *hook.Hook[*AdminCreateEvent]
|
|
|
|
// OnAdminBeforeUpdateRequest hook is triggered before each API
|
|
// Admin update request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnAdminBeforeUpdateRequest() *hook.Hook[*AdminUpdateEvent]
|
|
|
|
// OnAdminAfterUpdateRequest hook is triggered after each
|
|
// successful API Admin update request.
|
|
OnAdminAfterUpdateRequest() *hook.Hook[*AdminUpdateEvent]
|
|
|
|
// OnAdminBeforeDeleteRequest hook is triggered before each API
|
|
// Admin delete request (after model load and before actual deletion).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different delete behavior (returning [hook.StopPropagation]).
|
|
OnAdminBeforeDeleteRequest() *hook.Hook[*AdminDeleteEvent]
|
|
|
|
// OnAdminAfterDeleteRequest hook is triggered after each
|
|
// successful API Admin delete request.
|
|
OnAdminAfterDeleteRequest() *hook.Hook[*AdminDeleteEvent]
|
|
|
|
// OnAdminAuthRequest hook is triggered on each successful API Admin
|
|
// authentication request (sign-in, token refresh, etc.).
|
|
//
|
|
// Could be used to additionally validate or modify the
|
|
// authenticated admin data and token.
|
|
OnAdminAuthRequest() *hook.Hook[*AdminAuthEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// User API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnUsersListRequest hook is triggered on each API Users list request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnUsersListRequest() *hook.Hook[*UsersListEvent]
|
|
|
|
// OnUserViewRequest hook is triggered on each API User view request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnUserViewRequest() *hook.Hook[*UserViewEvent]
|
|
|
|
// OnUserBeforeCreateRequest hook is triggered before each API User
|
|
// create request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnUserBeforeCreateRequest() *hook.Hook[*UserCreateEvent]
|
|
|
|
// OnUserAfterCreateRequest hook is triggered after each
|
|
// successful API User create request.
|
|
OnUserAfterCreateRequest() *hook.Hook[*UserCreateEvent]
|
|
|
|
// OnUserBeforeUpdateRequest hook is triggered before each API User
|
|
// update request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnUserBeforeUpdateRequest() *hook.Hook[*UserUpdateEvent]
|
|
|
|
// OnUserAfterUpdateRequest hook is triggered after each
|
|
// successful API User update request.
|
|
OnUserAfterUpdateRequest() *hook.Hook[*UserUpdateEvent]
|
|
|
|
// OnUserBeforeDeleteRequest hook is triggered before each API User
|
|
// delete request (after model load and before actual deletion).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different delete behavior (returning [hook.StopPropagation]).
|
|
OnUserBeforeDeleteRequest() *hook.Hook[*UserDeleteEvent]
|
|
|
|
// OnUserAfterDeleteRequest hook is triggered after each
|
|
// successful API User delete request.
|
|
OnUserAfterDeleteRequest() *hook.Hook[*UserDeleteEvent]
|
|
|
|
// OnUserAuthRequest hook is triggered on each successful API User
|
|
// authentication request (sign-in, token refresh, etc.).
|
|
//
|
|
// Could be used to additionally validate or modify the
|
|
// authenticated user data and token.
|
|
OnUserAuthRequest() *hook.Hook[*UserAuthEvent]
|
|
|
|
// OnUserListExternalAuths hook is triggered on each API user's external auths list request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnUserListExternalAuths() *hook.Hook[*UserListExternalAuthsEvent]
|
|
|
|
// OnUserBeforeUnlinkExternalAuthRequest hook is triggered before each API user's
|
|
// external auth unlink request (after models load and before the actual relation deletion).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different delete behavior (returning [hook.StopPropagation]).
|
|
OnUserBeforeUnlinkExternalAuthRequest() *hook.Hook[*UserUnlinkExternalAuthEvent]
|
|
|
|
// OnUserAfterUnlinkExternalAuthRequest hook is triggered after each
|
|
// successful API user's external auth unlink request.
|
|
OnUserAfterUnlinkExternalAuthRequest() *hook.Hook[*UserUnlinkExternalAuthEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Record API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnRecordsListRequest hook is triggered on each API Records list request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnRecordsListRequest() *hook.Hook[*RecordsListEvent]
|
|
|
|
// OnRecordViewRequest hook is triggered on each API Record view request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnRecordViewRequest() *hook.Hook[*RecordViewEvent]
|
|
|
|
// OnRecordBeforeCreateRequest hook is triggered before each API Record
|
|
// create request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnRecordBeforeCreateRequest() *hook.Hook[*RecordCreateEvent]
|
|
|
|
// OnRecordAfterCreateRequest hook is triggered after each
|
|
// successful API Record create request.
|
|
OnRecordAfterCreateRequest() *hook.Hook[*RecordCreateEvent]
|
|
|
|
// OnRecordBeforeUpdateRequest hook is triggered before each API Record
|
|
// update request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnRecordBeforeUpdateRequest() *hook.Hook[*RecordUpdateEvent]
|
|
|
|
// OnRecordAfterUpdateRequest hook is triggered after each
|
|
// successful API Record update request.
|
|
OnRecordAfterUpdateRequest() *hook.Hook[*RecordUpdateEvent]
|
|
|
|
// OnRecordBeforeDeleteRequest hook is triggered before each API Record
|
|
// delete request (after model load and before actual deletion).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different delete behavior (returning [hook.StopPropagation]).
|
|
OnRecordBeforeDeleteRequest() *hook.Hook[*RecordDeleteEvent]
|
|
|
|
// OnRecordAfterDeleteRequest hook is triggered after each
|
|
// successful API Record delete request.
|
|
OnRecordAfterDeleteRequest() *hook.Hook[*RecordDeleteEvent]
|
|
|
|
// ---------------------------------------------------------------
|
|
// Collection API event hooks
|
|
// ---------------------------------------------------------------
|
|
|
|
// OnCollectionsListRequest hook is triggered on each API Collections list request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnCollectionsListRequest() *hook.Hook[*CollectionsListEvent]
|
|
|
|
// OnCollectionViewRequest hook is triggered on each API Collection view request.
|
|
//
|
|
// Could be used to validate or modify the response before returning it to the client.
|
|
OnCollectionViewRequest() *hook.Hook[*CollectionViewEvent]
|
|
|
|
// OnCollectionBeforeCreateRequest hook is triggered before each API Collection
|
|
// create request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnCollectionBeforeCreateRequest() *hook.Hook[*CollectionCreateEvent]
|
|
|
|
// OnCollectionAfterCreateRequest hook is triggered after each
|
|
// successful API Collection create request.
|
|
OnCollectionAfterCreateRequest() *hook.Hook[*CollectionCreateEvent]
|
|
|
|
// OnCollectionBeforeUpdateRequest hook is triggered before each API Collection
|
|
// update request (after request data load and before model persistence).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different persistence behavior (returning [hook.StopPropagation]).
|
|
OnCollectionBeforeUpdateRequest() *hook.Hook[*CollectionUpdateEvent]
|
|
|
|
// OnCollectionAfterUpdateRequest hook is triggered after each
|
|
// successful API Collection update request.
|
|
OnCollectionAfterUpdateRequest() *hook.Hook[*CollectionUpdateEvent]
|
|
|
|
// OnCollectionBeforeDeleteRequest hook is triggered before each API
|
|
// Collection delete request (after model load and before actual deletion).
|
|
//
|
|
// Could be used to additionally validate the request data or implement
|
|
// completely different delete behavior (returning [hook.StopPropagation]).
|
|
OnCollectionBeforeDeleteRequest() *hook.Hook[*CollectionDeleteEvent]
|
|
|
|
// OnCollectionAfterDeleteRequest hook is triggered after each
|
|
// successful API Collection delete request.
|
|
OnCollectionAfterDeleteRequest() *hook.Hook[*CollectionDeleteEvent]
|
|
|
|
// OnCollectionsBeforeImportRequest hook is triggered before each API
|
|
// collections import request (after request data load and before the actual import).
|
|
//
|
|
// Could be used to additionally validate the imported collections or
|
|
// to implement completely different import behavior (returning [hook.StopPropagation]).
|
|
OnCollectionsBeforeImportRequest() *hook.Hook[*CollectionsImportEvent]
|
|
|
|
// OnCollectionsAfterImportRequest hook is triggered after each
|
|
// successful API collections import request.
|
|
OnCollectionsAfterImportRequest() *hook.Hook[*CollectionsImportEvent]
|
|
}
|