@kookee/sdk 0.0.24 → 0.0.26

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/index.cjs CHANGED
@@ -1,3 +1,2 @@
1
1
  'use strict';var B="https://api.kookee.dev",H="Kookee-API-Key",x="Kookee-Project-Id",i=class n extends Error{constructor(t,s,o){super(s);this.code=t;this.status=o;this.name="KookeeApiError",Object.setPrototypeOf(this,n.prototype);}},u=class{baseUrl;apiKey;projectId;constructor(e){this.apiKey=e.apiKey,this.projectId=e.projectId,this.baseUrl=e.baseUrl??B;}getHeaders(){let e={"Content-Type":"application/json"};return this.apiKey&&(e[H]=this.apiKey),this.projectId&&(e[x]=this.projectId),e}async get(e,t){let s=new URL(`${this.baseUrl}${e}`);if(t){for(let[y,r]of Object.entries(t))if(r!=null)if(Array.isArray(r))for(let a of r)s.searchParams.append(y,String(a));else s.searchParams.set(y,String(r));}let o=await fetch(s.toString(),{method:"GET",headers:this.getHeaders()});return this.handleResponse(o)}async post(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:this.getHeaders(),body:t?JSON.stringify(t):void 0});return this.handleResponse(s)}async*streamPost(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:{...this.getHeaders(),Accept:"text/event-stream"},body:t?JSON.stringify(t):void 0});if(!s.ok){let a=null;try{a=await s.json();}catch{}throw new i(a?.code??"UNKNOWN_ERROR",a?.message??`Request failed with status ${s.status}`,s.status)}if(!s.body)return;let o=s.body.getReader(),y=new TextDecoder,r="";try{for(;;){let{done:a,value:b}=await o.read();if(a)break;r+=y.decode(b,{stream:!0});let C=r.split(`
2
- `);r=C.pop()??"";for(let I of C){let P=I.trim();if(!(!P||P.startsWith(":"))&&P.startsWith("data: ")){let R=P.slice(6);if(R==="[DONE]")return;yield JSON.parse(R);}}}}finally{o.releaseLock();}}async handleResponse(e){if(!e.ok){let t=null;try{t=await e.json();}catch{}throw new i(t?.code??"UNKNOWN_ERROR",t?.message??`Request failed with status ${e.status}`,e.status)}return e.json()}};var p=class{constructor(e){this.http=e;}async list(e){let{excludeIds:t,...s}=e??{},o=t?.length?{...s,excludeIds:t.join(",")}:s;return this.http.get("/v1/announcements",o)}async getById(e,t){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}/translations`)}};var c=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/blog/posts",e)}async getBySlug(e,t){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}`,t)}async getTags(){return this.http.get("/v1/blog/tags")}async getTranslationsById(e){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/blog/posts/${encodeURIComponent(e)}/reactions`,t)}};var l=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/changelog",e)}async getBySlug(e,t){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/changelog/${encodeURIComponent(e)}/reactions`,t)}};var g=class{constructor(e){this.http=e;}async getByKey(e){return this.http.get(`/v1/config/${encodeURIComponent(e)}`)}async list(e){return this.http.get("/v1/config",e)}};var m=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/feedback",e)}async getById(e){return this.http.get(`/v1/feedback/by-id/${encodeURIComponent(e)}`)}async vote(e,t){return this.http.post(`/v1/feedback/${encodeURIComponent(e)}/vote`,t)}async getTopContributors(e){return this.http.get("/v1/feedback/top-contributors",e)}};var d=class{constructor(e){this.http=e;}async categories(e){return this.http.get("/v1/help/categories",e)}async list(e){return this.http.get("/v1/help/articles",e)}async getBySlug(e,t){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}`,t)}async search(e){return this.http.get("/v1/help/search",e)}async getTranslationsById(e){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}/translations`)}async chat(e){return this.http.post("/v1/help/chat",e)}chatStream(e){return this.http.streamPost("/v1/help/chat/stream",e)}async voteUsefulness(e,t,s){return this.http.post(`/v1/help/articles/by-id/${encodeURIComponent(e)}/vote-usefulness`,{vote:t,previousVote:s})}};var h=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/pages",e)}async getBySlug(e,t){return this.http.get(`/v1/pages/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/pages/${encodeURIComponent(e)}/translations`)}};var f=class{http;announcements;blog;changelog;config;feedback;help;pages;constructor(e){if(!e.apiKey&&!e.projectId)throw new Error("Either apiKey or projectId is required");this.http=new u({apiKey:e.apiKey,projectId:e.projectId,baseUrl:e.baseUrl}),this.announcements=new p(this.http),this.blog=new c(this.http),this.changelog=new l(this.http),this.config=new g(this.http),this.feedback=new m(this.http),this.help=new d(this.http),this.pages=new h(this.http);}async health(){return this.http.get("/v1/health")}};exports.AnnouncementModule=p;exports.BlogModule=c;exports.ChangelogModule=l;exports.ConfigModule=g;exports.FeedbackModule=m;exports.HelpModule=d;exports.Kookee=f;exports.KookeeApiError=i;exports.PagesModule=h;//# sourceMappingURL=index.cjs.map
3
- //# sourceMappingURL=index.cjs.map
2
+ `);r=C.pop()??"";for(let I of C){let P=I.trim();if(!(!P||P.startsWith(":"))&&P.startsWith("data: ")){let R=P.slice(6);if(R==="[DONE]")return;yield JSON.parse(R);}}}}finally{o.releaseLock();}}async handleResponse(e){if(!e.ok){let t=null;try{t=await e.json();}catch{}throw new i(t?.code??"UNKNOWN_ERROR",t?.message??`Request failed with status ${e.status}`,e.status)}return e.json()}};var p=class{constructor(e){this.http=e;}async list(e){let{excludeIds:t,...s}=e??{},o=t?.length?{...s,excludeIds:t.join(",")}:s;return this.http.get("/v1/announcements",o)}async getById(e,t){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}/translations`)}};var c=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/blog/posts",e)}async getBySlug(e,t){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}`,t)}async getTags(){return this.http.get("/v1/blog/tags")}async getTranslationsById(e){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/blog/posts/${encodeURIComponent(e)}/reactions`,t)}};var l=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/changelog",e)}async getBySlug(e,t){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/changelog/${encodeURIComponent(e)}/reactions`,t)}};var g=class{constructor(e){this.http=e;}async getByKey(e){return this.http.get(`/v1/config/${encodeURIComponent(e)}`)}async list(e){return this.http.get("/v1/config",e)}};var m=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/feedback",e)}async getById(e){return this.http.get(`/v1/feedback/by-id/${encodeURIComponent(e)}`)}async vote(e,t){return this.http.post(`/v1/feedback/${encodeURIComponent(e)}/vote`,t)}async getTopContributors(e){return this.http.get("/v1/feedback/top-contributors",e)}};var d=class{constructor(e){this.http=e;}async categories(e){return this.http.get("/v1/help/categories",e)}async list(e){return this.http.get("/v1/help/articles",e)}async getBySlug(e,t){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}`,t)}async search(e){return this.http.get("/v1/help/search",e)}async getTranslationsById(e){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}/translations`)}async chat(e){return this.http.post("/v1/help/chat",e)}chatStream(e){return this.http.streamPost("/v1/help/chat/stream",e)}async voteUsefulness(e,t,s){return this.http.post(`/v1/help/articles/by-id/${encodeURIComponent(e)}/vote-usefulness`,{vote:t,previousVote:s})}};var h=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/pages",e)}async getBySlug(e,t){return this.http.get(`/v1/pages/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/pages/${encodeURIComponent(e)}/translations`)}};var f=class{http;announcements;blog;changelog;config;feedback;help;pages;constructor(e){if(!e.apiKey&&!e.projectId)throw new Error("Either apiKey or projectId is required");this.http=new u({apiKey:e.apiKey,projectId:e.projectId,baseUrl:e.baseUrl}),this.announcements=new p(this.http),this.blog=new c(this.http),this.changelog=new l(this.http),this.config=new g(this.http),this.feedback=new m(this.http),this.help=new d(this.http),this.pages=new h(this.http);}async health(){return this.http.get("/v1/health")}};exports.AnnouncementModule=p;exports.BlogModule=c;exports.ChangelogModule=l;exports.ConfigModule=g;exports.FeedbackModule=m;exports.HelpModule=d;exports.Kookee=f;exports.KookeeApiError=i;exports.PagesModule=h;
package/dist/index.d.cts CHANGED
@@ -110,7 +110,7 @@ interface HelpArticleListItem {
110
110
  excerptHtml: string | null;
111
111
  status: string;
112
112
  position: number;
113
- metadata: Record<string, unknown>;
113
+ metadata: Record<string, NonNullable<unknown>>;
114
114
  category: {
115
115
  name: string;
116
116
  slug: string;
@@ -234,7 +234,7 @@ interface HelpChatSource {
234
234
  slug: string;
235
235
  title: string;
236
236
  visibility: HelpArticleVisibility;
237
- metadata: Record<string, unknown> | null;
237
+ metadata: Record<string, NonNullable<unknown>> | null;
238
238
  category: HelpChatSourceCategory;
239
239
  }
240
240
  type HelpChatStreamChunk = {
package/dist/index.d.ts CHANGED
@@ -110,7 +110,7 @@ interface HelpArticleListItem {
110
110
  excerptHtml: string | null;
111
111
  status: string;
112
112
  position: number;
113
- metadata: Record<string, unknown>;
113
+ metadata: Record<string, NonNullable<unknown>>;
114
114
  category: {
115
115
  name: string;
116
116
  slug: string;
@@ -234,7 +234,7 @@ interface HelpChatSource {
234
234
  slug: string;
235
235
  title: string;
236
236
  visibility: HelpArticleVisibility;
237
- metadata: Record<string, unknown> | null;
237
+ metadata: Record<string, NonNullable<unknown>> | null;
238
238
  category: HelpChatSourceCategory;
239
239
  }
240
240
  type HelpChatStreamChunk = {
@@ -0,0 +1,2 @@
1
+ (function(exports){'use strict';var B="https://api.kookee.dev",H="Kookee-API-Key",x="Kookee-Project-Id",i=class n extends Error{constructor(t,s,o){super(s);this.code=t;this.status=o;this.name="KookeeApiError",Object.setPrototypeOf(this,n.prototype);}},u=class{baseUrl;apiKey;projectId;constructor(e){this.apiKey=e.apiKey,this.projectId=e.projectId,this.baseUrl=e.baseUrl??B;}getHeaders(){let e={"Content-Type":"application/json"};return this.apiKey&&(e[H]=this.apiKey),this.projectId&&(e[x]=this.projectId),e}async get(e,t){let s=new URL(`${this.baseUrl}${e}`);if(t){for(let[y,r]of Object.entries(t))if(r!=null)if(Array.isArray(r))for(let a of r)s.searchParams.append(y,String(a));else s.searchParams.set(y,String(r));}let o=await fetch(s.toString(),{method:"GET",headers:this.getHeaders()});return this.handleResponse(o)}async post(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:this.getHeaders(),body:t?JSON.stringify(t):void 0});return this.handleResponse(s)}async*streamPost(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:{...this.getHeaders(),Accept:"text/event-stream"},body:t?JSON.stringify(t):void 0});if(!s.ok){let a=null;try{a=await s.json();}catch{}throw new i(a?.code??"UNKNOWN_ERROR",a?.message??`Request failed with status ${s.status}`,s.status)}if(!s.body)return;let o=s.body.getReader(),y=new TextDecoder,r="";try{for(;;){let{done:a,value:b}=await o.read();if(a)break;r+=y.decode(b,{stream:!0});let C=r.split(`
2
+ `);r=C.pop()??"";for(let I of C){let P=I.trim();if(!(!P||P.startsWith(":"))&&P.startsWith("data: ")){let R=P.slice(6);if(R==="[DONE]")return;yield JSON.parse(R);}}}}finally{o.releaseLock();}}async handleResponse(e){if(!e.ok){let t=null;try{t=await e.json();}catch{}throw new i(t?.code??"UNKNOWN_ERROR",t?.message??`Request failed with status ${e.status}`,e.status)}return e.json()}};var p=class{constructor(e){this.http=e;}async list(e){let{excludeIds:t,...s}=e??{},o=t?.length?{...s,excludeIds:t.join(",")}:s;return this.http.get("/v1/announcements",o)}async getById(e,t){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}/translations`)}};var c=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/blog/posts",e)}async getBySlug(e,t){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}`,t)}async getTags(){return this.http.get("/v1/blog/tags")}async getTranslationsById(e){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/blog/posts/${encodeURIComponent(e)}/reactions`,t)}};var l=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/changelog",e)}async getBySlug(e,t){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/changelog/${encodeURIComponent(e)}/reactions`,t)}};var g=class{constructor(e){this.http=e;}async getByKey(e){return this.http.get(`/v1/config/${encodeURIComponent(e)}`)}async list(e){return this.http.get("/v1/config",e)}};var m=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/feedback",e)}async getById(e){return this.http.get(`/v1/feedback/by-id/${encodeURIComponent(e)}`)}async vote(e,t){return this.http.post(`/v1/feedback/${encodeURIComponent(e)}/vote`,t)}async getTopContributors(e){return this.http.get("/v1/feedback/top-contributors",e)}};var d=class{constructor(e){this.http=e;}async categories(e){return this.http.get("/v1/help/categories",e)}async list(e){return this.http.get("/v1/help/articles",e)}async getBySlug(e,t){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}`,t)}async search(e){return this.http.get("/v1/help/search",e)}async getTranslationsById(e){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}/translations`)}async chat(e){return this.http.post("/v1/help/chat",e)}chatStream(e){return this.http.streamPost("/v1/help/chat/stream",e)}async voteUsefulness(e,t,s){return this.http.post(`/v1/help/articles/by-id/${encodeURIComponent(e)}/vote-usefulness`,{vote:t,previousVote:s})}};var h=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/pages",e)}async getBySlug(e,t){return this.http.get(`/v1/pages/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/pages/${encodeURIComponent(e)}/translations`)}};var f=class{http;announcements;blog;changelog;config;feedback;help;pages;constructor(e){if(!e.apiKey&&!e.projectId)throw new Error("Either apiKey or projectId is required");this.http=new u({apiKey:e.apiKey,projectId:e.projectId,baseUrl:e.baseUrl}),this.announcements=new p(this.http),this.blog=new c(this.http),this.changelog=new l(this.http),this.config=new g(this.http),this.feedback=new m(this.http),this.help=new d(this.http),this.pages=new h(this.http);}async health(){return this.http.get("/v1/health")}};exports.AnnouncementModule=p;exports.BlogModule=c;exports.ChangelogModule=l;exports.ConfigModule=g;exports.FeedbackModule=m;exports.HelpModule=d;exports.Kookee=f;exports.KookeeApiError=i;exports.PagesModule=h;return exports;})({});
package/dist/index.js CHANGED
@@ -1,3 +1,2 @@
1
1
  var B="https://api.kookee.dev",H="Kookee-API-Key",x="Kookee-Project-Id",i=class n extends Error{constructor(t,s,o){super(s);this.code=t;this.status=o;this.name="KookeeApiError",Object.setPrototypeOf(this,n.prototype);}},u=class{baseUrl;apiKey;projectId;constructor(e){this.apiKey=e.apiKey,this.projectId=e.projectId,this.baseUrl=e.baseUrl??B;}getHeaders(){let e={"Content-Type":"application/json"};return this.apiKey&&(e[H]=this.apiKey),this.projectId&&(e[x]=this.projectId),e}async get(e,t){let s=new URL(`${this.baseUrl}${e}`);if(t){for(let[y,r]of Object.entries(t))if(r!=null)if(Array.isArray(r))for(let a of r)s.searchParams.append(y,String(a));else s.searchParams.set(y,String(r));}let o=await fetch(s.toString(),{method:"GET",headers:this.getHeaders()});return this.handleResponse(o)}async post(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:this.getHeaders(),body:t?JSON.stringify(t):void 0});return this.handleResponse(s)}async*streamPost(e,t){let s=await fetch(`${this.baseUrl}${e}`,{method:"POST",headers:{...this.getHeaders(),Accept:"text/event-stream"},body:t?JSON.stringify(t):void 0});if(!s.ok){let a=null;try{a=await s.json();}catch{}throw new i(a?.code??"UNKNOWN_ERROR",a?.message??`Request failed with status ${s.status}`,s.status)}if(!s.body)return;let o=s.body.getReader(),y=new TextDecoder,r="";try{for(;;){let{done:a,value:b}=await o.read();if(a)break;r+=y.decode(b,{stream:!0});let C=r.split(`
