Merge pull request #2 from syumai/sockets

Sockets
This commit is contained in:
a 2023-06-26 03:18:48 -05:00 committed by GitHub
commit c8dfc5eedf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 27 additions and 3 deletions

View File

@ -2,6 +2,7 @@ package cfruntimecontext
import (
"context"
"errors"
"syscall/js"
"github.com/syumai/workers/internal/runtimecontext"
@ -13,6 +14,7 @@ import (
* type RuntimeContext {
* env: Env;
* ctx: ExecutionContext;
* ...
* }
* ```
* This type is based on the type definition of ExportedHandlerFetchHandler.
@ -33,3 +35,16 @@ func GetExecutionContext(ctx context.Context) js.Value {
runtimeCtxValue := runtimecontext.MustExtract(ctx)
return runtimeCtxValue.Get("ctx")
}
var ErrValueNotFound = errors.New("execution context value for specified key not found")
// GetRuntimeContextValue gets value for specified key from RuntimeContext.
// - if the value is undefined, return error.
func GetRuntimeContextValue(ctx context.Context, key string) (js.Value, error) {
runtimeCtxValue := runtimecontext.MustExtract(ctx)
v := runtimeCtxValue.Get(key)
if v.IsUndefined() {
return js.Value{}, ErrValueNotFound
}
return v, nil
}

View File

@ -1,5 +1,6 @@
import "./polyfill_performance.js";
import "./wasm_exec.js";
import { connect } from 'cloudflare:sockets';
const go = new Go();
@ -18,19 +19,27 @@ async function run() {
await readyPromise;
}
function createRuntimeContext(env, ctx) {
return {
env,
ctx,
connect,
}
}
export async function fetch(req, env, ctx) {
await run();
return handleRequest(req, { env, ctx });
return handleRequest(req, createRuntimeContext(env, ctx));
}
export async function scheduled(event, env, ctx) {
await run();
return runScheduler(event, { env, ctx });
return runScheduler(event, createRuntimeContext(env, ctx));
}
// onRequest handles request to Cloudflare Pages
export async function onRequest(ctx) {
await run();
const { request, env } = ctx;
return handleRequest(request, { env, ctx });
return handleRequest(request, createRuntimeContext(env, ctx));
}