Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type EMailMessage ¶
type EMailMessage struct { Subject string `json:"subject,omitempty"` Text string `json:"text,omitempty"` To []string `json:"to,omitempty"` }
EMailMessage holds data required to send emails
type Feed ¶
type Feed struct { // a string composed by concatenating the UID, a "|" and a flavour ID string `json:"id" firestore:"-"` // A higher sequence number means that it came later SequenceNumber int `json:"sequenceNumber" firestore:"sequenceNumber"` // user identifier - who does this feed belong to? // this is also the unique identifier for a feed UID string `json:"uid" firestore:"uid"` // whether this is a consumer or pro feed Flavour feedlib.Flavour `json:"flavour" firestore:"flavour"` // what are the global actions available to this user? Actions []feedlib.Action `json:"actions" firestore:"actions"` // what does this user's feed contain? Items []feedlib.Item `json:"items" firestore:"items"` // what prompts or nudges should this user see? Nudges []feedlib.Nudge `json:"nudges" firestore:"nudges"` // indicates whether the user is Anonymous or not IsAnonymous *bool `json:"isAnonymous" firestore:"isAnonymous"` }
Feed manages and serializes the nudges, actions and feed items that a specific user should see.
A feed is stored and serialized on a per-user basis. If a feed item is sent to a group of users, it should be "expanded" before the user's feed gets stored.
func (Feed) IsEntity ¶
func (fe Feed) IsEntity()
IsEntity marks a feed as an Apollo federation GraphQL entity
func (*Feed) ValidateAndMarshal ¶
ValidateAndMarshal validates against the JSON schema then marshals to JSON
func (*Feed) ValidateAndUnmarshal ¶
ValidateAndUnmarshal checks that the input data is valid as per the relevant JSON schema and unmarshals it if it is
type GhostCMSAuthor ¶
type GhostCMSAuthor struct { ID string `json:"id"` Name string `json:"name"` Slug string `json:"slug"` ProfileImage string `json:"profile_image"` Website string `json:"website"` Location string `json:"location"` Facebook string `json:"facebook"` Twitter string `json:"twitter"` URL string `json:"url"` }
GhostCMSAuthor is used to serialize authors of Ghost CMS posts
type GhostCMSPost ¶
type GhostCMSPost struct { ID string `json:"id"` UUID string `json:"uuid"` Slug string `json:"slug"` Title string `json:"title"` HTML string `json:"html"` Excerpt string `json:"excerpt"` URL string `json:"url"` FeatureImage string `json:"feature_image"` Featured bool `json:"featured"` Visibility string `json:"visibility"` ReadingTime int `json:"reading_time"` CreatedAt time.Time `json:"created_at"` UpdatedAt time.Time `json:"updated_at"` PublishedAt time.Time `json:"published_at"` CommentID string `json:"comment_id"` Tags []GhostCMSTag `json:"tags"` Authors []GhostCMSAuthor `json:"authors"` PrimaryAuthor GhostCMSAuthor `json:"primary_author"` PrimaryTag GhostCMSTag `json:"primary_tag"` }
GhostCMSPost is the body of the post sourced from Ghost CMS
func (GhostCMSPost) IsEntity ¶
func (g GhostCMSPost) IsEntity()
IsEntity marks a Ghost CMS post as an entity
type GhostCMSServerResponse ¶
type GhostCMSServerResponse struct {
Posts []*GhostCMSPost `json:"posts"`
}
GhostCMSServerResponse assembles the posts fetched from a Ghost server, for serialization
type GhostCMSTag ¶
type GhostCMSTag struct { ID string `json:"id"` Name string `json:"name"` Slug string `json:"slug"` Description *string `json:"description"` Visibility string `json:"visibility"` URL string `json:"url"` }
GhostCMSTag represents the structure of a Ghost CMS tag
func (GhostCMSTag) IsEntity ¶
func (g GhostCMSTag) IsEntity()
IsEntity marks a Ghost CMS tag as an entity
type SurveyFeedback ¶ added in v0.0.38
type SurveyFeedback struct { Question string `json:"question" firestore:"question"` Answer string `json:"answer" firestore:"answer"` }
SurveyFeedback describes the set of feedback response from the user the question and the answer
type SurveyFeedbackInput ¶ added in v0.0.38
type SurveyFeedbackInput struct { Question string `json:"question" firestore:"question"` Answer string `json:"answer" firestore:"answer"` }
SurveyFeedbackInput refers to the Question and Answer Input
type SurveyFeedbackResponse ¶ added in v0.0.38
type SurveyFeedbackResponse struct { Feedback []SurveyFeedback `json:"feedback" firestore:"feedback"` ExtraFeedback string `json:"extraFeedback" firestore:"extraFeedback"` Timestamp time.Time `json:"timestamp,omitempty" firestore:"timestamp,omitempty"` }
SurveyFeedbackResponse shows the response that will be saved to firestore
type SurveyInput ¶ added in v0.0.38
type SurveyInput struct { Feedback []*SurveyFeedbackInput `json:"feedback"` ExtraFeedback string `json:"extraFeedback" firestore:"extraFeedback"` }
SurveyInput refers to the whole response collected from the survey: the set of questions and their answers, and any extraFeedback from the user