2
- `);r=C.pop()??"";for(let I of C){let P=I.trim();if(!(!P||P.startsWith(":"))&&P.startsWith("data: ")){let R=P.slice(6);if(R==="[DONE]")return;yield JSON.parse(R);}}}}finally{o.releaseLock();}}async handleResponse(e){if(!e.ok){let t=null;try{t=await e.json();}catch{}throw new i(t?.code??"UNKNOWN_ERROR",t?.message??`Request failed with status ${e.status}`,e.status)}return e.json()}};var p=class{constructor(e){this.http=e;}async list(e){let{excludeIds:t,...s}=e??{},o=t?.length?{...s,excludeIds:t.join(",")}:s;return this.http.get("/v1/announcements",o)}async getById(e,t){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}/translations`)}};var c=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/blog/posts",e)}async getBySlug(e,t){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}`,t)}async getTags(){return this.http.get("/v1/blog/tags")}async getTranslationsById(e){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/blog/posts/${encodeURIComponent(e)}/reactions`,t)}};var l=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/changelog",e)}async getBySlug(e,t){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/changelog/${encodeURIComponent(e)}/reactions`,t)}};var g=class{constructor(e){this.http=e;}async getByKey(e){return this.http.get(`/v1/config/${encodeURIComponent(e)}`)}async list(e){return this.http.get("/v1/config",e)}};var m=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/feedback",e)}async getById(e){return this.http.get(`/v1/feedback/by-id/${encodeURIComponent(e)}`)}async vote(e,t){return this.http.post(`/v1/feedback/${encodeURIComponent(e)}/vote`,t)}async getTopContributors(e){return this.http.get("/v1/feedback/top-contributors",e)}};var d=class{constructor(e){this.http=e;}async categories(e){return this.http.get("/v1/help/categories",e)}async list(e){return this.http.get("/v1/help/articles",e)}async getBySlug(e,t){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}`,t)}async search(e){return this.http.get("/v1/help/search",e)}async getTranslationsById(e){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}/translations`)}async chat(e){return this.http.post("/v1/help/chat",e)}chatStream(e){return this.http.streamPost("/v1/help/chat/stream",e)}async voteUsefulness(e,t,s){return this.http.post(`/v1/help/articles/by-id/${encodeURIComponent(e)}/vote-usefulness`,{vote:t,previousVote:s})}};var h=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/pages",e)}async getBySlug(e,t){return this.http.get(`/v1/pages/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/pages/${encodeURIComponent(e)}/translations`)}};var f=class{http;announcements;blog;changelog;config;feedback;help;pages;constructor(e){if(!e.apiKey&&!e.projectId)throw new Error("Either apiKey or projectId is required");this.http=new u({apiKey:e.apiKey,projectId:e.projectId,baseUrl:e.baseUrl}),this.announcements=new p(this.http),this.blog=new c(this.http),this.changelog=new l(this.http),this.config=new g(this.http),this.feedback=new m(this.http),this.help=new d(this.http),this.pages=new h(this.http);}async health(){return this.http.get("/v1/health")}};export{p as AnnouncementModule,c as BlogModule,l as ChangelogModule,g as ConfigModule,m as FeedbackModule,d as HelpModule,f as Kookee,i as KookeeApiError,h as PagesModule};//# sourceMappingURL=index.js.map
3
- //# sourceMappingURL=index.js.map
2
+ `);r=C.pop()??"";for(let I of C){let P=I.trim();if(!(!P||P.startsWith(":"))&&P.startsWith("data: ")){let R=P.slice(6);if(R==="[DONE]")return;yield JSON.parse(R);}}}}finally{o.releaseLock();}}async handleResponse(e){if(!e.ok){let t=null;try{t=await e.json();}catch{}throw new i(t?.code??"UNKNOWN_ERROR",t?.message??`Request failed with status ${e.status}`,e.status)}return e.json()}};var p=class{constructor(e){this.http=e;}async list(e){let{excludeIds:t,...s}=e??{},o=t?.length?{...s,excludeIds:t.join(",")}:s;return this.http.get("/v1/announcements",o)}async getById(e,t){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/announcements/${encodeURIComponent(e)}/translations`)}};var c=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/blog/posts",e)}async getBySlug(e,t){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}`,t)}async getTags(){return this.http.get("/v1/blog/tags")}async getTranslationsById(e){return this.http.get(`/v1/blog/posts/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/blog/posts/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/blog/posts/${encodeURIComponent(e)}/reactions`,t)}};var l=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/changelog",e)}async getBySlug(e,t){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/changelog/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/changelog/${encodeURIComponent(e)}/translations`)}async react(e,t){return this.http.post(`/v1/changelog/${encodeURIComponent(e)}/reactions`,t)}};var g=class{constructor(e){this.http=e;}async getByKey(e){return this.http.get(`/v1/config/${encodeURIComponent(e)}`)}async list(e){return this.http.get("/v1/config",e)}};var m=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/feedback",e)}async getById(e){return this.http.get(`/v1/feedback/by-id/${encodeURIComponent(e)}`)}async vote(e,t){return this.http.post(`/v1/feedback/${encodeURIComponent(e)}/vote`,t)}async getTopContributors(e){return this.http.get("/v1/feedback/top-contributors",e)}};var d=class{constructor(e){this.http=e;}async categories(e){return this.http.get("/v1/help/categories",e)}async list(e){return this.http.get("/v1/help/articles",e)}async getBySlug(e,t){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}`,t)}async search(e){return this.http.get("/v1/help/search",e)}async getTranslationsById(e){return this.http.get(`/v1/help/articles/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/help/articles/${encodeURIComponent(e)}/translations`)}async chat(e){return this.http.post("/v1/help/chat",e)}chatStream(e){return this.http.streamPost("/v1/help/chat/stream",e)}async voteUsefulness(e,t,s){return this.http.post(`/v1/help/articles/by-id/${encodeURIComponent(e)}/vote-usefulness`,{vote:t,previousVote:s})}};var h=class{constructor(e){this.http=e;}async list(e){return this.http.get("/v1/pages",e)}async getBySlug(e,t){return this.http.get(`/v1/pages/${encodeURIComponent(e)}`,t)}async getById(e,t){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}`,t)}async getTranslationsById(e){return this.http.get(`/v1/pages/by-id/${encodeURIComponent(e)}/translations`)}async getTranslationsBySlug(e){return this.http.get(`/v1/pages/${encodeURIComponent(e)}/translations`)}};var f=class{http;announcements;blog;changelog;config;feedback;help;pages;constructor(e){if(!e.apiKey&&!e.projectId)throw new Error("Either apiKey or projectId is required");this.http=new u({apiKey:e.apiKey,projectId:e.projectId,baseUrl:e.baseUrl}),this.announcements=new p(this.http),this.blog=new c(this.http),this.changelog=new l(this.http),this.config=new g(this.http),this.feedback=new m(this.http),this.help=new d(this.http),this.pages=new h(this.http);}async health(){return this.http.get("/v1/health")}};export{p as AnnouncementModule,c as BlogModule,l as ChangelogModule,g as ConfigModule,m as FeedbackModule,d as HelpModule,f as Kookee,i as KookeeApiError,h as PagesModule};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kookee/sdk",
3
- "version": "0.0.24",
3
+ "version": "0.0.26",
4
4
  "description": "Official Kookee SDK - Access your blog, changelog, help center, and more",
