@kulupu-linku/sona 0.3.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/client.js CHANGED
@@ -149,7 +149,7 @@ var l = (e, t) => new Proxy(() => {
149
149
  return o;
150
150
  }, []);
151
151
  const b = (e) => {
152
- const { baseUrl: t = "https://api.linku.la", fetch: r = global.fetch } = e;
152
+ const { baseUrl: t = "https://api.linku.la", fetch: r = globalThis.fetch } = e ?? {};
153
153
  return C(t, {
154
154
  fetch: r
155
155
  });
@@ -157,4 +157,4 @@ const b = (e) => {
157
157
  export {
158
158
  b as client
159
159
  };
160
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"client.js","sources":["../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/utils/cookie.js","../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/client/utils.js","../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/client/client.js","../src/lib/client.ts"],"sourcesContent":["// src/utils/cookie.ts\nimport { decodeURIComponent_ } from \"./url.js\";\nvar algorithm = { name: \"HMAC\", hash: \"SHA-256\" };\nvar getCryptoKey = async (secret) => {\n  const secretBuf = typeof secret === \"string\" ? new TextEncoder().encode(secret) : secret;\n  return await crypto.subtle.importKey(\"raw\", secretBuf, algorithm, false, [\"sign\", \"verify\"]);\n};\nvar makeSignature = async (value, secret) => {\n  const key = await getCryptoKey(secret);\n  const signature = await crypto.subtle.sign(algorithm.name, key, new TextEncoder().encode(value));\n  return btoa(String.fromCharCode(...new Uint8Array(signature)));\n};\nvar verifySignature = async (base64Signature, value, secret) => {\n  try {\n    const signatureBinStr = atob(base64Signature);\n    const signature = new Uint8Array(signatureBinStr.length);\n    for (let i = 0, len = signatureBinStr.length; i < len; i++) {\n      signature[i] = signatureBinStr.charCodeAt(i);\n    }\n    return await crypto.subtle.verify(algorithm, secret, signature, new TextEncoder().encode(value));\n  } catch (e) {\n    return false;\n  }\n};\nvar validCookieNameRegEx = /^[\\w!#$%&'*.^`|~+-]+$/;\nvar validCookieValueRegEx = /^[ !#-:<-[\\]-~]*$/;\nvar parse = (cookie, name) => {\n  const pairs = cookie.trim().split(\";\");\n  return pairs.reduce((parsedCookie, pairStr) => {\n    pairStr = pairStr.trim();\n    const valueStartPos = pairStr.indexOf(\"=\");\n    if (valueStartPos === -1) {\n      return parsedCookie;\n    }\n    const cookieName = pairStr.substring(0, valueStartPos).trim();\n    if (name && name !== cookieName || !validCookieNameRegEx.test(cookieName)) {\n      return parsedCookie;\n    }\n    let cookieValue = pairStr.substring(valueStartPos + 1).trim();\n    if (cookieValue.startsWith('\"') && cookieValue.endsWith('\"')) {\n      cookieValue = cookieValue.slice(1, -1);\n    }\n    if (validCookieValueRegEx.test(cookieValue)) {\n      parsedCookie[cookieName] = decodeURIComponent_(cookieValue);\n    }\n    return parsedCookie;\n  }, {});\n};\nvar parseSigned = async (cookie, secret, name) => {\n  const parsedCookie = {};\n  const secretKey = await getCryptoKey(secret);\n  for (const [key, value] of Object.entries(parse(cookie, name))) {\n    const signatureStartPos = value.lastIndexOf(\".\");\n    if (signatureStartPos < 1) {\n      continue;\n    }\n    const signedValue = value.substring(0, signatureStartPos);\n    const signature = value.substring(signatureStartPos + 1);\n    if (signature.length !== 44 || !signature.endsWith(\"=\")) {\n      continue;\n    }\n    const isVerified = await verifySignature(signature, signedValue, secretKey);\n    parsedCookie[key] = isVerified ? signedValue : false;\n  }\n  return parsedCookie;\n};\nvar _serialize = (name, value, opt = {}) => {\n  let cookie = `${name}=${value}`;\n  if (name.startsWith(\"__Secure-\") && !opt.secure) {\n    throw new Error(\"__Secure- Cookie must have Secure attributes\");\n  }\n  if (name.startsWith(\"__Host-\")) {\n    if (!opt.secure) {\n      throw new Error(\"__Host- Cookie must have Secure attributes\");\n    }\n    if (opt.path !== \"/\") {\n      throw new Error('__Host- Cookie must have Path attributes with \"/\"');\n    }\n    if (opt.domain) {\n      throw new Error(\"__Host- Cookie must not have Domain attributes\");\n    }\n  }\n  if (opt && typeof opt.maxAge === \"number\" && opt.maxAge >= 0) {\n    if (opt.maxAge > 3456e4) {\n      throw new Error(\n        \"Cookies Max-Age SHOULD NOT be greater than 400 days (34560000 seconds) in duration.\"\n      );\n    }\n    cookie += `; Max-Age=${Math.floor(opt.maxAge)}`;\n  }\n  if (opt.domain && opt.prefix !== \"host\") {\n    cookie += `; Domain=${opt.domain}`;\n  }\n  if (opt.path) {\n    cookie += `; Path=${opt.path}`;\n  }\n  if (opt.expires) {\n    if (opt.expires.getTime() - Date.now() > 3456e7) {\n      throw new Error(\n        \"Cookies Expires SHOULD NOT be greater than 400 days (34560000 seconds) in the future.\"\n      );\n    }\n    cookie += `; Expires=${opt.expires.toUTCString()}`;\n  }\n  if (opt.httpOnly) {\n    cookie += \"; HttpOnly\";\n  }\n  if (opt.secure) {\n    cookie += \"; Secure\";\n  }\n  if (opt.sameSite) {\n    cookie += `; SameSite=${opt.sameSite}`;\n  }\n  if (opt.partitioned) {\n    if (!opt.secure) {\n      throw new Error(\"Partitioned Cookie must have Secure attributes\");\n    }\n    cookie += \"; Partitioned\";\n  }\n  return cookie;\n};\nvar serialize = (name, value, opt) => {\n  value = encodeURIComponent(value);\n  return _serialize(name, value, opt);\n};\nvar serializeSigned = async (name, value, secret, opt = {}) => {\n  const signature = await makeSignature(value, secret);\n  value = `${value}.${signature}`;\n  value = encodeURIComponent(value);\n  return _serialize(name, value, opt);\n};\nexport {\n  parse,\n  parseSigned,\n  serialize,\n  serializeSigned\n};\n","// src/client/utils.ts\nvar mergePath = (base, path) => {\n  base = base.replace(/\\/+$/, \"\");\n  base = base + \"/\";\n  path = path.replace(/^\\/+/, \"\");\n  return base + path;\n};\nvar replaceUrlParam = (urlString, params) => {\n  for (const [k, v] of Object.entries(params)) {\n    const reg = new RegExp(\"/:\" + k + \"(?:{[^/]+})?\");\n    urlString = urlString.replace(reg, `/${v}`);\n  }\n  return urlString;\n};\nvar replaceUrlProtocol = (urlString, protocol) => {\n  switch (protocol) {\n    case \"ws\":\n      return urlString.replace(/^http/, \"ws\");\n    case \"http\":\n      return urlString.replace(/^ws/, \"http\");\n  }\n};\nvar removeIndexString = (urlSting) => {\n  return urlSting.replace(/\\/index$/, \"\");\n};\nfunction isObject(item) {\n  return typeof item === \"object\" && item !== null && !Array.isArray(item);\n}\nfunction deepMerge(target, source) {\n  if (!isObject(target) && !isObject(source)) {\n    return source;\n  }\n  const merged = { ...target };\n  for (const key in source) {\n    const value = source[key];\n    if (isObject(merged[key]) && isObject(value)) {\n      merged[key] = deepMerge(merged[key], value);\n    } else {\n      merged[key] = value;\n    }\n  }\n  return merged;\n}\nexport {\n  deepMerge,\n  mergePath,\n  removeIndexString,\n  replaceUrlParam,\n  replaceUrlProtocol\n};\n","// src/client/client.ts\nimport { serialize } from \"../utils/cookie.js\";\nimport {\n  deepMerge,\n  mergePath,\n  removeIndexString,\n  replaceUrlParam,\n  replaceUrlProtocol\n} from \"./utils.js\";\nvar createProxy = (callback, path) => {\n  const proxy = new Proxy(() => {\n  }, {\n    get(_obj, key) {\n      if (typeof key !== \"string\" || key === \"then\") {\n        return void 0;\n      }\n      return createProxy(callback, [...path, key]);\n    },\n    apply(_1, _2, args) {\n      return callback({\n        path,\n        args\n      });\n    }\n  });\n  return proxy;\n};\nvar ClientRequestImpl = class {\n  url;\n  method;\n  queryParams = void 0;\n  pathParams = {};\n  rBody;\n  cType = void 0;\n  constructor(url, method) {\n    this.url = url;\n    this.method = method;\n  }\n  fetch = async (args, opt) => {\n    if (args) {\n      if (args.query) {\n        for (const [k, v] of Object.entries(args.query)) {\n          if (v === void 0) {\n            continue;\n          }\n          this.queryParams ||= new URLSearchParams();\n          if (Array.isArray(v)) {\n            for (const v2 of v) {\n              this.queryParams.append(k, v2);\n            }\n          } else {\n            this.queryParams.set(k, v);\n          }\n        }\n      }\n      if (args.form) {\n        const form = new FormData();\n        for (const [k, v] of Object.entries(args.form)) {\n          form.append(k, v);\n        }\n        this.rBody = form;\n      }\n      if (args.json) {\n        this.rBody = JSON.stringify(args.json);\n        this.cType = \"application/json\";\n      }\n      if (args.param) {\n        this.pathParams = args.param;\n      }\n    }\n    let methodUpperCase = this.method.toUpperCase();\n    const headerValues = {\n      ...args?.header ?? {},\n      ...typeof opt?.headers === \"function\" ? await opt.headers() : opt?.headers ? opt.headers : {}\n    };\n    if (args?.cookie) {\n      const cookies = [];\n      for (const [key, value] of Object.entries(args.cookie)) {\n        cookies.push(serialize(key, value, { path: \"/\" }));\n      }\n      headerValues[\"Cookie\"] = cookies.join(\",\");\n    }\n    if (this.cType) {\n      headerValues[\"Content-Type\"] = this.cType;\n    }\n    const headers = new Headers(headerValues ?? void 0);\n    let url = this.url;\n    url = removeIndexString(url);\n    url = replaceUrlParam(url, this.pathParams);\n    if (this.queryParams) {\n      url = url + \"?\" + this.queryParams.toString();\n    }\n    methodUpperCase = this.method.toUpperCase();\n    const setBody = !(methodUpperCase === \"GET\" || methodUpperCase === \"HEAD\");\n    return (opt?.fetch || fetch)(url, {\n      body: setBody ? this.rBody : void 0,\n      method: methodUpperCase,\n      headers\n    });\n  };\n};\nvar hc = (baseUrl, options) => createProxy((opts) => {\n  const parts = [...opts.path];\n  let method = \"\";\n  if (/^\\$/.test(parts[parts.length - 1])) {\n    const last = parts.pop();\n    if (last) {\n      method = last.replace(/^\\$/, \"\");\n    }\n  }\n  const path = parts.join(\"/\");\n  const url = mergePath(baseUrl, path);\n  if (method === \"url\") {\n    if (opts.args[0] && opts.args[0].param) {\n      return new URL(replaceUrlParam(url, opts.args[0].param));\n    }\n    return new URL(url);\n  }\n  if (method === \"ws\") {\n    const targetUrl = replaceUrlProtocol(\n      opts.args[0] && opts.args[0].param ? replaceUrlParam(url, opts.args[0].param) : url,\n      \"ws\"\n    );\n    return new WebSocket(targetUrl);\n  }\n  const req = new ClientRequestImpl(url, method);\n  if (method) {\n    options ??= {};\n    const args = deepMerge(options, { ...opts.args[1] ?? {} });\n    return req.fetch(opts.args[0], args);\n  }\n  return req;\n}, []);\nexport {\n  hc\n};\n","import { hc } from \"hono/client\";\nimport type { AppType } from \"$server\";\n\nexport const client = (args?: { baseUrl?: string; fetch?: (typeof global)[\"fetch\"] }) => {\n\tconst { baseUrl = \"https://api.linku.la\", fetch = global.fetch } = args;\n\treturn hc<AppType>(baseUrl, {\n\t\tfetch,\n\t});\n};\n\nexport type ApiType = AppType;\n"],"names":["_serialize","name","value","opt","cookie","serialize","mergePath","base","path","replaceUrlParam","urlString","params","k","v","reg","replaceUrlProtocol","protocol","removeIndexString","urlSting","isObject","item","deepMerge","target","source","merged","key","createProxy","callback","_obj","_1","_2","args","ClientRequestImpl","url","method","__publicField","v2","form","methodUpperCase","headerValues","cookies","headers","setBody","hc","baseUrl","options","opts","parts","last","targetUrl","req","client","fetch"],"mappings":"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","x_google_ignoreList":[0,1,2]}
160
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"client.js","sources":["../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/utils/cookie.js","../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/client/utils.js","../node_modules/.pnpm/hono@4.2.4/node_modules/hono/dist/client/client.js","../src/lib/client.ts"],"sourcesContent":["// src/utils/cookie.ts\nimport { decodeURIComponent_ } from \"./url.js\";\nvar algorithm = { name: \"HMAC\", hash: \"SHA-256\" };\nvar getCryptoKey = async (secret) => {\n  const secretBuf = typeof secret === \"string\" ? new TextEncoder().encode(secret) : secret;\n  return await crypto.subtle.importKey(\"raw\", secretBuf, algorithm, false, [\"sign\", \"verify\"]);\n};\nvar makeSignature = async (value, secret) => {\n  const key = await getCryptoKey(secret);\n  const signature = await crypto.subtle.sign(algorithm.name, key, new TextEncoder().encode(value));\n  return btoa(String.fromCharCode(...new Uint8Array(signature)));\n};\nvar verifySignature = async (base64Signature, value, secret) => {\n  try {\n    const signatureBinStr = atob(base64Signature);\n    const signature = new Uint8Array(signatureBinStr.length);\n    for (let i = 0, len = signatureBinStr.length; i < len; i++) {\n      signature[i] = signatureBinStr.charCodeAt(i);\n    }\n    return await crypto.subtle.verify(algorithm, secret, signature, new TextEncoder().encode(value));\n  } catch (e) {\n    return false;\n  }\n};\nvar validCookieNameRegEx = /^[\\w!#$%&'*.^`|~+-]+$/;\nvar validCookieValueRegEx = /^[ !#-:<-[\\]-~]*$/;\nvar parse = (cookie, name) => {\n  const pairs = cookie.trim().split(\";\");\n  return pairs.reduce((parsedCookie, pairStr) => {\n    pairStr = pairStr.trim();\n    const valueStartPos = pairStr.indexOf(\"=\");\n    if (valueStartPos === -1) {\n      return parsedCookie;\n    }\n    const cookieName = pairStr.substring(0, valueStartPos).trim();\n    if (name && name !== cookieName || !validCookieNameRegEx.test(cookieName)) {\n      return parsedCookie;\n    }\n    let cookieValue = pairStr.substring(valueStartPos + 1).trim();\n    if (cookieValue.startsWith('\"') && cookieValue.endsWith('\"')) {\n      cookieValue = cookieValue.slice(1, -1);\n    }\n    if (validCookieValueRegEx.test(cookieValue)) {\n      parsedCookie[cookieName] = decodeURIComponent_(cookieValue);\n    }\n    return parsedCookie;\n  }, {});\n};\nvar parseSigned = async (cookie, secret, name) => {\n  const parsedCookie = {};\n  const secretKey = await getCryptoKey(secret);\n  for (const [key, value] of Object.entries(parse(cookie, name))) {\n    const signatureStartPos = value.lastIndexOf(\".\");\n    if (signatureStartPos < 1) {\n      continue;\n    }\n    const signedValue = value.substring(0, signatureStartPos);\n    const signature = value.substring(signatureStartPos + 1);\n    if (signature.length !== 44 || !signature.endsWith(\"=\")) {\n      continue;\n    }\n    const isVerified = await verifySignature(signature, signedValue, secretKey);\n    parsedCookie[key] = isVerified ? signedValue : false;\n  }\n  return parsedCookie;\n};\nvar _serialize = (name, value, opt = {}) => {\n  let cookie = `${name}=${value}`;\n  if (name.startsWith(\"__Secure-\") && !opt.secure) {\n    throw new Error(\"__Secure- Cookie must have Secure attributes\");\n  }\n  if (name.startsWith(\"__Host-\")) {\n    if (!opt.secure) {\n      throw new Error(\"__Host- Cookie must have Secure attributes\");\n    }\n    if (opt.path !== \"/\") {\n      throw new Error('__Host- Cookie must have Path attributes with \"/\"');\n    }\n    if (opt.domain) {\n      throw new Error(\"__Host- Cookie must not have Domain attributes\");\n    }\n  }\n  if (opt && typeof opt.maxAge === \"number\" && opt.maxAge >= 0) {\n    if (opt.maxAge > 3456e4) {\n      throw new Error(\n        \"Cookies Max-Age SHOULD NOT be greater than 400 days (34560000 seconds) in duration.\"\n      );\n    }\n    cookie += `; Max-Age=${Math.floor(opt.maxAge)}`;\n  }\n  if (opt.domain && opt.prefix !== \"host\") {\n    cookie += `; Domain=${opt.domain}`;\n  }\n  if (opt.path) {\n    cookie += `; Path=${opt.path}`;\n  }\n  if (opt.expires) {\n    if (opt.expires.getTime() - Date.now() > 3456e7) {\n      throw new Error(\n        \"Cookies Expires SHOULD NOT be greater than 400 days (34560000 seconds) in the future.\"\n      );\n    }\n    cookie += `; Expires=${opt.expires.toUTCString()}`;\n  }\n  if (opt.httpOnly) {\n    cookie += \"; HttpOnly\";\n  }\n  if (opt.secure) {\n    cookie += \"; Secure\";\n  }\n  if (opt.sameSite) {\n    cookie += `; SameSite=${opt.sameSite}`;\n  }\n  if (opt.partitioned) {\n    if (!opt.secure) {\n      throw new Error(\"Partitioned Cookie must have Secure attributes\");\n    }\n    cookie += \"; Partitioned\";\n  }\n  return cookie;\n};\nvar serialize = (name, value, opt) => {\n  value = encodeURIComponent(value);\n  return _serialize(name, value, opt);\n};\nvar serializeSigned = async (name, value, secret, opt = {}) => {\n  const signature = await makeSignature(value, secret);\n  value = `${value}.${signature}`;\n  value = encodeURIComponent(value);\n  return _serialize(name, value, opt);\n};\nexport {\n  parse,\n  parseSigned,\n  serialize,\n  serializeSigned\n};\n","// src/client/utils.ts\nvar mergePath = (base, path) => {\n  base = base.replace(/\\/+$/, \"\");\n  base = base + \"/\";\n  path = path.replace(/^\\/+/, \"\");\n  return base + path;\n};\nvar replaceUrlParam = (urlString, params) => {\n  for (const [k, v] of Object.entries(params)) {\n    const reg = new RegExp(\"/:\" + k + \"(?:{[^/]+})?\");\n    urlString = urlString.replace(reg, `/${v}`);\n  }\n  return urlString;\n};\nvar replaceUrlProtocol = (urlString, protocol) => {\n  switch (protocol) {\n    case \"ws\":\n      return urlString.replace(/^http/, \"ws\");\n    case \"http\":\n      return urlString.replace(/^ws/, \"http\");\n  }\n};\nvar removeIndexString = (urlSting) => {\n  return urlSting.replace(/\\/index$/, \"\");\n};\nfunction isObject(item) {\n  return typeof item === \"object\" && item !== null && !Array.isArray(item);\n}\nfunction deepMerge(target, source) {\n  if (!isObject(target) && !isObject(source)) {\n    return source;\n  }\n  const merged = { ...target };\n  for (const key in source) {\n    const value = source[key];\n    if (isObject(merged[key]) && isObject(value)) {\n      merged[key] = deepMerge(merged[key], value);\n    } else {\n      merged[key] = value;\n    }\n  }\n  return merged;\n}\nexport {\n  deepMerge,\n  mergePath,\n  removeIndexString,\n  replaceUrlParam,\n  replaceUrlProtocol\n};\n","// src/client/client.ts\nimport { serialize } from \"../utils/cookie.js\";\nimport {\n  deepMerge,\n  mergePath,\n  removeIndexString,\n  replaceUrlParam,\n  replaceUrlProtocol\n} from \"./utils.js\";\nvar createProxy = (callback, path) => {\n  const proxy = new Proxy(() => {\n  }, {\n    get(_obj, key) {\n      if (typeof key !== \"string\" || key === \"then\") {\n        return void 0;\n      }\n      return createProxy(callback, [...path, key]);\n    },\n    apply(_1, _2, args) {\n      return callback({\n        path,\n        args\n      });\n    }\n  });\n  return proxy;\n};\nvar ClientRequestImpl = class {\n  url;\n  method;\n  queryParams = void 0;\n  pathParams = {};\n  rBody;\n  cType = void 0;\n  constructor(url, method) {\n    this.url = url;\n    this.method = method;\n  }\n  fetch = async (args, opt) => {\n    if (args) {\n      if (args.query) {\n        for (const [k, v] of Object.entries(args.query)) {\n          if (v === void 0) {\n            continue;\n          }\n          this.queryParams ||= new URLSearchParams();\n          if (Array.isArray(v)) {\n            for (const v2 of v) {\n              this.queryParams.append(k, v2);\n            }\n          } else {\n            this.queryParams.set(k, v);\n          }\n        }\n      }\n      if (args.form) {\n        const form = new FormData();\n        for (const [k, v] of Object.entries(args.form)) {\n          form.append(k, v);\n        }\n        this.rBody = form;\n      }\n      if (args.json) {\n        this.rBody = JSON.stringify(args.json);\n        this.cType = \"application/json\";\n      }\n      if (args.param) {\n        this.pathParams = args.param;\n      }\n    }\n    let methodUpperCase = this.method.toUpperCase();\n    const headerValues = {\n      ...args?.header ?? {},\n      ...typeof opt?.headers === \"function\" ? await opt.headers() : opt?.headers ? opt.headers : {}\n    };\n    if (args?.cookie) {\n      const cookies = [];\n      for (const [key, value] of Object.entries(args.cookie)) {\n        cookies.push(serialize(key, value, { path: \"/\" }));\n      }\n      headerValues[\"Cookie\"] = cookies.join(\",\");\n    }\n    if (this.cType) {\n      headerValues[\"Content-Type\"] = this.cType;\n    }\n    const headers = new Headers(headerValues ?? void 0);\n    let url = this.url;\n    url = removeIndexString(url);\n    url = replaceUrlParam(url, this.pathParams);\n    if (this.queryParams) {\n      url = url + \"?\" + this.queryParams.toString();\n    }\n    methodUpperCase = this.method.toUpperCase();\n    const setBody = !(methodUpperCase === \"GET\" || methodUpperCase === \"HEAD\");\n    return (opt?.fetch || fetch)(url, {\n      body: setBody ? this.rBody : void 0,\n      method: methodUpperCase,\n      headers\n    });\n  };\n};\nvar hc = (baseUrl, options) => createProxy((opts) => {\n  const parts = [...opts.path];\n  let method = \"\";\n  if (/^\\$/.test(parts[parts.length - 1])) {\n    const last = parts.pop();\n    if (last) {\n      method = last.replace(/^\\$/, \"\");\n    }\n  }\n  const path = parts.join(\"/\");\n  const url = mergePath(baseUrl, path);\n  if (method === \"url\") {\n    if (opts.args[0] && opts.args[0].param) {\n      return new URL(replaceUrlParam(url, opts.args[0].param));\n    }\n    return new URL(url);\n  }\n  if (method === \"ws\") {\n    const targetUrl = replaceUrlProtocol(\n      opts.args[0] && opts.args[0].param ? replaceUrlParam(url, opts.args[0].param) : url,\n      \"ws\"\n    );\n    return new WebSocket(targetUrl);\n  }\n  const req = new ClientRequestImpl(url, method);\n  if (method) {\n    options ??= {};\n    const args = deepMerge(options, { ...opts.args[1] ?? {} });\n    return req.fetch(opts.args[0], args);\n  }\n  return req;\n}, []);\nexport {\n  hc\n};\n","import { hc } from \"hono/client\";\nimport type { AppType } from \"$server\";\n\nexport const client = (args?: { baseUrl?: string; fetch?: (typeof globalThis)[\"fetch\"] }) => {\n\tconst { baseUrl = \"https://api.linku.la\", fetch = globalThis.fetch } = args ?? {};\n\treturn hc<AppType>(baseUrl, {\n\t\tfetch,\n\t});\n};\n\nexport type ApiType = AppType;\n"],"names":["_serialize","name","value","opt","cookie","serialize","mergePath","base","path","replaceUrlParam","urlString","params","k","v","reg","replaceUrlProtocol","protocol","removeIndexString","urlSting","isObject","item","deepMerge","target","source","merged","key","createProxy","callback","_obj","_1","_2","args","ClientRequestImpl","url","method","__publicField","v2","form","methodUpperCase","headerValues","cookies","headers","setBody","hc","baseUrl","options","opts","parts","last","targetUrl","req","client","fetch"],"mappings":"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","x_google_ignoreList":[0,1,2]}
@@ -2,7 +2,7 @@ import { AppType } from '../server';
2
2
 
