mirror of
https://github.com/status-im/status-go.git
synced 2025-01-14 16:56:44 +00:00
61 lines
1.8 KiB
Go
61 lines
1.8 KiB
Go
|
package shhext
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"time"
|
||
|
|
||
|
"github.com/status-im/status-go/db"
|
||
|
)
|
||
|
|
||
|
// ContextKey is a type used for keys in shhext Context.
|
||
|
type ContextKey struct {
|
||
|
Name string
|
||
|
}
|
||
|
|
||
|
// NewContextKey returns new ContextKey instance.
|
||
|
func NewContextKey(name string) ContextKey {
|
||
|
return ContextKey{Name: name}
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
historyDBKey = NewContextKey("history_db")
|
||
|
requestRegistryKey = NewContextKey("request_registry")
|
||
|
timeKey = NewContextKey("time")
|
||
|
)
|
||
|
|
||
|
// NewContextFromService creates new context instance using Service fileds directly and Storage.
|
||
|
func NewContextFromService(ctx context.Context, service *Service, storage db.Storage) Context {
|
||
|
return NewContext(ctx, service.w.GetCurrentTime, service.requestsRegistry, storage)
|
||
|
}
|
||
|
|
||
|
// NewContext creates Context with all required fields.
|
||
|
func NewContext(ctx context.Context, source TimeSource, registry *RequestsRegistry, storage db.Storage) Context {
|
||
|
ctx = context.WithValue(ctx, historyDBKey, db.NewHistoryStore(storage))
|
||
|
ctx = context.WithValue(ctx, timeKey, source)
|
||
|
ctx = context.WithValue(ctx, requestRegistryKey, registry)
|
||
|
return Context{ctx}
|
||
|
}
|
||
|
|
||
|
// TimeSource is a type used for current time.
|
||
|
type TimeSource func() time.Time
|
||
|
|
||
|
// Context provides access to request-scoped values.
|
||
|
type Context struct {
|
||
|
context.Context
|
||
|
}
|
||
|
|
||
|
// HistoryStore returns db.HistoryStore instance associated with this request.
|
||
|
func (c Context) HistoryStore() db.HistoryStore {
|
||
|
return c.Value(historyDBKey).(db.HistoryStore)
|
||
|
}
|
||
|
|
||
|
// Time returns current time using time function associated with this request.
|
||
|
func (c Context) Time() time.Time {
|
||
|
return c.Value(timeKey).(TimeSource)()
|
||
|
}
|
||
|
|
||
|
// RequestRegistry returns RequestRegistry that tracks each request life-span.
|
||
|
func (c Context) RequestRegistry() *RequestsRegistry {
|
||
|
return c.Value(requestRegistryKey).(*RequestsRegistry)
|
||
|
}
|