mirror of
https://github.com/XTLS/Xray-core.git
synced 2025-01-25 19:14:12 +00:00
496b2c02c5
* Fix Dial function crash instance when there is no instance context in the ctx * check ctx to fix. (#841) * Feat: core.ToContext(ctx, v) for ctx initialization (#852) * remove exported API: toContext * Remove unnecessary API * rework document for API * fix: make sure the ctx is propagated to connections by detached connection Co-authored-by: Shelikhoo <xiaokangwang@outlook.com> Co-authored-by: rurirei <72071920+rurirei@users.noreply.github.com>
53 lines
1.5 KiB
Go
53 lines
1.5 KiB
Go
package core
|
|
|
|
import (
|
|
"context"
|
|
)
|
|
|
|
// XrayKey is the key type of Instance in Context, exported for test.
|
|
type XrayKey int
|
|
|
|
const xrayKey XrayKey = 1
|
|
|
|
// FromContext returns an Instance from the given context, or nil if the context doesn't contain one.
|
|
func FromContext(ctx context.Context) *Instance {
|
|
if s, ok := ctx.Value(xrayKey).(*Instance); ok {
|
|
return s
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// MustFromContext returns an Instance from the given context, or panics if not present.
|
|
func MustFromContext(ctx context.Context) *Instance {
|
|
x := FromContext(ctx)
|
|
if x == nil {
|
|
panic("X is not in context.")
|
|
}
|
|
return x
|
|
}
|
|
|
|
/* toContext returns ctx from the given context, or creates an Instance if the context doesn't find that.
|
|
|
|
It is unsupported to use this function to create a context that is suitable to invoke Xray's internal component
|
|
in third party code, you shouldn't use //go:linkname to alias of this function into your own package and
|
|
use this function in your third party code.
|
|
|
|
For third party code, usage enabled by creating a context to interact with Xray's internal component is unsupported,
|
|
and may break at any time.
|
|
|
|
*/
|
|
func toContext(ctx context.Context, v *Instance) context.Context {
|
|
if FromContext(ctx) != v {
|
|
ctx = context.WithValue(ctx, xrayKey, v)
|
|
}
|
|
return ctx
|
|
}
|
|
|
|
/*ToBackgroundDetachedContext create a detached context from another context
|
|
Internal API
|
|
*/
|
|
func ToBackgroundDetachedContext(ctx context.Context) context.Context {
|
|
instance := MustFromContext(ctx)
|
|
return toContext(context.Background(), instance)
|
|
}
|