5
5
  "main": "./dist/index.cjs",
6
6
  "module": "./dist/index.js",
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/http-client.ts","../src/lib/modules/announcement.ts","../src/lib/modules/blog.ts","../src/lib/modules/changelog.ts","../src/lib/modules/config.ts","../src/lib/modules/feedback.ts","../src/lib/modules/help.ts","../src/lib/modules/pages.ts","../src/lib/client.ts"],"names":["DEFAULT_BASE_URL","API_KEY_HEADER","PROJECT_ID_HEADER","KookeeApiError","_KookeeApiError","code","message","status","HttpClient","options","headers","path","params","url","key","value","item","response","body","errorData","reader","decoder","buffer","done","lines","line","trimmed","data","AnnouncementModule","http","excludeIds","rest","queryParams","id","BlogModule","slug","postId","ChangelogModule","changelogId","ConfigModule","FeedbackModule","HelpModule","articleId","vote","previousVote","PagesModule","pageId","Kookee","config"],"mappings":"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","file":"index.cjs","sourcesContent":["import type { ApiError } from './types';\n\nconst DEFAULT_BASE_URL = 'https://api.kookee.dev';\nconst API_KEY_HEADER = 'Kookee-API-Key';\nconst PROJECT_ID_HEADER = 'Kookee-Project-Id';\n\nexport class KookeeApiError extends Error {\n constructor(\n public readonly code: string,\n message: string,\n public readonly status: number\n ) {\n super(message);\n this.name = 'KookeeApiError';\n Object.setPrototypeOf(this, KookeeApiError.prototype);\n }\n}\n\nexport class HttpClient {\n private readonly baseUrl: string;\n private readonly apiKey?: string;\n private readonly projectId?: string;\n\n constructor(options: { apiKey?: string; projectId?: string; baseUrl?: string }) {\n this.apiKey = options.apiKey;\n this.projectId = options.projectId;\n this.baseUrl = options.baseUrl ?? DEFAULT_BASE_URL;\n }\n\n private getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n if (this.apiKey) {\n headers[API_KEY_HEADER] = this.apiKey;\n }\n if (this.projectId) {\n headers[PROJECT_ID_HEADER] = this.projectId;\n }\n return headers;\n }\n\n async get<T>(path: string, params?: object): Promise<T> {\n const url = new URL(`${this.baseUrl}${path}`);\n\n if (params) {\n for (const [key, value] of Object.entries(params)) {\n if (value !== undefined && value !== null) {\n if (Array.isArray(value)) {\n for (const item of value) {\n url.searchParams.append(key, String(item));\n }\n } else {\n url.searchParams.set(key, String(value));\n }\n }\n }\n }\n\n const response = await fetch(url.toString(), {\n method: 'GET',\n headers: this.getHeaders(),\n });\n\n return this.handleResponse<T>(response);\n }\n\n async post<T>(path: string, body?: unknown): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: body ? JSON.stringify(body) : undefined,\n });\n\n return this.handleResponse<T>(response);\n }\n\n async *streamPost<T>(path: string, body?: unknown): AsyncIterable<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n Accept: 'text/event-stream',\n },\n body: body ? JSON.stringify(body) : undefined,\n });\n\n if (!response.ok) {\n let errorData: ApiError | null = null;\n try {\n errorData = (await response.json()) as ApiError;\n } catch {\n // Response body is not JSON\n }\n throw new KookeeApiError(\n errorData?.code ?? 'UNKNOWN_ERROR',\n errorData?.message ?? `Request failed with status ${response.status}`,\n response.status\n );\n }\n\n if (!response.body) {\n return;\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() ?? '';\n\n for (const line of lines) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(':')) continue;\n if (trimmed.startsWith('data: ')) {\n const data = trimmed.slice(6);\n if (data === '[DONE]') return;\n yield JSON.parse(data) as T;\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n }\n\n private async handleResponse<T>(response: Response): Promise<T> {\n if (!response.ok) {\n let errorData: ApiError | null = null;\n\n try {\n errorData = (await response.json()) as ApiError;\n } catch {\n // Response body is not JSON\n }\n\n throw new KookeeApiError(\n errorData?.code ?? 'UNKNOWN_ERROR',\n errorData?.message ?? `Request failed with status ${response.status}`,\n response.status\n );\n }\n\n return response.json() as Promise<T>;\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n Announcement,\n AnnouncementListItem,\n AnnouncementOrderBy,\n AnnouncementType,\n LocaleOptions,\n OrderDirection,\n PaginatedResponse,\n PaginationParams,\n} from '../types';\n\nexport interface AnnouncementListParams extends PaginationParams, LocaleOptions {\n type?: AnnouncementType;\n excludeIds?: string[];\n orderBy?: AnnouncementOrderBy;\n order?: OrderDirection;\n}\n\nexport interface AnnouncementGetByIdParams extends LocaleOptions {}\n\nexport class AnnouncementModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: AnnouncementListParams): Promise<PaginatedResponse<AnnouncementListItem>> {\n const { excludeIds, ...rest } = params ?? {};\n const queryParams = excludeIds?.length ? { ...rest, excludeIds: excludeIds.join(',') } : rest;\n return this.http.get<PaginatedResponse<AnnouncementListItem>>('/v1/announcements', queryParams);\n }\n\n async getById(id: string, params?: AnnouncementGetByIdParams): Promise<Announcement> {\n return this.http.get<Announcement>(`/v1/announcements/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(id: string): Promise<Record<string, Announcement>> {\n return this.http.get<Record<string, Announcement>>(\n `/v1/announcements/${encodeURIComponent(id)}/translations`\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n BlogPost,\n BlogPostListItem,\n BlogTagWithCount,\n LocaleOptions,\n PaginatedResponse,\n PaginationParams,\n ReactParams,\n ReactResponse,\n} from '../types';\n\nexport interface BlogListParams extends PaginationParams, LocaleOptions {\n tags?: string[];\n search?: string;\n}\n\nexport interface BlogGetBySlugParams extends LocaleOptions {}\n\nexport interface BlogGetByIdParams extends LocaleOptions {}\n\nexport class BlogModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: BlogListParams): Promise<PaginatedResponse<BlogPostListItem>> {\n return this.http.get<PaginatedResponse<BlogPostListItem>>('/v1/blog/posts', params);\n }\n\n async getBySlug(slug: string, params?: BlogGetBySlugParams): Promise<BlogPost> {\n return this.http.get<BlogPost>(`/v1/blog/posts/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: BlogGetByIdParams): Promise<BlogPost> {\n return this.http.get<BlogPost>(`/v1/blog/posts/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTags(): Promise<BlogTagWithCount[]> {\n return this.http.get<BlogTagWithCount[]>('/v1/blog/tags');\n }\n\n async getTranslationsById(postId: string): Promise<Record<string, BlogPost>> {\n return this.http.get<Record<string, BlogPost>>(\n `/v1/blog/posts/by-id/${encodeURIComponent(postId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, BlogPost>> {\n return this.http.get<Record<string, BlogPost>>(\n `/v1/blog/posts/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async react(postId: string, params: ReactParams): Promise<ReactResponse> {\n return this.http.post<ReactResponse>(\n `/v1/blog/posts/${encodeURIComponent(postId)}/reactions`,\n params\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n ChangelogEntry,\n ChangelogEntryListItem,\n ChangelogOrderBy,\n LocaleOptions,\n OrderDirection,\n PaginatedResponse,\n PaginationParams,\n ReactParams,\n ReactResponse,\n} from '../types';\n\nexport interface ChangelogListParams extends PaginationParams, LocaleOptions {\n type?: string;\n search?: string;\n orderBy?: ChangelogOrderBy;\n order?: OrderDirection;\n}\n\nexport interface ChangelogGetBySlugParams extends LocaleOptions {}\n\nexport interface ChangelogGetByIdParams extends LocaleOptions {}\n\nexport class ChangelogModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: ChangelogListParams): Promise<PaginatedResponse<ChangelogEntryListItem>> {\n return this.http.get<PaginatedResponse<ChangelogEntryListItem>>('/v1/changelog', params);\n }\n\n async getBySlug(slug: string, params?: ChangelogGetBySlugParams): Promise<ChangelogEntry> {\n return this.http.get<ChangelogEntry>(`/v1/changelog/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: ChangelogGetByIdParams): Promise<ChangelogEntry> {\n return this.http.get<ChangelogEntry>(`/v1/changelog/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(id: string): Promise<Record<string, ChangelogEntry>> {\n return this.http.get<Record<string, ChangelogEntry>>(\n `/v1/changelog/by-id/${encodeURIComponent(id)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, ChangelogEntry>> {\n return this.http.get<Record<string, ChangelogEntry>>(\n `/v1/changelog/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async react(changelogId: string, params: ReactParams): Promise<ReactResponse> {\n return this.http.post<ReactResponse>(\n `/v1/changelog/${encodeURIComponent(changelogId)}/reactions`,\n params\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type { PublicConfig } from '../types';\n\nexport interface ConfigListParams {\n keys?: string[];\n}\n\nexport class ConfigModule {\n constructor(private readonly http: HttpClient) {}\n\n async getByKey(key: string): Promise<PublicConfig> {\n return this.http.get<PublicConfig>(`/v1/config/${encodeURIComponent(key)}`);\n }\n\n async list(params?: ConfigListParams): Promise<PublicConfig[]> {\n return this.http.get<PublicConfig[]>('/v1/config', params);\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n FeedbackPost,\n FeedbackPostCategory,\n FeedbackPostListItem,\n FeedbackPostStatus,\n FeedbackSortOption,\n FeedbackTopContributor,\n FeedbackVoteResponse,\n PaginatedResponse,\n PaginationParams,\n} from '../types';\n\nexport interface FeedbackListParams extends PaginationParams {\n status?: FeedbackPostStatus;\n category?: FeedbackPostCategory;\n search?: string;\n sort?: FeedbackSortOption;\n}\n\nexport interface FeedbackVoteParams {\n action: 'upvote' | 'downvote';\n}\n\nexport interface FeedbackTopContributorsParams {\n limit?: number;\n}\n\nexport class FeedbackModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: FeedbackListParams): Promise<PaginatedResponse<FeedbackPostListItem>> {\n return this.http.get<PaginatedResponse<FeedbackPostListItem>>('/v1/feedback', params);\n }\n\n async getById(id: string): Promise<FeedbackPost> {\n return this.http.get<FeedbackPost>(`/v1/feedback/by-id/${encodeURIComponent(id)}`);\n }\n\n async vote(postId: string, params: FeedbackVoteParams): Promise<FeedbackVoteResponse> {\n return this.http.post<FeedbackVoteResponse>(\n `/v1/feedback/${encodeURIComponent(postId)}/vote`,\n params\n );\n }\n\n async getTopContributors(params?: FeedbackTopContributorsParams): Promise<FeedbackTopContributor[]> {\n return this.http.get<FeedbackTopContributor[]>('/v1/feedback/top-contributors', params);\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n HelpArticle,\n HelpArticleListItem,\n HelpCategory,\n HelpChatParams,\n HelpChatResponse,\n HelpChatStreamChunk,\n HelpSearchResult,\n LocaleOptions,\n PaginatedResponse,\n PaginationParams,\n VoteUsefulnessResponse,\n} from '../types';\n\nexport interface HelpCategoriesParams extends LocaleOptions {}\n\nexport interface HelpListParams extends PaginationParams, LocaleOptions {\n category?: string;\n search?: string;\n}\n\nexport interface HelpSearchParams extends LocaleOptions {\n query: string;\n limit?: number;\n}\n\nexport interface HelpGetBySlugParams extends LocaleOptions {}\n\nexport interface HelpGetByIdParams extends LocaleOptions {}\n\nexport class HelpModule {\n constructor(private readonly http: HttpClient) {}\n\n async categories(params?: HelpCategoriesParams): Promise<HelpCategory[]> {\n return this.http.get<HelpCategory[]>('/v1/help/categories', params);\n }\n\n async list(params?: HelpListParams): Promise<PaginatedResponse<HelpArticleListItem>> {\n return this.http.get<PaginatedResponse<HelpArticleListItem>>('/v1/help/articles', params);\n }\n\n async getBySlug(slug: string, params?: HelpGetBySlugParams): Promise<HelpArticle> {\n return this.http.get<HelpArticle>(`/v1/help/articles/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: HelpGetByIdParams): Promise<HelpArticle> {\n return this.http.get<HelpArticle>(`/v1/help/articles/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async search(params: HelpSearchParams): Promise<HelpSearchResult[]> {\n return this.http.get<HelpSearchResult[]>('/v1/help/search', params);\n }\n\n async getTranslationsById(articleId: string): Promise<Record<string, HelpArticle>> {\n return this.http.get<Record<string, HelpArticle>>(\n `/v1/help/articles/by-id/${encodeURIComponent(articleId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, HelpArticle>> {\n return this.http.get<Record<string, HelpArticle>>(\n `/v1/help/articles/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async chat(params: HelpChatParams): Promise<HelpChatResponse> {\n return this.http.post<HelpChatResponse>('/v1/help/chat', params);\n }\n\n chatStream(params: HelpChatParams): AsyncIterable<HelpChatStreamChunk> {\n return this.http.streamPost<HelpChatStreamChunk>('/v1/help/chat/stream', params);\n }\n\n async voteUsefulness(\n articleId: string,\n vote: 'yes' | 'no' | null,\n previousVote?: 'yes' | 'no' | null,\n ): Promise<VoteUsefulnessResponse> {\n return this.http.post<VoteUsefulnessResponse>(\n `/v1/help/articles/by-id/${encodeURIComponent(articleId)}/vote-usefulness`,\n { vote, previousVote }\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type { LocaleOptions, Page, PageListItem, PaginatedResponse, PaginationParams } from '../types';\n\nexport interface PagesListParams extends PaginationParams, LocaleOptions {\n search?: string;\n}\n\nexport interface PagesGetBySlugParams extends LocaleOptions {}\n\nexport interface PagesGetByIdParams extends LocaleOptions {}\n\nexport class PagesModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: PagesListParams): Promise<PaginatedResponse<PageListItem>> {\n return this.http.get<PaginatedResponse<PageListItem>>('/v1/pages', params);\n }\n\n async getBySlug(slug: string, params?: PagesGetBySlugParams): Promise<Page> {\n return this.http.get<Page>(`/v1/pages/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: PagesGetByIdParams): Promise<Page> {\n return this.http.get<Page>(`/v1/pages/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(pageId: string): Promise<Record<string, Page>> {\n return this.http.get<Record<string, Page>>(\n `/v1/pages/by-id/${encodeURIComponent(pageId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, Page>> {\n return this.http.get<Record<string, Page>>(\n `/v1/pages/${encodeURIComponent(slug)}/translations`\n );\n }\n}\n","import { HttpClient } from './http-client';\nimport { AnnouncementModule } from './modules/announcement';\nimport { BlogModule } from './modules/blog';\nimport { ChangelogModule } from './modules/changelog';\nimport { ConfigModule } from './modules/config';\nimport { FeedbackModule } from './modules/feedback';\nimport { HelpModule } from './modules/help';\nimport { PagesModule } from './modules/pages';\nimport type { KookeeConfig, HealthCheckResponse } from './types';\n\nexport class Kookee {\n private readonly http: HttpClient;\n\n public readonly announcements: AnnouncementModule;\n public readonly blog: BlogModule;\n public readonly changelog: ChangelogModule;\n public readonly config: ConfigModule;\n public readonly feedback: FeedbackModule;\n public readonly help: HelpModule;\n public readonly pages: PagesModule;\n\n constructor(config: KookeeConfig) {\n if (!config.apiKey && !config.projectId) {\n throw new Error('Either apiKey or projectId is required');\n }\n\n this.http = new HttpClient({ apiKey: config.apiKey, projectId: config.projectId, baseUrl: config.baseUrl });\n\n this.announcements = new AnnouncementModule(this.http);\n this.blog = new BlogModule(this.http);\n this.changelog = new ChangelogModule(this.http);\n this.config = new ConfigModule(this.http);\n this.feedback = new FeedbackModule(this.http);\n this.help = new HelpModule(this.http);\n this.pages = new PagesModule(this.http);\n }\n\n async health(): Promise<HealthCheckResponse> {\n return this.http.get<HealthCheckResponse>('/v1/health');\n }\n}\n"]}
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/lib/http-client.ts","../src/lib/modules/announcement.ts","../src/lib/modules/blog.ts","../src/lib/modules/changelog.ts","../src/lib/modules/config.ts","../src/lib/modules/feedback.ts","../src/lib/modules/help.ts","../src/lib/modules/pages.ts","../src/lib/client.ts"],"names":["DEFAULT_BASE_URL","API_KEY_HEADER","PROJECT_ID_HEADER","KookeeApiError","_KookeeApiError","code","message","status","HttpClient","options","headers","path","params","url","key","value","item","response","body","errorData","reader","decoder","buffer","done","lines","line","trimmed","data","AnnouncementModule","http","excludeIds","rest","queryParams","id","BlogModule","slug","postId","ChangelogModule","changelogId","ConfigModule","FeedbackModule","HelpModule","articleId","vote","previousVote","PagesModule","pageId","Kookee","config"],"mappings":"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","file":"index.js","sourcesContent":["import type { ApiError } from './types';\n\nconst DEFAULT_BASE_URL = 'https://api.kookee.dev';\nconst API_KEY_HEADER = 'Kookee-API-Key';\nconst PROJECT_ID_HEADER = 'Kookee-Project-Id';\n\nexport class KookeeApiError extends Error {\n constructor(\n public readonly code: string,\n message: string,\n public readonly status: number\n ) {\n super(message);\n this.name = 'KookeeApiError';\n Object.setPrototypeOf(this, KookeeApiError.prototype);\n }\n}\n\nexport class HttpClient {\n private readonly baseUrl: string;\n private readonly apiKey?: string;\n private readonly projectId?: string;\n\n constructor(options: { apiKey?: string; projectId?: string; baseUrl?: string }) {\n this.apiKey = options.apiKey;\n this.projectId = options.projectId;\n this.baseUrl = options.baseUrl ?? DEFAULT_BASE_URL;\n }\n\n private getHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n 'Content-Type': 'application/json',\n };\n if (this.apiKey) {\n headers[API_KEY_HEADER] = this.apiKey;\n }\n if (this.projectId) {\n headers[PROJECT_ID_HEADER] = this.projectId;\n }\n return headers;\n }\n\n async get<T>(path: string, params?: object): Promise<T> {\n const url = new URL(`${this.baseUrl}${path}`);\n\n if (params) {\n for (const [key, value] of Object.entries(params)) {\n if (value !== undefined && value !== null) {\n if (Array.isArray(value)) {\n for (const item of value) {\n url.searchParams.append(key, String(item));\n }\n } else {\n url.searchParams.set(key, String(value));\n }\n }\n }\n }\n\n const response = await fetch(url.toString(), {\n method: 'GET',\n headers: this.getHeaders(),\n });\n\n return this.handleResponse<T>(response);\n }\n\n async post<T>(path: string, body?: unknown): Promise<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: this.getHeaders(),\n body: body ? JSON.stringify(body) : undefined,\n });\n\n return this.handleResponse<T>(response);\n }\n\n async *streamPost<T>(path: string, body?: unknown): AsyncIterable<T> {\n const response = await fetch(`${this.baseUrl}${path}`, {\n method: 'POST',\n headers: {\n ...this.getHeaders(),\n Accept: 'text/event-stream',\n },\n body: body ? JSON.stringify(body) : undefined,\n });\n\n if (!response.ok) {\n let errorData: ApiError | null = null;\n try {\n errorData = (await response.json()) as ApiError;\n } catch {\n // Response body is not JSON\n }\n throw new KookeeApiError(\n errorData?.code ?? 'UNKNOWN_ERROR',\n errorData?.message ?? `Request failed with status ${response.status}`,\n response.status\n );\n }\n\n if (!response.body) {\n return;\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n let buffer = '';\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split('\\n');\n buffer = lines.pop() ?? '';\n\n for (const line of lines) {\n const trimmed = line.trim();\n if (!trimmed || trimmed.startsWith(':')) continue;\n if (trimmed.startsWith('data: ')) {\n const data = trimmed.slice(6);\n if (data === '[DONE]') return;\n yield JSON.parse(data) as T;\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n }\n\n private async handleResponse<T>(response: Response): Promise<T> {\n if (!response.ok) {\n let errorData: ApiError | null = null;\n\n try {\n errorData = (await response.json()) as ApiError;\n } catch {\n // Response body is not JSON\n }\n\n throw new KookeeApiError(\n errorData?.code ?? 'UNKNOWN_ERROR',\n errorData?.message ?? `Request failed with status ${response.status}`,\n response.status\n );\n }\n\n return response.json() as Promise<T>;\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n Announcement,\n AnnouncementListItem,\n AnnouncementOrderBy,\n AnnouncementType,\n LocaleOptions,\n OrderDirection,\n PaginatedResponse,\n PaginationParams,\n} from '../types';\n\nexport interface AnnouncementListParams extends PaginationParams, LocaleOptions {\n type?: AnnouncementType;\n excludeIds?: string[];\n orderBy?: AnnouncementOrderBy;\n order?: OrderDirection;\n}\n\nexport interface AnnouncementGetByIdParams extends LocaleOptions {}\n\nexport class AnnouncementModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: AnnouncementListParams): Promise<PaginatedResponse<AnnouncementListItem>> {\n const { excludeIds, ...rest } = params ?? {};\n const queryParams = excludeIds?.length ? { ...rest, excludeIds: excludeIds.join(',') } : rest;\n return this.http.get<PaginatedResponse<AnnouncementListItem>>('/v1/announcements', queryParams);\n }\n\n async getById(id: string, params?: AnnouncementGetByIdParams): Promise<Announcement> {\n return this.http.get<Announcement>(`/v1/announcements/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(id: string): Promise<Record<string, Announcement>> {\n return this.http.get<Record<string, Announcement>>(\n `/v1/announcements/${encodeURIComponent(id)}/translations`\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n BlogPost,\n BlogPostListItem,\n BlogTagWithCount,\n LocaleOptions,\n PaginatedResponse,\n PaginationParams,\n ReactParams,\n ReactResponse,\n} from '../types';\n\nexport interface BlogListParams extends PaginationParams, LocaleOptions {\n tags?: string[];\n search?: string;\n}\n\nexport interface BlogGetBySlugParams extends LocaleOptions {}\n\nexport interface BlogGetByIdParams extends LocaleOptions {}\n\nexport class BlogModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: BlogListParams): Promise<PaginatedResponse<BlogPostListItem>> {\n return this.http.get<PaginatedResponse<BlogPostListItem>>('/v1/blog/posts', params);\n }\n\n async getBySlug(slug: string, params?: BlogGetBySlugParams): Promise<BlogPost> {\n return this.http.get<BlogPost>(`/v1/blog/posts/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: BlogGetByIdParams): Promise<BlogPost> {\n return this.http.get<BlogPost>(`/v1/blog/posts/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTags(): Promise<BlogTagWithCount[]> {\n return this.http.get<BlogTagWithCount[]>('/v1/blog/tags');\n }\n\n async getTranslationsById(postId: string): Promise<Record<string, BlogPost>> {\n return this.http.get<Record<string, BlogPost>>(\n `/v1/blog/posts/by-id/${encodeURIComponent(postId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, BlogPost>> {\n return this.http.get<Record<string, BlogPost>>(\n `/v1/blog/posts/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async react(postId: string, params: ReactParams): Promise<ReactResponse> {\n return this.http.post<ReactResponse>(\n `/v1/blog/posts/${encodeURIComponent(postId)}/reactions`,\n params\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n ChangelogEntry,\n ChangelogEntryListItem,\n ChangelogOrderBy,\n LocaleOptions,\n OrderDirection,\n PaginatedResponse,\n PaginationParams,\n ReactParams,\n ReactResponse,\n} from '../types';\n\nexport interface ChangelogListParams extends PaginationParams, LocaleOptions {\n type?: string;\n search?: string;\n orderBy?: ChangelogOrderBy;\n order?: OrderDirection;\n}\n\nexport interface ChangelogGetBySlugParams extends LocaleOptions {}\n\nexport interface ChangelogGetByIdParams extends LocaleOptions {}\n\nexport class ChangelogModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: ChangelogListParams): Promise<PaginatedResponse<ChangelogEntryListItem>> {\n return this.http.get<PaginatedResponse<ChangelogEntryListItem>>('/v1/changelog', params);\n }\n\n async getBySlug(slug: string, params?: ChangelogGetBySlugParams): Promise<ChangelogEntry> {\n return this.http.get<ChangelogEntry>(`/v1/changelog/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: ChangelogGetByIdParams): Promise<ChangelogEntry> {\n return this.http.get<ChangelogEntry>(`/v1/changelog/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(id: string): Promise<Record<string, ChangelogEntry>> {\n return this.http.get<Record<string, ChangelogEntry>>(\n `/v1/changelog/by-id/${encodeURIComponent(id)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, ChangelogEntry>> {\n return this.http.get<Record<string, ChangelogEntry>>(\n `/v1/changelog/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async react(changelogId: string, params: ReactParams): Promise<ReactResponse> {\n return this.http.post<ReactResponse>(\n `/v1/changelog/${encodeURIComponent(changelogId)}/reactions`,\n params\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type { PublicConfig } from '../types';\n\nexport interface ConfigListParams {\n keys?: string[];\n}\n\nexport class ConfigModule {\n constructor(private readonly http: HttpClient) {}\n\n async getByKey(key: string): Promise<PublicConfig> {\n return this.http.get<PublicConfig>(`/v1/config/${encodeURIComponent(key)}`);\n }\n\n async list(params?: ConfigListParams): Promise<PublicConfig[]> {\n return this.http.get<PublicConfig[]>('/v1/config', params);\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n FeedbackPost,\n FeedbackPostCategory,\n FeedbackPostListItem,\n FeedbackPostStatus,\n FeedbackSortOption,\n FeedbackTopContributor,\n FeedbackVoteResponse,\n PaginatedResponse,\n PaginationParams,\n} from '../types';\n\nexport interface FeedbackListParams extends PaginationParams {\n status?: FeedbackPostStatus;\n category?: FeedbackPostCategory;\n search?: string;\n sort?: FeedbackSortOption;\n}\n\nexport interface FeedbackVoteParams {\n action: 'upvote' | 'downvote';\n}\n\nexport interface FeedbackTopContributorsParams {\n limit?: number;\n}\n\nexport class FeedbackModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: FeedbackListParams): Promise<PaginatedResponse<FeedbackPostListItem>> {\n return this.http.get<PaginatedResponse<FeedbackPostListItem>>('/v1/feedback', params);\n }\n\n async getById(id: string): Promise<FeedbackPost> {\n return this.http.get<FeedbackPost>(`/v1/feedback/by-id/${encodeURIComponent(id)}`);\n }\n\n async vote(postId: string, params: FeedbackVoteParams): Promise<FeedbackVoteResponse> {\n return this.http.post<FeedbackVoteResponse>(\n `/v1/feedback/${encodeURIComponent(postId)}/vote`,\n params\n );\n }\n\n async getTopContributors(params?: FeedbackTopContributorsParams): Promise<FeedbackTopContributor[]> {\n return this.http.get<FeedbackTopContributor[]>('/v1/feedback/top-contributors', params);\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type {\n HelpArticle,\n HelpArticleListItem,\n HelpCategory,\n HelpChatParams,\n HelpChatResponse,\n HelpChatStreamChunk,\n HelpSearchResult,\n LocaleOptions,\n PaginatedResponse,\n PaginationParams,\n VoteUsefulnessResponse,\n} from '../types';\n\nexport interface HelpCategoriesParams extends LocaleOptions {}\n\nexport interface HelpListParams extends PaginationParams, LocaleOptions {\n category?: string;\n search?: string;\n}\n\nexport interface HelpSearchParams extends LocaleOptions {\n query: string;\n limit?: number;\n}\n\nexport interface HelpGetBySlugParams extends LocaleOptions {}\n\nexport interface HelpGetByIdParams extends LocaleOptions {}\n\nexport class HelpModule {\n constructor(private readonly http: HttpClient) {}\n\n async categories(params?: HelpCategoriesParams): Promise<HelpCategory[]> {\n return this.http.get<HelpCategory[]>('/v1/help/categories', params);\n }\n\n async list(params?: HelpListParams): Promise<PaginatedResponse<HelpArticleListItem>> {\n return this.http.get<PaginatedResponse<HelpArticleListItem>>('/v1/help/articles', params);\n }\n\n async getBySlug(slug: string, params?: HelpGetBySlugParams): Promise<HelpArticle> {\n return this.http.get<HelpArticle>(`/v1/help/articles/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: HelpGetByIdParams): Promise<HelpArticle> {\n return this.http.get<HelpArticle>(`/v1/help/articles/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async search(params: HelpSearchParams): Promise<HelpSearchResult[]> {\n return this.http.get<HelpSearchResult[]>('/v1/help/search', params);\n }\n\n async getTranslationsById(articleId: string): Promise<Record<string, HelpArticle>> {\n return this.http.get<Record<string, HelpArticle>>(\n `/v1/help/articles/by-id/${encodeURIComponent(articleId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, HelpArticle>> {\n return this.http.get<Record<string, HelpArticle>>(\n `/v1/help/articles/${encodeURIComponent(slug)}/translations`\n );\n }\n\n async chat(params: HelpChatParams): Promise<HelpChatResponse> {\n return this.http.post<HelpChatResponse>('/v1/help/chat', params);\n }\n\n chatStream(params: HelpChatParams): AsyncIterable<HelpChatStreamChunk> {\n return this.http.streamPost<HelpChatStreamChunk>('/v1/help/chat/stream', params);\n }\n\n async voteUsefulness(\n articleId: string,\n vote: 'yes' | 'no' | null,\n previousVote?: 'yes' | 'no' | null,\n ): Promise<VoteUsefulnessResponse> {\n return this.http.post<VoteUsefulnessResponse>(\n `/v1/help/articles/by-id/${encodeURIComponent(articleId)}/vote-usefulness`,\n { vote, previousVote }\n );\n }\n}\n","import type { HttpClient } from '../http-client';\nimport type { LocaleOptions, Page, PageListItem, PaginatedResponse, PaginationParams } from '../types';\n\nexport interface PagesListParams extends PaginationParams, LocaleOptions {\n search?: string;\n}\n\nexport interface PagesGetBySlugParams extends LocaleOptions {}\n\nexport interface PagesGetByIdParams extends LocaleOptions {}\n\nexport class PagesModule {\n constructor(private readonly http: HttpClient) {}\n\n async list(params?: PagesListParams): Promise<PaginatedResponse<PageListItem>> {\n return this.http.get<PaginatedResponse<PageListItem>>('/v1/pages', params);\n }\n\n async getBySlug(slug: string, params?: PagesGetBySlugParams): Promise<Page> {\n return this.http.get<Page>(`/v1/pages/${encodeURIComponent(slug)}`, params);\n }\n\n async getById(id: string, params?: PagesGetByIdParams): Promise<Page> {\n return this.http.get<Page>(`/v1/pages/by-id/${encodeURIComponent(id)}`, params);\n }\n\n async getTranslationsById(pageId: string): Promise<Record<string, Page>> {\n return this.http.get<Record<string, Page>>(\n `/v1/pages/by-id/${encodeURIComponent(pageId)}/translations`\n );\n }\n\n async getTranslationsBySlug(slug: string): Promise<Record<string, Page>> {\n return this.http.get<Record<string, Page>>(\n `/v1/pages/${encodeURIComponent(slug)}/translations`\n );\n }\n}\n","import { HttpClient } from './http-client';\nimport { AnnouncementModule } from './modules/announcement';\nimport { BlogModule } from './modules/blog';\nimport { ChangelogModule } from './modules/changelog';\nimport { ConfigModule } from './modules/config';\nimport { FeedbackModule } from './modules/feedback';\nimport { HelpModule } from './modules/help';\nimport { PagesModule } from './modules/pages';\nimport type { KookeeConfig, HealthCheckResponse } from './types';\n\nexport class Kookee {\n private readonly http: HttpClient;\n\n public readonly announcements: AnnouncementModule;\n public readonly blog: BlogModule;\n public readonly changelog: ChangelogModule;\n public readonly config: ConfigModule;\n public readonly feedback: FeedbackModule;\n public readonly help: HelpModule;\n public readonly pages: PagesModule;\n\n constructor(config: KookeeConfig) {\n if (!config.apiKey && !config.projectId) {\n throw new Error('Either apiKey or projectId is required');\n }\n\n this.http = new HttpClient({ apiKey: config.apiKey, projectId: config.projectId, baseUrl: config.baseUrl });\n\n this.announcements = new AnnouncementModule(this.http);\n this.blog = new BlogModule(this.http);\n this.changelog = new ChangelogModule(this.http);\n this.config = new ConfigModule(this.http);\n this.feedback = new FeedbackModule(this.http);\n this.help = new HelpModule(this.http);\n this.pages = new PagesModule(this.http);\n }\n\n async health(): Promise<HealthCheckResponse> {\n return this.http.get<HealthCheckResponse>('/v1/health');\n }\n}\n"]}