3
3
  export declare const client: (args?: {
4
4
  baseUrl?: string;
5
- fetch?: (typeof global)["fetch"];
5
+ fetch?: (typeof globalThis)["fetch"];
6
6
  }) => {
7
7
  index: import('hono/client').ClientRequest<{
8
8
  $get: {
@@ -83,7 +83,7 @@ export declare const client: (args?: {
83
83
  jasima: import('hono/client').ClientRequest<{
84
84
  $get: {
85
85
  input: {};
86
- output: {};
86
+ output: never;
87
87
  };
88
88
  }>;
89
89
  } & {
@@ -343,6 +343,14 @@ export declare const client: (args?: {
343
343
  language: string;
344
344
  sign: string;
345
345
  }[];
346
+ translations: Record<string, {
347
+ parameters: {
348
+ handshape?: string | undefined;
349
+ movement?: string | undefined;
350
+ placement?: string | undefined;
351
+ orientation?: string | undefined;
352
+ };
353
+ }>;
346
354
  is_two_handed: boolean;
347
355
  signwriting: {
348
356
  fsw: string;
@@ -421,6 +429,15 @@ export declare const client: (args?: {
421
429
  language: string;
422
430
  sign?: string | undefined;
423
431
  }[];
432
+ translations: Record<string, {
433
+ parameters: {
434
+ handshape?: string | undefined;
435
+ movement?: string | undefined;
436
+ placement?: string | undefined;
437
+ orientation?: string | undefined;
438
+ };
439
+ icons: string;
440
+ }>;
424
441
  definition: string;
425
442
  is_two_handed: boolean;
426
443
  new_gloss: string;
@@ -6,7 +6,7 @@ import { Fingerspelling, Font, Fonts, Language, Languages, LocalizedFingerspelli
6
6
  type ResponseType<F> = F extends {
7
7
  $get: (...args: any[]) => Promise<ClientResponse<infer O>>;
8
8
  } ? O : never;
9
- type ClientType = typeof client;
9
+ type ClientType = ReturnType<typeof client>;
10
10
  type Result<T> = {
11
11
  ok: true;
12
12
  data: T;
@@ -299,6 +299,14 @@ declare const app: import('hono/hono-base').HonoBase<{}, {
299
299
  language: string;
300
300
  sign: string;
301
301
  }[];
302
+ translations: Record<string, {
303
+ parameters: {
304
+ handshape?: string | undefined;
305
+ movement?: string | undefined;
306
+ placement?: string | undefined;
307
+ orientation?: string | undefined;
308
+ };
309
+ }>;
302
310
  is_two_handed: boolean;
303
311
  signwriting: {
304
312
  fsw: string;
@@ -365,6 +373,15 @@ declare const app: import('hono/hono-base').HonoBase<{}, {
365
373
  language: string;
366
374
  sign?: string | undefined;
367
375
  }[];
376
+ translations: Record<string, {
377
+ parameters: {
378
+ handshape?: string | undefined;
379
+ movement?: string | undefined;
380
+ placement?: string | undefined;
381
+ orientation?: string | undefined;
382
+ };
383
+ icons: string;
384
+ }>;
368
385
  definition: string;
369
386
  is_two_handed: boolean;
370
387
  new_gloss: string;
@@ -477,7 +494,7 @@ declare const app: import('hono/hono-base').HonoBase<{}, {
477
494
  "/jasima": {
478
495
  $get: {
479
496
  input: {};
480
- output: {};
497
+ output: never;
481
498
  };
482
499
  };
483
500
  }, "/">;
@@ -14,7 +14,7 @@ export declare const keys: <const K extends PropertyKey>(o: Record<K, any>) => K
14
14
  export declare const filterObject: <const T extends object>(o: T, predicate: (o: [keyof T, T[keyof T]]) => boolean) => {
15
15
  [k: string]: T[keyof T];
16
16
  };
17
- export declare const langIdCoalesce: (lang: string, langs: Languages) => string | null;
17
+ export declare const langIdCoalesce: (lang: string, langs: Languages) => string | undefined;
18
18
  export declare const langValidator: import('hono').MiddlewareHandler<import('hono').Env, string, {
19
19
  in: {
20
20
  query: {
@@ -309,6 +309,14 @@ declare const app: Hono<{}, {
309
309
  language: string;
310
310
  sign: string;
311
311
  }[];
312
+ translations: Record<string, {
313
+ parameters: {
314
+ handshape?: string | undefined;
315
+ movement?: string | undefined;
316
+ placement?: string | undefined;
317
+ orientation?: string | undefined;
318
+ };
319
+ }>;
312
320
  is_two_handed: boolean;
313
321
  signwriting: {
314
322
  fsw: string;
@@ -377,6 +385,15 @@ declare const app: Hono<{}, {
377
385
  language: string;
378
386
  sign?: string | undefined;
379
387
  }[];
388
+ translations: Record<string, {
389
+ parameters: {
390
+ handshape?: string | undefined;
391
+ movement?: string | undefined;
392
+ placement?: string | undefined;
393
+ orientation?: string | undefined;
394
+ };
395
+ icons: string;
396
+ }>;
380
397
  definition: string;
381
398
  is_two_handed: boolean;
382
399
  new_gloss: string;
@@ -15,7 +15,7 @@ export type Versions = {
15
15
  };
16
16
  export declare const versions: {
17
17
  readonly v1: {
18
- readonly branch: any;
18
+ readonly branch: string;
19
19
  readonly schemas: {
20
20
  readonly words: z.ZodRecord<z.ZodString, z.ZodObject<{
21
21
  id: z.ZodString;
@@ -2046,6 +2046,14 @@ export declare const apps: {
2046
2046
  language: string;
2047
2047
  sign: string;
2048
2048
  }[];
2049
+ translations: Record<string, {
2050
+ parameters: {
2051
+ handshape?: string | undefined;
2052
+ movement?: string | undefined;
2053
+ placement?: string | undefined;
2054
+ orientation?: string | undefined;
2055
+ };
2056
+ }>;
2049
2057
  is_two_handed: boolean;
2050
2058
  signwriting: {
2051
2059
  fsw: string;
@@ -2114,6 +2122,15 @@ export declare const apps: {
2114
2122
  language: string;
2115
2123
  sign?: string | undefined;
2116
2124
  }[];
2125
+ translations: Record<string, {
2126
+ parameters: {
2127
+ handshape?: string | undefined;
2128
+ movement?: string | undefined;
2129
+ placement?: string | undefined;
2130
+ orientation?: string | undefined;
2131
+ };
2132
+ icons: string;
2133
+ }>;
2117
2134
  definition: string;
2118
2135
  is_two_handed: boolean;
2119
2136
  new_gloss: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kulupu-linku/sona",
3
- "version": "0.3.0",
3
+ "version": "0.3.1",
4
4
  "description": "A library providing TypeScript types and Zod schemas for the sona API",
5
5
  "homepage": "https://linku.la/",
6
6
  "bugs": {
@@ -70,6 +70,7 @@
70
70
  "build": "vite build",
71
71
  "build:lib": "vite build --mode lib",
72
72
  "generate": "tsx ./generateSchemas.ts",
73
- "generate:watch": "tsx ./generateSchemas.ts --watch-path=./**/*.ts"
73
+ "generate:watch": "tsx ./generateSchemas.ts --watch-path=./**/*.ts",
74
+ "format": "prettier --write ."
74
75
  }
75
76
  }