Documentation ¶
Index ¶
- Constants
- Variables
- func ApiKeyFromContext(ctx context.Context) string
- func CreateSlug(title string) string
- func ErrorCode(err error) string
- func ErrorMessage(err error) string
- func NewContextWithApiKey(ctx context.Context, key string) context.Context
- func NewContextWithSiteConfig(ctx context.Context, site *Site) context.Context
- type Config
- type Error
- type ModelSettings
- type OutputSettings
- type Payload
- type Registry
- type RegistryService
- type RegistrySettings
- type SanitizerService
- type Site
- type SiteService
- type StrapiWebhookEvents
Constants ¶
const ( ErrInternal = "internal" ErrInvalid = "invalid" ErrUnaccepted = "unaccepted" ErrRegistry = "registry" ErrSiteConfig = "site config" )
Variables ¶
var ( Commit string Version string RegistryServices map[string]func(site Site) RegistryService Sanitizer SanitizerService )
var ReportError = func(ctx context.Context, err error, args ...interface{}) { log.Printf("error: %+v\n", err) }
ReportError is used to notify external services of error.
Functions ¶
func ApiKeyFromContext ¶
ApiKeyFromContext returns current API key from context.
func CreateSlug ¶
CreateSlug generates an url-safe string from title (or any other string) to be used as post/page slug.
func ErrorCode ¶
ErrorCode unwraps an application error and returns its code. Non-application errors always return ErrInternal.
func ErrorMessage ¶
ErrorMessage unwraps an application error and returns its message. Non-application errors always return "Internal error"
func NewContextWithApiKey ¶
NewContextWithApiKey returns a new context with given API key.
Types ¶
type Error ¶
type Error struct { // Machine-readable error code Code string // Human-readable error message Message string }
Error represents an application-specific error. App errors can be unwrapped to extract out the code & message.
Any non-application errors (such as a disk error) should be reported as en ErrInternal error, so the end-user should only see "internal error". These error details should be logged to the operator of application.
type ModelSettings ¶
type OutputSettings ¶
type Registry ¶
Registry type is used to hold data from registries. It's structure is Id => Filename. So from this JSON:
{ "1": "sample-post.html" }
"1" would be a key and "sample-post.html" would be a value.
type RegistryService ¶
type RegistrySettings ¶
type SanitizerService ¶
type Site ¶
type Site struct { SiteName string `json:"siteName"` RootDir string `json:"rootDir"` OutputSettings OutputSettings `json:"outputSettings"` BuildDrafts bool `json:"buildDrafts"` DraftsUrl string `json:"draftsUrl"` Service string `json:"service"` Registry RegistrySettings `json:"registry"` CollectionTypes map[string]ModelSettings `json:"collectionTypes"` SingleTypes map[string]ModelSettings `json:"singleTypes"` }
func SiteConfigFromContext ¶
SiteConfigFromContext returns current config from context.
type SiteService ¶
type StrapiWebhookEvents ¶
type StrapiWebhookEvents int64
const ( Undefined StrapiWebhookEvents = iota Create Update Delete Publish Unpublish )
func (StrapiWebhookEvents) MarshalJSON ¶
func (event StrapiWebhookEvents) MarshalJSON() ([]byte, error)
func (StrapiWebhookEvents) String ¶
func (event StrapiWebhookEvents) String() string
func (*StrapiWebhookEvents) UnmarshalJSON ¶
func (event *StrapiWebhookEvents) UnmarshalJSON(bytes []byte) error