Documentation ¶
Index ¶
- Constants
- Variables
- func ErrorHandler(c *gin.Context, errWithCode gtserror.WithCode, ...)
- func NegotiateAccept(c *gin.Context, offers ...MIME) (string, error)
- func NegotiateFormat(c *gin.Context, offered ...string) string
- func NotFoundHandler(c *gin.Context, ...)
- func OAuthErrorHandler(c *gin.Context, errWithCode gtserror.WithCode)
- func ParseAPIVersion(value string, availableVersion ...string) (string, gtserror.WithCode)
- func ParseDomainBlockExport(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseDomainBlockImport(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseID(value string) (string, gtserror.WithCode)
- func ParseLimit(value string, defaultValue int, max, min int) (int, gtserror.WithCode)
- func ParseLocal(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseMaxID(value string, defaultValue string) string
- func ParseSearchExcludeUnreviewed(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseSearchFollowing(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseSearchLookup(value string) (string, gtserror.WithCode)
- func ParseSearchOffset(value string, defaultValue int, max, min int) (int, gtserror.WithCode)
- func ParseSearchQuery(value string) (string, gtserror.WithCode)
- func ParseSearchResolve(value string, defaultValue bool) (bool, gtserror.WithCode)
- func ParseTagName(value string) (string, gtserror.WithCode)
- func ParseWebStatusID(value string) (string, gtserror.WithCode)
- func ParseWebUsername(value string) (string, gtserror.WithCode)
- func WebErrorHandler(c *gin.Context, errWithCode gtserror.WithCode, ...)
- type MIME
Constants ¶
const ( APIVersionKey = "api_version" APIv1 = "v1" APIv2 = "v2" IDKey = "id" LimitKey = "limit" LocalKey = "local" MaxIDKey = "max_id" SinceIDKey = "since_id" MinIDKey = "min_id" SearchExcludeUnreviewedKey = "exclude_unreviewed" SearchFollowingKey = "following" SearchLookupKey = "acct" SearchOffsetKey = "offset" SearchQueryKey = "q" SearchResolveKey = "resolve" SearchTypeKey = "type" TagNameKey = "tag_name" WebUsernameKey = "username" WebStatusIDKey = "status" DomainBlockExportKey = "export" DomainBlockImportKey = "import" )
Variables ¶
var ActivityPubHeaders = []MIME{ AppActivityLDJSON, AppActivityJSON, }
ActivityPubHeaders matches only activitypub Accept headers. This is useful for URLs should only serve ActivityPub.
https://www.w3.org/TR/activitypub/#retrieving-objects
var ActivityPubOrHTMLHeaders = []MIME{ AppActivityLDJSON, AppActivityJSON, TextHTML, }
ActivityPubOrHTMLHeaders matches activitypub types first, then text/html. This is useful for URLs that should serve ActivityPub by default, but which a user might also go to in their browser sometimes.
https://www.w3.org/TR/activitypub/#retrieving-objects
var HTMLAcceptHeaders = []MIME{ TextHTML, }
HTMLAcceptHeaders is a slice of offers that just contains text/html types.
var HTMLOrActivityPubHeaders = []MIME{ TextHTML, AppActivityLDJSON, AppActivityJSON, }
HTMLOrActivityPubHeaders matches text/html first, then activitypub types. This is useful for user URLs that a user might go to in their browser, but which should also be able to serve ActivityPub as a fallback.
https://www.w3.org/TR/activitypub/#retrieving-objects
var HostMetaHeaders = []MIME{ AppXMLXRD, AppXML, }
var JSONAcceptHeaders = []MIME{ AppJSON, }
JSONAcceptHeaders is a slice of offers that just contains application/json types.
var JSONOrHTMLAcceptHeaders = []MIME{ AppJSON, TextHTML, }
JSONOrHTMLAcceptHeaders is a slice of offers that prefers AppJSON and will fall back to HTML if necessary. This is useful for error handling, since it can be used to serve a nice HTML page if the caller accepts that, or just JSON if not.
var WebfingerJSONAcceptHeaders = []MIME{ AppJRDJSON, AppJSON, }
WebfingerJSONAcceptHeaders is a slice of offers that prefers the jrd+json content type, but will be chill and fall back to app/json. This is to be used specifically for webfinger responses. See https://www.rfc-editor.org/rfc/rfc7033#section-10.2
Functions ¶
func ErrorHandler ¶
func ErrorHandler(c *gin.Context, errWithCode gtserror.WithCode, instanceGet func(ctx context.Context) (*apimodel.InstanceV1, gtserror.WithCode), offers ...MIME)
ErrorHandler takes the provided gin context and errWithCode and tries to serve a helpful error to the caller.
It will do content negotiation to figure out if the caller prefers to see an html page with the error rendered there. If not, or if something goes wrong during the function, it will recover and just try to serve an appropriate application/json content-type error. To override the default response type, specify `offers`.
If the requester already hung up on the request, ErrorHandler will overwrite the given errWithCode with a 499 error to indicate that the failure wasn't due to something we did, and will avoid trying to write extensive bytes to the caller by just aborting.
See: https://en.wikipedia.org/wiki/List_of_HTTP_status_codes#nginx.
func NegotiateAccept ¶
NegotiateAccept takes the *gin.Context from an incoming request, and a slice of Offers, and performs content negotiation for the given request with the given content-type offers. It will return a string representation of the first suitable content-type, or an error if something goes wrong or a suitable content-type cannot be matched.
For example, if the request in the *gin.Context has Accept headers of value [application/json, text/html], and the provided offers are of value [application/json, application/xml], then the returned string will be 'application/json', which indicates the content-type that should be returned.
If the length of offers is 0, then an error will be returned, so this function should only be called in places where format negotiation is actually needed.
If there are no Accept headers in the request, then the first offer will be returned, under the assumption that it's better to serve *something* than error out completely.
Callers can use the offer slices exported in this package as shortcuts for often-used Accept types.
func NegotiateFormat ¶ added in v0.9.0
This is the exact same thing as gin.Context.NegotiateFormat except it contains tsmethurst's fix to make it work properly with multiple accept headers.
func NotFoundHandler ¶
func NotFoundHandler(c *gin.Context, instanceGet func(ctx context.Context) (*apimodel.InstanceV1, gtserror.WithCode), accept string)
NotFoundHandler serves a 404 html page through the provided gin context, if accept is 'text/html', or just returns a json error if 'accept' is empty or application/json.
When serving html, NotFoundHandler calls the provided InstanceGet function to fetch the apimodel representation of the instance, for serving in the 404 header and footer.
If an error is returned by InstanceGet, the function will panic.
func OAuthErrorHandler ¶
OAuthErrorHandler is a lot like ErrorHandler, but it specifically returns errors that are compatible with https://datatracker.ietf.org/doc/html/rfc6749#section-5.2, but serializing errWithCode.Error() in the 'error' field, and putting any help text from the error in the 'error_description' field. This means you should be careful not to pass any detailed errors (that might contain sensitive information) into the errWithCode.Error() field, since the client will see this. Use your noggin!
func ParseAPIVersion ¶ added in v0.11.0
func ParseDomainBlockExport ¶ added in v0.10.0
func ParseDomainBlockImport ¶ added in v0.10.0
func ParseLimit ¶ added in v0.10.0
func ParseLocal ¶ added in v0.10.0
func ParseMaxID ¶ added in v0.10.0
func ParseSearchExcludeUnreviewed ¶ added in v0.10.0
func ParseSearchFollowing ¶ added in v0.10.0
func ParseSearchLookup ¶ added in v0.10.0
func ParseSearchOffset ¶ added in v0.10.0
func ParseSearchQuery ¶ added in v0.10.0
func ParseSearchResolve ¶ added in v0.10.0
func ParseWebStatusID ¶ added in v0.10.0
func ParseWebUsername ¶ added in v0.10.0
Types ¶
type MIME ¶
type MIME string
MIME represents a mime-type.
const ( AppJSON MIME = `application/json` AppXML MIME = `application/xml` AppXMLXRD MIME = `application/xrd+xml` AppRSSXML MIME = `application/rss+xml` AppActivityJSON MIME = `application/activity+json` AppActivityLDJSON MIME = `application/ld+json; profile="https://www.w3.org/ns/activitystreams"` AppJRDJSON MIME = `application/jrd+json` // https://www.rfc-editor.org/rfc/rfc7033#section-10.2 AppForm MIME = `application/x-www-form-urlencoded` MultipartForm MIME = `multipart/form-data` TextXML MIME = `text/xml` TextHTML MIME = `text/html` TextCSS MIME = `text/css` )