Documentation ¶
Index ¶
- Variables
- func BasicAuth(user, pass string) string
- func DetectContentType(b []byte, filename string) (mimeType string, ext string)
- func DurationToHuman(d time.Duration) (str string)
- func FileExists(filename string) bool
- func Gzip(next http.Handler) http.Handler
- func InIntList(haystack []int, needle int) bool
- func InStringList(haystack []string, needle string) bool
- func InStringListAll(haystack []string, needles []string) bool
- func LastString(s []string, def string) string
- func MaybeMarshalJSON(v interface{}) string
- func ParseFutureTime(s string, now time.Time) (time.Time, error)
- func ParsePriority(priority string) (int, error)
- func ParseSize(s string) (int64, error)
- func PriorityString(priority int) (string, error)
- func RandomString(length int) string
- func ReadPassword(in io.Reader) ([]byte, error)
- func ShortTopicURL(s string) string
- func SplitKV(s string, sep string) (key string, value string)
- func SplitNoEmpty(s string, sep string) []string
- func ValidRandomString(s string, length int) bool
- type CachingEmbedFS
- type ContentTypeWriter
- type FixedLimiter
- type LimitWriter
- type Limiter
- type PeekedReadCloser
- type RateLimiter
Constants ¶
This section is empty.
Variables ¶
var ErrLimitReached = errors.New("limit reached")
ErrLimitReached is the error returned by the Limiter and LimitWriter when the predefined limit has been reached
Functions ¶
func DetectContentType ¶ added in v1.12.0
DetectContentType probes the byte array b and returns mime type and file extension. The filename is only used to override certain special cases.
func DurationToHuman ¶ added in v1.3.0
DurationToHuman converts a duration to a human-readable format
func FileExists ¶
FileExists checks if a file exists, and returns true if it does
func Gzip ¶ added in v1.17.0
Gzip is a HTTP middleware to transparently compress responses using gzip. Original code from https://gist.github.com/CJEnright/bc2d8b8dc0c1389a9feeddb110f822d7 (MIT)
func InStringList ¶ added in v1.5.2
InStringList returns true if needle is contained in haystack
func InStringListAll ¶ added in v1.8.0
InStringListAll returns true if all needles are contained in haystack
func LastString ¶ added in v1.26.0
LastString returns the last string in a slice, or def if s is empty
func MaybeMarshalJSON ¶ added in v1.25.0
func MaybeMarshalJSON(v interface{}) string
MaybeMarshalJSON returns a JSON string of the given object, or "<cannot serialize>" if serialization failed. This is useful for logging purposes where a failure doesn't matter that much.
func ParseFutureTime ¶ added in v1.6.0
ParseFutureTime parses a date/time string to a time.Time. It supports unix timestamps, durations and natural language dates
func ParsePriority ¶ added in v1.8.0
ParsePriority parses a priority string into its equivalent integer value
func ParseSize ¶ added in v1.12.0
ParseSize parses a size string like 2K or 2M into bytes. If no unit is found, e.g. 123, bytes is assumed.
func PriorityString ¶ added in v1.9.0
PriorityString converts a priority number to a string
func RandomString ¶
RandomString returns a random string with a given length
func ReadPassword ¶ added in v1.14.0
ReadPassword will read a password from STDIN. If the terminal supports it, it will not print the input characters to the screen. If not, it'll just read using normal readline semantics (useful for testing).
func ShortTopicURL ¶ added in v1.9.0
ShortTopicURL shortens the topic URL to be human-friendly, removing the http:// or https://
func SplitKV ¶ added in v1.21.0
SplitKV splits a string into a key/value pair using a separator, and trimming space. If the separator is not found, key is empty.
func SplitNoEmpty ¶ added in v1.8.0
SplitNoEmpty splits a string using strings.Split, but filters out empty strings
func ValidRandomString ¶ added in v1.16.0
ValidRandomString returns true if the given string matches the format created by RandomString
Types ¶
type CachingEmbedFS ¶ added in v1.5.0
CachingEmbedFS is a wrapper around embed.FS that allows setting a ModTime, so that the default static file server can send 304s back. It can be used like this:
var ( //go:embed docs docsStaticFs embed.FS docsStaticCached = &util.CachingEmbedFS{ModTime: time.Now(), FS: docsStaticFs} ) http.FileServer(http.FS(docsStaticCached)).ServeHTTP(w, r)
type ContentTypeWriter ¶ added in v1.12.0
type ContentTypeWriter struct {
// contains filtered or unexported fields
}
ContentTypeWriter is an implementation of http.ResponseWriter that will detect the content type and set the Content-Type and (optionally) Content-Disposition headers accordingly.
It will always set a Content-Type based on http.DetectContentType, but will never send the "text/html" content type.
func NewContentTypeWriter ¶ added in v1.12.0
func NewContentTypeWriter(w http.ResponseWriter, filename string) *ContentTypeWriter
NewContentTypeWriter creates a new ContentTypeWriter
type FixedLimiter ¶ added in v1.12.0
type FixedLimiter struct {
// contains filtered or unexported fields
}
FixedLimiter is a helper that allows adding values up to a well-defined limit. Once the limit is reached ErrLimitReached will be returned. FixedLimiter may be used by multiple goroutines.
func NewFixedLimiter ¶ added in v1.12.0
func NewFixedLimiter(limit int64) *FixedLimiter
NewFixedLimiter creates a new Limiter
func (*FixedLimiter) Allow ¶ added in v1.12.0
func (l *FixedLimiter) Allow(n int64) error
Allow adds n to the limiters internal value, but only if the limit has not been reached. If the limit was exceeded after adding n, ErrLimitReached is returned.
type LimitWriter ¶ added in v1.12.0
type LimitWriter struct {
// contains filtered or unexported fields
}
LimitWriter implements an io.Writer that will pass through all Write calls to the underlying writer w until any of the limiter's limit is reached, at which point a Write will return ErrLimitReached. Each limiter's value is increased with every write.
func NewLimitWriter ¶ added in v1.12.0
func NewLimitWriter(w io.Writer, limiters ...Limiter) *LimitWriter
NewLimitWriter creates a new LimitWriter
type Limiter ¶ added in v1.1.3
type Limiter interface { // Allow adds n to the limiters internal value, or returns ErrLimitReached if the limit has been reached Allow(n int64) error }
Limiter is an interface that implements a rate limiting mechanism, e.g. based on time or a fixed value
type PeekedReadCloser ¶ added in v1.20.0
type PeekedReadCloser struct { PeekedBytes []byte LimitReached bool // contains filtered or unexported fields }
PeekedReadCloser is a ReadCloser that allows peeking into a stream and buffering it in memory. It can be instantiated using the Peek function. After a stream has been peeked, it can still be fully read by reading the PeekedReadCloser. It first drained from the memory buffer, and then from the remaining underlying reader.
func Peek ¶ added in v1.20.0
func Peek(underlying io.ReadCloser, limit int) (*PeekedReadCloser, error)
Peek reads the underlying ReadCloser into memory up until the limit and returns a PeekedReadCloser. It does not return an error if limit is reached. Instead, LimitReached will be set to true.
func (*PeekedReadCloser) Close ¶ added in v1.20.0
func (r *PeekedReadCloser) Close() error
Close closes the underlying stream
type RateLimiter ¶ added in v1.12.0
type RateLimiter struct {
// contains filtered or unexported fields
}
RateLimiter is a Limiter that wraps a rate.Limiter, allowing a floating time-based limit.
func NewBytesLimiter ¶ added in v1.12.0
func NewBytesLimiter(bytes int, interval time.Duration) *RateLimiter
NewBytesLimiter creates a RateLimiter that is meant to be used for a bytes-per-interval limit, e.g. 250 MB per day. And example of the underlying idea can be found here: https://go.dev/play/p/0ljgzIZQ6dJ
func NewRateLimiter ¶ added in v1.12.0
func NewRateLimiter(r rate.Limit, b int) *RateLimiter
NewRateLimiter creates a new RateLimiter
func (*RateLimiter) Allow ¶ added in v1.12.0
func (l *RateLimiter) Allow(n int64) error
Allow adds n to the limiters internal value, but only if the limit has not been reached. If the limit was exceeded after adding n, ErrLimitReached is returned.