Documentation ¶
Index ¶
- Constants
- Variables
- func Chk(err error)
- func Filter[T any](collection []T, fn func(T) bool) []T
- func FilterMap[T any, R any](collection []T, fn func(T) (R, bool)) []R
- func FlatMap[T any, R any](collection []T, fn func(T) []R) []R
- func HmacSha256(s string, key string) string
- func HttpGet(getUrl string, credential ...string) ([]byte, error)
- func HttpGet2(getUrl string, contentType string, opt *HttpOpt) ([]byte, error)
- func HttpPost(postUrl string, q url.Values, credential ...string) ([]byte, error)
- func HttpPost2(postUrl string, contentType string, body io.Reader, opt *HttpOpt) ([]byte, error)
- func IsPemExpire(b []byte) (bool, error)
- func Map[T any, R any](collection []T, fn func(T) R) []R
- func Max(n ...int) int
- func Md5(b []byte) []byte
- func Md5Str(salt string) func(string) string
- func Min(n ...int) int
- func MultiDeleteFromMap[K comparable, V any](m map[K]V, ks ...K)
- func OrderBy[T any, R constraints.Ordered](l []T, fn func(T) R) []T
- func OrderByDescending[T any, R constraints.Ordered](l []T, fn func(T) R) []T
- func ParseAddr(s string) (string, int, error)
- func Reject[T any](collection []T, fn func(T) bool) []T
- func SendMail(user, password, host, to, subject, body, mailtype string) error
- func SetHttpClient(hc *http.Client)
- func Sha1Str(salt string) func(string) string
- func Sha256Str(salt string) func(string) string
- func Shuffle[T any](collection []T) []T
- func SplitIntSlice(src []int, chunkSize int) [][]int
- func SplitStringSlice(src []string, chunkSize int) [][]string
- func SplitStringSliceIntoN(a []string, n int) [][]string
- func Sum[T constraints.Ordered](l []T) T
- func Truncate(s string, maxLen uint) string
- type BasicAuth
- type HttpOpt
- type J
- type MemQueue
- type PerfLog
- type SyncMap
- type SyncMap2
- type Throttle
- type Tick
- type TimerCache
- type TimerCache2
Constants ¶
const ( MAX_HTTP_CLIENT_CONCURRENT = 1000 ContentTypeForm = "application/x-www-form-urlencoded" ContentTypeJson = "application/json; charset=utf-8" )
Variables ¶
var ( // PlainMd5 string md5 function with empty salt PlainMd5 = Md5Str("") // PlainSha1 string sha-1 function with empty salt PlainSha1 = Sha1Str("") )
var (
ErrEmptyHeaderName = errors.New("header name must not be empty")
)
var ErrFull = errors.New("queue is full")
Functions ¶
func HmacSha256 ¶
func IsPemExpire ¶
func MultiDeleteFromMap ¶ added in v1.2.2
func MultiDeleteFromMap[K comparable, V any](m map[K]V, ks ...K)
func OrderBy ¶ added in v1.3.0
func OrderBy[T any, R constraints.Ordered](l []T, fn func(T) R) []T
OrderBy order by fn, return ordered copy of slice
func OrderByDescending ¶ added in v1.3.0
func OrderByDescending[T any, R constraints.Ordered](l []T, fn func(T) R) []T
OrderByDescending order by fn descending, return ordered copy of slice
func SetHttpClient ¶ added in v1.2.7
HTTP Client expose for further customize
func SplitIntSlice ¶ added in v1.2.8
SplitIntSlice split int slice into chunks Deprecated use lo.Chunk instead
func SplitStringSlice ¶ added in v1.2.8
SplitStringSlice split string slice into chunks Deprecated use lo.Chunk instead
func SplitStringSliceIntoN ¶ added in v1.2.8
SplitStringSliceIntoN split a into several parts, no more than n
Types ¶
type MemQueue ¶
type MemQueue chan interface{}
MemQueue memory queue
func NewLeakMemQueue ¶
NewLeakMemQueue create memory queue, auto-leak element concurrently to worker
func (MemQueue) EnqBlocking ¶
func (p MemQueue) EnqBlocking(data interface{})
EnqBlocking enqueue, block if queue is full
type SyncMap2 ¶ added in v1.4.0
type SyncMap2[K comparable, V any] struct { sync.RWMutex // contains filtered or unexported fields }
SyncMap2 generic sync map
type Throttle ¶
type Throttle struct {
// contains filtered or unexported fields
}
Throttle , limit number of concurrent goroutines
func NewThrottle ¶
NewThrottle New Throttle max , max number of this throttle
type Tick ¶
type Tick int64
Tick unix timestamp in millisecond
type TimerCache ¶
type TimerCache struct {
// contains filtered or unexported fields
}
func NewTimerCache ¶
func NewTimerCache(ttl int, expireCb func(key, value interface{})) *TimerCache
NewTimerCache ttl in second expireCb, expire callback Deprecated, use NewTimerCache2 instead
func (*TimerCache) Get ¶
func (p *TimerCache) Get(key interface{}) interface{}
func (*TimerCache) Keys ¶
func (p *TimerCache) Keys() []interface{}
func (*TimerCache) Len ¶
func (p *TimerCache) Len() int
func (*TimerCache) Put ¶
func (p *TimerCache) Put(key, val interface{}) bool
func (*TimerCache) Remove ¶
func (p *TimerCache) Remove(key interface{}) interface{}
func (*TimerCache) TTL ¶ added in v1.2.6
func (p *TimerCache) TTL(key interface{}) int64
TTL Check ttl (in second)
type TimerCache2 ¶ added in v1.4.0
type TimerCache2[K comparable, V any] struct { // contains filtered or unexported fields }
TimerCache2 generic timer cache
func NewTimerCache2 ¶ added in v1.4.0
func NewTimerCache2[K comparable, V any](ttl int, expireCb ...func(key K, value V)) *TimerCache2[K, V]
NewTimerCache2 create new TimerCache2 ttl in second expireCb, expire callback
func (*TimerCache2[K, V]) Get ¶ added in v1.4.0
func (p *TimerCache2[K, V]) Get(key K) (V, bool)
func (*TimerCache2[K, V]) Keys ¶ added in v1.4.0
func (p *TimerCache2[K, V]) Keys() []K
func (*TimerCache2[K, V]) Len ¶ added in v1.4.0
func (p *TimerCache2[K, V]) Len() int
func (*TimerCache2[K, V]) Put ¶ added in v1.4.0
func (p *TimerCache2[K, V]) Put(key K, val V) bool
func (*TimerCache2[K, V]) Remove ¶ added in v1.4.0
func (p *TimerCache2[K, V]) Remove(key K) (V, bool)
func (*TimerCache2[K, V]) TTL ¶ added in v1.4.0
func (p *TimerCache2[K, V]) TTL(key K) (int64, bool)
TTL Check ttl (in second)