Documentation
¶
Index ¶
Constants ¶
const ( // ModerncDepsCheckHookId is the id of the hook that performs the modernc.org/* deps checks. // It could be used for removing/unbinding the hook if you don't want the checks. ModerncDepsCheckHookId = "baseModerncDepsCheck" )
Variables ¶
var Version = "(untracked)"
Version of Base
Functions ¶
This section is empty.
Types ¶
type Base ¶
type Base struct { core.App // RootCmd is the main console command RootCmd *cobra.Command // contains filtered or unexported fields }
Base defines a Base app launcher.
It implements core.App via embedding and all of the app interface methods could be accessed directly through the instance (eg. Base.DataDir()).
func New ¶
func New() *Base
New creates a new Base instance with the default configuration. Use NewWithConfig if you want to provide a custom configuration.
Note that the application will not be initialized/bootstrapped yet, aka. DB connections, migrations, app settings, etc. will not be accessible. Everything will be initialized when Base.Start is executed. If you want to initialize the application before calling Base.Start, then you'll have to manually call [Base.Bootstrap].
func NewWithConfig ¶
NewWithConfig creates a new Base instance with the provided config.
Note that the application will not be initialized/bootstrapped yet, aka. DB connections, migrations, app settings, etc. will not be accessible. Everything will be initialized when Base.Start is executed. If you want to initialize the application before calling Base.Start, then you'll have to manually call [Base.Bootstrap].
type Config ¶
type Config struct { // hide the default console server info on app startup HideStartBanner bool // optional default values for the console flags DefaultDev bool DefaultDataDir string // if not set, it will fallback to "./hz_data" DefaultEncryptionEnv string DefaultQueryTimeout time.Duration // default to core.DefaultQueryTimeout (in seconds) // optional DB configurations DataMaxOpenConns int // default to core.DefaultDataMaxOpenConns DataMaxIdleConns int // default to core.DefaultDataMaxIdleConns AuxMaxOpenConns int // default to core.DefaultAuxMaxOpenConns AuxMaxIdleConns int // default to core.DefaultAuxMaxIdleConns DBConnect core.DBConnectFunc // default to core.dbConnect }
Config is the Base initialization config struct.
Directories
¶
Path | Synopsis |
---|---|
Package core is the backbone of Base.
|
Package core is the backbone of Base. |
validators
Package validators implements some common custom Base validators.
|
Package validators implements some common custom Base validators. |
examples
|
|
Package mails implements various helper methods for sending common emails like forgotten password, verification, etc.
|
Package mails implements various helper methods for sending common emails like forgotten password, verification, etc. |
plugins
|
|
ghupdate
Package ghupdate implements a new command to selfupdate the current Base executable with the latest GitHub release.
|
Package ghupdate implements a new command to selfupdate the current Base executable with the latest GitHub release. |
jsvm
Package jsvm implements pluggable utilities for binding a JS goja runtime to the Base instance (loading migrations, attaching to app hooks, etc.).
|
Package jsvm implements pluggable utilities for binding a JS goja runtime to the Base instance (loading migrations, attaching to app hooks, etc.). |
migratecmd
Package migratecmd adds a new "migrate" command support to a Base instance.
|
Package migratecmd adds a new "migrate" command support to a Base instance. |
Package tests provides common helpers and mocks used in Base application tests.
|
Package tests provides common helpers and mocks used in Base application tests. |
tools
|
|
cron
Package cron implements a crontab-like service to execute and schedule repeative tasks/jobs.
|
Package cron implements a crontab-like service to execute and schedule repeative tasks/jobs. |
template
Package template is a thin wrapper around the standard html/template and text/template packages that implements a convenient registry to load and cache templates on the fly concurrently.
|
Package template is a thin wrapper around the standard html/template and text/template packages that implements a convenient registry to load and cache templates on the fly concurrently. |
tokenizer
Package tokenizer implements a rudimentary tokens parser of buffered io.Reader while respecting quotes and parenthesis boundaries.
|
Package tokenizer implements a rudimentary tokens parser of buffered io.Reader while respecting quotes and parenthesis boundaries. |
types
Package types implements some commonly used db serializable types like datetime, json, etc.
|
Package types implements some commonly used db serializable types like datetime, json, etc. |
Package ui handles the Base Superuser frontend embedding.
|
Package ui handles the Base Superuser frontend embedding. |