summaryrefslogtreecommitdiffhomepage
path: root/app/packages/function/src/api.ts
diff options
context:
space:
mode:
authorFrank <[email protected]>2025-05-23 16:34:02 -0400
committerDax Raad <[email protected]>2025-05-26 12:40:17 -0400
commit7623b33f31939912c148623190cba1186dad4fd3 (patch)
treef804658006691cd881211de999400bc73140bc12 /app/packages/function/src/api.ts
parent9b331a917edc567cd1d4b75df7deff31a54836aa (diff)
downloadopencode-7623b33f31939912c148623190cba1186dad4fd3.tar.gz
opencode-7623b33f31939912c148623190cba1186dad4fd3.zip
Share: sync
Diffstat (limited to 'app/packages/function/src/api.ts')
-rw-r--r--app/packages/function/src/api.ts15
1 files changed, 9 insertions, 6 deletions
diff --git a/app/packages/function/src/api.ts b/app/packages/function/src/api.ts
index 2f8ece9f7..d08eedb4a 100644
--- a/app/packages/function/src/api.ts
+++ b/app/packages/function/src/api.ts
@@ -82,7 +82,7 @@ export default {
const body = await request.json()
const sessionID = body.sessionID
const shareID = createHash("sha256").update(sessionID).digest("hex")
- const infoFile = `${shareID}/info/${sessionID}.json`
+ const infoFile = `${shareID}/session/info/${sessionID}.json`
const ret = await Resource.Bucket.get(infoFile)
if (ret)
return new Response("Error: Session already sharing", { status: 400 })
@@ -97,7 +97,7 @@ export default {
const body = await request.json()
const sessionID = body.sessionID
const shareID = body.shareID
- const infoFile = `${shareID}/info/${sessionID}.json`
+ const infoFile = `${shareID}/session/info/${sessionID}.json`
await Resource.Bucket.delete(infoFile)
return new Response(JSON.stringify({}), {
headers: { "Content-Type": "application/json" },
@@ -107,14 +107,17 @@ export default {
const body = await request.json()
const sessionID = body.sessionID
const shareID = body.shareID
- const key = body.key
+ const key = `${body.key}.json`
const content = body.content
// validate key
- if (!key.startsWith("info/") && !key.startsWith("message/"))
+ if (
+ !key.startsWith(`session/info/${sessionID}`) &&
+ !key.startsWith(`session/message/${sessionID}/`)
+ )
return new Response("Error: Invalid key", { status: 400 })
- const infoFile = `${shareID}/info/${sessionID}.json`
+ const infoFile = `${shareID}/session/info/${sessionID}.json`
const ret = await Resource.Bucket.get(infoFile)
if (!ret)
return new Response("Error: Session not shared", { status: 400 })
@@ -148,7 +151,7 @@ export default {
// Get session ID
const listRet = await Resource.Bucket.list({
- prefix: `${shareID}/info/`,
+ prefix: `${shareID}/session/info/`,
delimiter: "/",
})