 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package app handles the routes and views for the Defacto2 website.
Index ¶
- Constants
- Variables
- func Apps(c echo.Context, sl *slog.Logger) error
- func Areacodes(c echo.Context, sl *slog.Logger) error
- func Artifact404(c echo.Context, sl *slog.Logger, id string) error
- func Artifacts(c echo.Context, db *sql.DB, sl *slog.Logger, uri, page string) error
- func Artifacts404(c echo.Context, sl *slog.Logger, uri string) error
- func Artist(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Attribute(write, code, art, music, name string) string
- func BBS(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func BBSAZ(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func BBSYear(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func BadRequestErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func Brief(platform, section any) string
- func BrokenTexts(c echo.Context, sl *slog.Logger) error
- func ByteFile(cnt, bytes any) template.HTML
- func ByteFileS(name string, count, bytes any) template.HTML
- func Categories(c echo.Context, db *sql.DB, sl *slog.Logger, stats bool) error
- func Checksum(c echo.Context, db *sql.DB, sl *slog.Logger, id string) error
- func Coder(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Compression(c echo.Context, sl *slog.Logger) error
- func Configurations(cx echo.Context, db *sql.DB, sl *slog.Logger, conf config.Config) error
- func DatabaseErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func Day(d any) string
- func Deletions(c echo.Context, db *sql.DB, sl *slog.Logger, page string) error
- func Describe(platform, section, year, month any) template.HTML
- func Download(c echo.Context, db *sql.DB, sl *slog.Logger, downl dir.Directory) error
- func DownloadErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func DownloadJsDos(c echo.Context, db *sql.DB, sl *slog.Logger, extra, downl dir.Directory) error
- func EmptyTester(c echo.Context) map[string]any
- func FTP(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func FileMissingErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func Fixes(c echo.Context, sl *slog.Logger) error
- func ForApproval(c echo.Context, db *sql.DB, sl *slog.Logger, page string) error
- func ForbiddenErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func GetDemozoo(c echo.Context, db *sql.DB, demozooID int, defacto2UNID string, ...) error
- func GetDemozooParam(c echo.Context, db *sql.DB, download dir.Directory) error
- func GetPouet(c echo.Context, db *sql.DB, pouetID int, defacto2UNID string, ...) error
- func GlobTo(name string) string
- func GoogleCallback(c echo.Context, sl *slog.Logger, clientID string, maxAge int, ...) error
- func HasSuffix(s, suffix string) bool
- func History(c echo.Context, sl *slog.Logger) error
- func Index(c echo.Context, sl *slog.Logger) error
- func Inline(c echo.Context, db *sql.DB, sl *slog.Logger, downl dir.Directory) error
- func InternalErr(c echo.Context, sl *slog.Logger, uri string, err error) error
- func Interview(c echo.Context, sl *slog.Logger) error
- func LastUpdated(t any) string
- func LinkDownload(id any, securityAlert string) template.HTML
- func LinkHref(id any) (string, error)
- func LinkInterview(href string) template.HTML
- func LinkPage(id, kboard any) template.HTML
- func LinkPreview(id any, name, platform string) template.HTML
- func LinkPreviews(youtube, demozoo, pouet, colors16, github, rels, sites string) []string
- func LinkReleasers(performant, magazine bool, a, b any) template.HTML
- func LinkRelrs(magazine bool, a, b any) template.HTML
- func LinkRels(a, b any) template.HTML
- func LinkRelsPerf(a, b any) template.HTML
- func LinkRemote(href, name string) template.HTML
- func LinkRemoteTip(href, name, tooltip string) template.HTML
- func LinkRunApp(id any) template.HTML
- func LinkScnr(name string) (string, error)
- func LinkScnrs(names string) template.HTML
- func LinkWiki(uri, name string) template.HTML
- func LinkWikiTip(uri, name, tooltip string) template.HTML
- func LogoText(s string) string
- func Magazine(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func MagazineAZ(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Month(m any) string
- func Musician(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func New(c echo.Context, sl *slog.Logger) error
- func Page404(c echo.Context, sl *slog.Logger, uri, page string) error
- func PlatformEdit(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func PlatformTagInfo(c echo.Context) error
- func PostDesc(c echo.Context, db *sql.DB, sl *slog.Logger, input string) error
- func PostFilename(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func PostName(c echo.Context, db *sql.DB, sl *slog.Logger, mode FileSearch) error
- func PouetCache(c echo.Context, data string) error
- func Prefix(s string) string
- func ProdPouet(c echo.Context, id string) error
- func ProdZoo(c echo.Context, id string) error
- func RecordRels(a, b any) string
- func Releaser(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Releaser404(c echo.Context, sl *slog.Logger, invalidID string) error
- func ReleaserAZ(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func ReleaserYear(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Releasers(c echo.Context, db *sql.DB, sl *slog.Logger, uri string, public embed.FS) error
- func RemovePCBoard(b []byte) []byte
- func SafeBBS(a any) template.HTML
- func SafeHTML(s string) template.HTML
- func SafeJS(s string) template.JS
- func Scener(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func Scener404(c echo.Context, sl *slog.Logger, id string) error
- func Sceners(c echo.Context, db *sql.DB, sl *slog.Logger, uri string) error
- func SearchDesc(c echo.Context, sl *slog.Logger) error
- func SearchFile(c echo.Context, sl *slog.Logger) error
- func SearchID(c echo.Context, sl *slog.Logger) error
- func SearchReleaser(c echo.Context, sl *slog.Logger) error
- func SignOut(c echo.Context, sl *slog.Logger) error
- func SignedOut(c echo.Context, sl *slog.Logger) error
- func Signin(c echo.Context, sl *slog.Logger, clientID, nonce string) error
- func StatusErr(c echo.Context, sl *slog.Logger, code int, uri string) error
- func SubTitle(section null.String, title any, large bool) template.HTML
- func TagBrief(tag string) string
- func TagEdit(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func TagInfo(c echo.Context) error
- func TagOption(s, value any) template.HTML
- func TagWithOS(os, tag string) string
- func Terms(c echo.Context, sl *slog.Logger) error
- func Thanks(c echo.Context, sl *slog.Logger) error
- func TheScene(c echo.Context, sl *slog.Logger) error
- func Titles(c echo.Context, sl *slog.Logger) error
- func TrimSiteSuffix(s string) string
- func TrimSpace(a any) string
- func URLEncode(a any) string
- func Unwanted(c echo.Context, db *sql.DB, sl *slog.Logger, page string) error
- func VotePouet(c echo.Context, sl *slog.Logger, id string) error
- func Website(c echo.Context, sl *slog.Logger, open string) error
- func WebsiteIcon(url string) template.HTML
- func Writer(c echo.Context, db *sql.DB, sl *slog.Logger) error
- func YMDEdit(c echo.Context, db *sql.DB) error
- type Accordion
- type Asset
- type Cache
- type Dirs
- type FileSearch
- type Font
- type Fonts
- type Form
- type Group
- type Groups
- type Interviewee
- type Interviews
- type Links
- type Milestone
- type Milestones
- type Page
- type Pagination
- type Paths
- type Picture
- type SRI
- type Site
- type Sites
- type Templ
- func (t *Templ) Elements() *template.FuncMap
- func (t *Templ) FuncClosures(db *sql.DB) *template.FuncMap
- func (t *Templ) FuncMap(db *sql.DB) *template.FuncMap
- func (t *Templ) Funcs() template.FuncMap
- func (t *Templ) Layout(name filename) []string
- func (t *Templ) Pages() *Page
- func (t *Templ) Templates(db *sql.DB) (map[string]*template.Template, error)
 
Constants ¶
const ( // Welcome is the default logo monospace text, // each side contains 20 whitespace characters. // The welcome to defacto2 text is 19 characters long. // The letter O of the word "TO" is the center of the text. Welcome = `: ` + `·· WELCOME TO DEFACTO2 ··` + ` ·` )
Variables ¶
var ( ErrClaims = errors.New("no sub id in the claims playload") ErrCorrupt = errors.New("cache data is invalid or corrupt") ErrMisMatch = errors.New("token mismatch") ErrNegative = errors.New("value cannot be a negative number") ErrSession = errors.New("no sub id in session") ErrStatus = errors.New("the http status code is not valid") ErrTmpl = errors.New("the server could not render the html template for this page") ErrUser = errors.New("unknown user") ErrValue = errors.New("value is empty") )
var Caching = Cache{} //nolint:gochecknoglobals
    Caching are values that are used throughout the app or layouts.
Functions ¶
func Areacodes ¶ added in v1.6.0
Areacodes is the handler for the BBS and telephone area codes page.
func Artifact404 ¶
Artifact404 renders the error page for the artifact links.
func Artifacts ¶
Artifacts is the handler for the list and preview of the files page. The uri is the category or collection of files to display. The page is the page number of the results to display.
func Artifacts404 ¶
Artifacts404 renders the files error page for the Artifacts menu and categories. It provides different error messages to the standard error page.
func Attribute ¶
Attribute returns a formatted string of the roles for the given scener name. For example if the name is "ben", write is "ben" and code is "bianca,ben" then the following would return:
"Writer and programmer attributions"
func BadRequestErr ¶
BadRequestErr is the handler for handling Bad Request Errors, caused by invalid user input or a malformed client requests.
func Brief ¶
Brief returns a human readable brief description of the combined platform and section. For example providing "windows" and "intro" would return:
"a Windows intro"
func BrokenTexts ¶ added in v1.8.0
BrokenTexts is the handler for the Broken texts page.
func ByteFileS ¶
ByteFileS returns a human readable string of the byte count with a named description.
func Categories ¶
Categories is the handler for the artifact categories page.
func Compression ¶ added in v1.8.22
Compression is the handler for information on historic compression tools page.
func Configurations ¶ added in v0.8.0
Configurations is the handler for the Configuration page.
func DatabaseErr ¶
DatabaseErr is the handler for database connection issues. A HTTP 503 Service Unavailable error is returned, to reflect the database connection issue but where the server is still running and usable for the client.
func Describe ¶
Describe returns a human readable description of a release. Based on the platform, section, year and month.
For example providing "windows", "intro", 1990 and 1 would return:
"a Windows intro published in Jan, 1990."
func DownloadErr ¶
DownloadErr is the handler for missing download files and database ID errors.
func DownloadJsDos ¶ added in v0.9.0
DownloadJsDos is the handler for the js-dos emulator to download zip files that are then mounted as a C: hard drive in the emulation. js-dos only supports common zip compression methods, so this func first attempts to offer a re-archived zip file found in the extra directory, and only if that fails does it offer the original download file.
func EmptyTester ¶ added in v0.14.0
EmptyTester is a map of defaults for the app template tests.
func FileMissingErr ¶
FileMissingErr is the handler for missing download files and database ID errors.
func ForApproval ¶
ForApproval is the handler for the list and preview of the files page. The uri is the category or collection of files to display. The page is the page number of the results to display.
func ForbiddenErr ¶
ForbiddenErr is the handler for handling Forbidden Errors, caused by clients requesting pages that they do not have permission to access.
func GetDemozoo ¶ added in v0.10.0
func GetDemozoo(c echo.Context, db *sql.DB, demozooID int, defacto2UNID string, download dir.Directory) error
GetDemozoo fetches the download link from Demozoo and saves it to the download directory. It then runs Update to modify the database record with various metadata from the file and Demozoo record API data.
This function is a wrapper for the remote.DemozooLink.Download method.
func GetDemozooParam ¶ added in v0.10.0
GetDemozooParam fetches the multiple download_links values from the Demozoo production API and attempts to download and save one of the linked files. If multiple links are found, the first link is used as they should all point to the same asset.
Both the Demozoo production ID param and the Defacto2 UUID query param values are required as params to fetch the production data and to save the file to the correct filename.
func GetPouet ¶ added in v0.10.0
func GetPouet(c echo.Context, db *sql.DB, pouetID int, defacto2UNID string, download dir.Directory) error
GetPouet fetches the download link from Pouet and saves it to the download directory. It then runs Update to modify the database record with various metadata from the file and Pouet record API data.
This function is a wrapper for the remote.PouetLink.Download method.
func GoogleCallback ¶
func GoogleCallback(c echo.Context, sl *slog.Logger, clientID string, maxAge int, accounts ...[48]byte) error
GoogleCallback is the handler for the Google OAuth2 callback page to verify the Google ID token.
func InternalErr ¶
InternalErr is the handler for handling Internal Server Errors, caused by programming bugs or crashes. The uri string is the part of the URL that caused the error. The optional error value is logged using the logger. If the echo context is nil then a user hostile, fallback error in raw text is returned.
func LastUpdated ¶
LastUpdated returns a string of the time since the given time t. The time is formatted as "Last updated 1 hour ago". If the time is not valid, an empty string is returned.
func LinkDownload ¶
LinkDownload creates a URL to link to the file download of the record. The id needs to be a valid integer. If the security alert is not empty, then a strike-through warning is returned. For example providing 1 and an empty security alert would return:
<a class="card-link" href="/d/9b1c6">Download</a>
func LinkHref ¶
LinkHref creates a URL path to link to the file page for the record. The id needs to be a valid integer.
func LinkInterview ¶
LinkInterview returns a SVG arrow icon to indicate an interview link hosted on an external website. If the href is not a valid URL then an empty string is returned.
func LinkPage ¶
LinkPage creates a URL anchor element to link to the file page for the record. The id needs to be a valid integer. For example providing 1 would return:
The keyboard shortcut is "kboard" and is used to link to the file page with the keyboard focus. It can be left empty to not include the keyboard shortcut.
func LinkPreview ¶
LinkPreview creates a URL to link to the file record in-tab to use as a preview. The preview link will only show with compatible file types based on the platform and filename extension. The id needs to be a valid integer, the name is the filename and the platform is the platform of the release. Any invalid values will return an empty string.
For example providing 1, "readme.txt" and "text" would return:
  <a class="card-link" href="/v/9b1c6">Preview</a>
But providing 1, "file.zip" and "text" would return an empty string.
func LinkPreviews ¶
LinkPreviews returns a slice of HTML formatted links for the artifact editor.
func LinkReleasers ¶ added in v0.10.0
LinkReleasers returns the groups associated with a release and a link to each group. The performant flag will use the group name instead of the much slower group slug formatter.
func LinkRelsPerf ¶ added in v1.5.13
LinkRelsPerf returns the groups associated with a release and a link to each group. It is a faster version of LinkRels and can be used with the templates that have large lists of group names.
func LinkRemote ¶
LinkRemote returns a HTML link with an embedded SVG icon to an external website. There are no checks for the href or name values other than they are not empty.
func LinkRemoteTip ¶ added in v1.7.0
LinkRemoteTip returns a HTML link with an embedded SVG icon to an external website. If the href or name values are empty then an error message is returned. If the tooltip is empty then LinkRemote is returned.
func LinkRunApp ¶ added in v0.10.0
LinkRunApp creates a URL anchor element to link to the artifact page to launch the js-dos emulator. The id needs to be a valid integer. For example providing 1 would return:
    <a class="card-link" href="/f/9b1c6#runapp">Run app</a>
func LinkScnr ¶
LinkScnr returns a link to the named scener page. If the name is empty then an empty string is returned with no error. An example of providing "some scener" would return:
"/p/some-scener", nil
func LinkScnrs ¶ added in v1.2.0
LinkScnrs returns a list of links to the named scener pages. Multiple names can be provided as a comma separated string. If the name is empty then an empty string is returned with no error.
func LinkWiki ¶
LinkWiki returns a HTML link with an embedded SVG icon to the Defacto2 wiki on GitHub. The uri must be a valid URI path to a wiki page and the name must not be empty.
func LinkWikiTip ¶ added in v1.7.0
LinkWikiTip returns a HTML link with an embedded SVG icon to the Defacto2 wiki on GitHub. The uri must be a valid URI path to a wiki page and the name must not be empty. If the tooltip is empty then LinkWiki is returned.
func LogoText ¶
LogoText returns a string of text padded with spaces to center it in the logo. If the string is empty then the default logo text is returned. The text is converted to uppercase and truncated if it is longer than the limit. An example of providing "abc" would return:
" : ·· ABC ·· ·"
func MagazineAZ ¶
MagazineAZ is the handler for the Magazine page ordered chronologically.
func Month ¶
Month returns a short string of the month. If the month number is not a valid then an empty string is returned. For example providing 1 would return:
"Jan"
func Page404 ¶
Page404 renders the files page error page for the Artifacts menu and categories. It provides different error messages to the standard error page.
func PlatformEdit ¶
PlatformEdit handles the post submission for the Platform selection field.
func PlatformTagInfo ¶
func PlatformTagInfo(c echo.Context) error
PlatformTagInfo handles the POST submission for the platform and tag info.
func PostFilename ¶
PostFilename is the handler for the Search for filenames form post page.
func PouetCache ¶
PouetCache parses the cached data for the Pouet production votes. If the cache is valid it is returned as JSON response. If the cache is invalid or corrupt an error will be returned and a API request should be made to Pouet.
func RecordRels ¶
RecordRels returns the groups associated with a release and joins them using a plus sign. For example providing "Group 1" and "Group 2" would return:
"Group 1 + Group 2"
func Releaser404 ¶
Releaser404 renders the files error page for the Groups menu and invalid releasers.
func ReleaserAZ ¶
ReleaserAZ is the handler for the releaser page ordered alphabetically.
func ReleaserYear ¶
ReleaserYear is the handler for the releaser page ordered by year of the first release.
func RemovePCBoard ¶ added in v1.6.3
RemovePCBoard removes any PCBoard sequences from the byte slice.
func SafeBBS ¶ added in v1.6.3
SafeBBS returns a string as a template.HTML type to prevent HTML escaping in the template, but also removes any PCBoard sequences from the string.
If any value is not a valid string then an empty string is returned.
func SafeHTML ¶
SafeHTML returns a string as a template.HTML type to prevent HTML escaping in the template.
func SafeJS ¶
SafeJS returns a string as a template.JS type to prevent JavaScript escaping in the template.
func SearchDesc ¶
SearchDesc is the handler for the Search for file descriptions page.
func SearchFile ¶
SearchFile is the handler for the Search for files page.
func SearchReleaser ¶
SearchReleaser is the handler for the Releaser Search page.
func StatusErr ¶
StatusErr is the handler for the HTTP status pages such as the 404 - not found. If the logger is nil then the error page is returned but no error is logged. If the echo context is nil then a user hostile, fallback error in raw text is returned.
func SubTitle ¶
SubTitle returns a secondary element with the record title. If the section is "magazine" and the title is a number then it is prefixed with "Issue". For example providing "magazine" and 1 would return:
`<h3 class="card-subtitle mb-2 text-body-secondary fs-6">Issue 1</h3>`
Otherwise providing "text" and "Some Cool Stuff" would return:
`<h3 class="card-subtitle mb-2 text-body-secondary fs-6">Some Cool Stuff</h3>`
func TagBrief ¶
TagBrief returns a small summary of the tag. For example providing "interview" would return:
"Conversations with the personalities of The Scene"
func TagInfo ¶
func TagInfo(c echo.Context) error
TagInfo handles the POST submission for the platform and tag info.
func TagOption ¶
TagOption returns a HTML option tag with a "selected" attribute if the s matches the value. For example providing "interview" and "interview" would return:
`<option value="interview" selected>`
func TagWithOS ¶
TagWithOS returns a small summary of the tag with the operating system. If either the os or tags are unknown then a message is returned. For example providing "dos" and "magazine" would return:
"a Dos magazine"
func TrimSiteSuffix ¶
TrimSiteSuffix returns a string with the last 4 characters removed if they are " FTP" or " BBS". For example providing "My super FTP" would return:
"My super"
func TrimSpace ¶
TrimSpace returns a string with all leading and trailing whitespace removed. If the value is a null.String then the value is checked for validity.
func URLEncode ¶ added in v0.10.0
URLEncode returns a URL encoded string from the given string. This can be used to pass filenames as URL parameters.
func Website ¶
Website is the handler for the websites page. Open is the ID of the accordion section to open.
func WebsiteIcon ¶
WebsiteIcon returns a Bootstrap icon name for the given website url. For example if the url contains "archive.org" then the Bootstrap icon "bank2" svg icon is returned.
Types ¶
type Accordion ¶
type Accordion = []struct {
	Name  string // Name of the category.
	Title string // Title tab for the category.
	ID    string // ID of the category.
	Sites Sites  // Sites are the websites shown in the category.
	Open  bool   // Whether the category is displayed or closed.
}
    Accordion is a collection of websites grouped by a category.
type Asset ¶
type Asset int
Asset is a relative path to a public facing CSS, JS or WASM file.
const ( Bootstrap5 Asset = iota // Bootstrap is the path to the minified Bootstrap 5.3 CSS file. Bootstrap5JS // BootstrapJS is the path to the minified Bootstrap 5.3 JS file. BootstrapIcons // BootstrapIcons is the path to the custom Bootstrap Icons SVG sprites file. DosboxJS // DosboxJS is the js-dos v6 default variant compiled with emscripten. DosboxWasm // DosboxWasm is the js-dos v6 WASM binary file. EditArtifact // EditArtifact is the path to the minified Artifact Editor JS file. EditAssets // EditAssets is the path to the minified Editor assets JS file. EditForApproval // EditForApproval is the path to the minified Editor for-approval JS file. Htmx // Htmx is the path to the minified htmx AJAX JS file. HtmxRespTargets // Htmx is the path to the minified response targets extension file. Jsdos6JS // Jsdos6JS is the path to the minified js-dos v6 JS file. Layout // Layout is the path to the minified layout CSS file. LayoutJS // LayoutJS is the path to the minified layout JS file. Pouet // Pouet is the path to the minified Pouet JS file. Readme // Readme is the path to the minified Readme JS file. Uploader // Uploader is the path to the minified Uploader JS file. )
type Cache ¶
type Cache struct {
	RecordCount int // The total number of file records in the database.
}
    Cache contains database values that are used throughout the app or layouts, but do not change frequently enough to warrant a database query on every page load.
type Dirs ¶
type Dirs struct {
	Download  dir.Directory // path to the artifact download directory
	Preview   dir.Directory // path to the preview and screenshot directory
	Thumbnail dir.Directory // path to the file thumbnail directory
	Extra     dir.Directory // path to the extra files directory
	URI       string        // the URI of the file record
}
    Dirs contains the directories used by the artifact pages.
type FileSearch ¶
type FileSearch int
FileSearch is the type of search to perform.
const ( Filenames FileSearch = iota // Filenames is the search for filenames. Descriptions // Descriptions is the search for file descriptions and titles. )
type Font ¶
type Font int
Font is a relative path to a public facing font file.
const ( VGA8 Font = iota // VGA8 is the path to the IBM VGA 8px font file. VGA8Woff // VGA8Woff is the path to the IBM VGA 8px legacy WOFF format font file. VGA8TT // VGA8TT is the path to the IBM VGA 8px legacy TrueType format font file. A1200 // A1200 is the path to the Topaz Plus font file. A1200Woff // A1200Woff is the path to the Topaz Plus legacy WOFF format font file. A1200TT // A1200TT is the path to the Topaz Plus legacy TrueType format font file. CascadiaMono // CascadiaMono is the path to the Cascadia Mono font file. CascadiaMonoWoff // CascadiaMonoWoff is the path to the Cascadia Mono WOFF format font file. CascadiaMonoTT // CascadiaMonoTT is the path to the Cascadia Mono TrueType format font file. )
type Fonts ¶
Fonts are a map of the public facing font files.
type Form ¶
type Form struct {
	Target   string `query:"target"`   // Target is the name of the file to extract from the zip archive.
	Value    string `query:"value"`    // Value of the form input field to change.
	Platform string `query:"platform"` // Platform of the release.
	Tag      string `query:"tag"`      // Tag of the release.
	ID       int    `query:"id"`       // ID is the auto incrementing database id of the record.
	Year     int16  `query:"year"`     // Year of the release.
	Month    int16  `query:"month"`    // Month of the release.
	Day      int16  `query:"day"`      // Day of the release.
	Online   bool   `query:"online"`   // Online is the record online and public toggle.
	Readme   bool   `query:"readme"`   // Readme hides the readme text file from the artifact page.
}
    Form is the form data for the editor.
type Group ¶
type Group struct {
	Name       string     // Name is the name of the group.
	Link       string     // Link is a local URL to the group.
	Interviews Interviews // Interviews is a list of interviews with members of the group.
}
    Group is a collection of interviews with members of a group.
type Groups ¶
type Groups []Group
Groups is a collection of group interviews.
func Interviewees ¶
func Interviewees() Groups
Interviewees returns a list of interviewees and their interviews. These are categorized by the group they were in at the time of the interview.
type Interviewee ¶
type Interviewee struct {
	Scener  string // Scener is the name of the person interviewed.
	Content string // Content is a short description of the interview.
	Link    string // Link is the URL to the interview.
	Year    int    // Year is the year the interview was conducted.
	Month   int    // Month is the month the interview was conducted.
}
    Interviewee is a person who was interviewed with a link to the interview.
type Links ¶
type Links []struct {
	LinkTitle string // LinkTitle is the title of the Link.
	SubTitle  string // SublTitle is the title of the Link in a smaller font and in brackets.
	Link      string // Link is the URL to an article about the milestone or the product.
	Forward   string // Forward is an optional name of a group that is prefixed before the link to indicate a merger.
}
    Links is a collection of Links.
type Milestone ¶
type Milestone struct {
	Picture   Picture // Picture is an image or screenshot for a milestone.
	Prefix    string  // Prefix replacement for the month, such as 'Early', 'Mid' or 'Late'.
	Title     string  // Title of the milestone should be the accomplishment.
	Lead      string  // Lead paragraph, is optional and should usually be the product.
	Content   string  // Content is the main body of the milestone and can be HTML.
	Link      string  // Link is the URL to an article about the milestone or the product.
	LinkTitle string  // LinkTitle is the title of the Link.
	List      Links   // Links is a collection of links that are displayed as a HTML list.
	Year      int     // Year of the milestone.
	Month     int     // Month of the milestone.
	Day       int     // Day of the milestone.
	Highlight bool    // Highlight is a flag to outline the milestone.
}
    Milestone is an accomplishment for a year and optional month.
type Pagination ¶
type Pagination struct {
	BaseURL   string // BaseURL is the base URL for the pagination links.
	CurrPage  int    // CurrPage is the current page number.
	SumPages  int    // SumPages is the total number of pages.
	PrevPage  int    // PrevPage is the previous page number.
	NextPage  int    // NextPage is the next page number.
	TwoBelow  int    // TwoBelow is the page number two below the current page.
	TwoAfter  int    // TwoAfter is the page number two after the current page.
	RangeStep int    // RangeStep is the number of pages to skip in the pagination range.
}
    type Paths ¶
Paths are a map of the public facing CSS, JS and WASM files.
type Picture ¶
type Picture struct {
	Title       string // Title of the picture.
	Alt         string // Alt is the alternative text for the picture.
	Attribution string // attribution is the name of the author of the picture.
	License     string // License is the license of the picture.
	LicenseLink string // LicenseLink is the URL to the license of the picture.
	Webp        string // Webp is the filename of the WebP screenshot.
	Png         string // Png is the filename of the PNG screenshot.
	Jpg         string // Jpg is the filename of the JPG photo.
	Avif        string // Avif is the filename of the AVIF photo.
	Webm        string // Webm is the filename of the WebM multimedia container, such as a video.
}
    Picture is an image or screenshot for a milestone.
type SRI ¶
type SRI struct {
	Bootstrap5      string // Bootstrap CSS verification hash.
	Bootstrap5JS    string // Bootstrap JS verification hash.
	BootstrapIcons  string // Bootstrap Icons SVG verification hash.
	EditArtifact    string // Artifact Editor JS verification hash.
	EditAssets      string // Editor Assets JS verification hash.
	EditForApproval string // Editor For Approval JS verification hash.
	Jsdos6JS        string // js-dos v6 verification hash.
	DosboxJS        string // DOSBox Emscripten verification hash.
	Layout          string // Layout CSS verification hash.
	LayoutJS        string // Layout JS verification hash.
	Pouet           string // Pouet JS verification hash.
	Readme          string // Readme JS verification hash.
	Uploader        string // Uploader JS verification hash.
	Htmx            string // htmx JS verification hash.
	HtmxRespTargets string // htmx response targets extension JS verification hash.
}
    SRI are the Sub-Resource Integrity hashes for the layout.
type Site ¶
type Site struct {
	Title string // Title of the website.
	URL   string // URL of the website, including the HTTP or HTTPS protocol.
	Info  string // A short description of the website.
}
    Site is a website.
type Templ ¶
type Templ struct {
	Public      embed.FS      // Public facing files.
	View        embed.FS      // Views are Go templates.
	Subresource SRI           // SRI are the Subresource Integrity hashes for the layout.
	Version     string        // Version is the current version of the app.
	Brand       []byte        // Brand contains to the Defacto2 ASCII logo.
	Environment config.Config // Environment configurations from the host system environment.
	RecordCount int           // RecordCount is the total number of records in the database.
}
    Templ is the configuration and status of the web application templates.
func (*Templ) Elements ¶ added in v0.10.0
Elements returns a map of functions that return HTML elements.
func (*Templ) FuncClosures ¶ added in v0.10.0
FuncClosures returns a map of closures that return converted type or modified strings.
func (*Templ) Funcs ¶ added in v0.10.0
Funcs are a collection of mapped functions that can be used in a template.
The "fmtURI" function is not performant for large lists, instead use "fmtRangeURI" in TemplateStrings().
       Source Files
      ¶
      Source Files
      ¶
    
  
       Directories
      ¶
      Directories
      ¶
    
    | Path | Synopsis | 
|---|---|
| internal
       | |
| 
          
            filerecord
            
            
          
           Package filerecord provides functions for the file model which is an artifact record. | Package filerecord provides functions for the file model which is an artifact record. | 
| 
          
            fileslice
            
            
          
           Package fileslice provides functions that return model FileSlices, which are multiple artifact records. | Package fileslice provides functions that return model FileSlices, which are multiple artifact records. | 
| 
          
            simple
            
            
          
           Package simple provides functions for handling string or integer input data. | Package simple provides functions for handling string or integer input data. | 
| Package remote provides the remote download and update of artifact data from third-party sources such as API's. | Package remote provides the remote download and update of artifact data from third-party sources such as API's. |