Skip to content

Commit

Permalink
Merge pull request #109 from Mintplex-Labs/chroma-header-pt2
Browse files Browse the repository at this point in the history
normalize header requests Chroma
  • Loading branch information
timothycarambat committed Dec 31, 2023
2 parents d4c2b8e + 5f29de9 commit e7659c9
Showing 1 changed file with 30 additions and 19 deletions.
49 changes: 30 additions & 19 deletions backend/utils/vectordatabases/providers/chroma/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,34 @@ class Chroma {
this.config = this.setConfig(connector);
}

// For use with ChromaClient SDK only.
#appendClientAuthHeaders() {
const { settings } = this.config
if (!settings?.authToken) return {};

const headerName = settings.authTokenHeader || "X-Api-Key";
const authToken = headerName === 'Authorization' ? `Bearer ${settings.authToken}` : settings.authToken
return {
fetchOptions: {
headers: {
[headerName]: authToken,
},
},
}
}

// For use with fetch API endpoints only.
#appendRawAuthHeaders() {
const { settings } = this.config
if (!settings?.authToken) return {};

const headerName = settings.authTokenHeader || "X-Api-Key";
const authToken = headerName === 'Authorization' ? `Bearer ${settings.authToken}` : settings.authToken
return {
[headerName]: authToken,
}
}

setConfig(config) {
var { type, settings } = config;
if (typeof settings === "string") settings = JSON.parse(settings);
Expand All @@ -34,15 +62,7 @@ class Chroma {

const client = new ChromaClient({
path: settings.instanceURL,
...(settings?.authToken
? {
fetchOptions: {
headers: {
[settings.authTokenHeader || "X-Api-Key"]: settings.authToken,
},
},
}
: {}),
...this.#appendClientAuthHeaders(),
});

const isAlive = await client.heartbeat();
Expand Down Expand Up @@ -114,23 +134,14 @@ class Chroma {
}

async rawGet(collectionId, pageSize = 10, offset = 0) {
const { settings } = this.config;
return await fetch(
`${this.config.settings.instanceURL}/api/v1/collections/${collectionId}/get`,
{
method: "POST",
headers: {

accept: "application/json",
"Content-Type": "application/json",
...(settings?.authToken
? {
[settings.authTokenHeader || "X-Api-Key"]:
settings.authTokenHeader === 'Authorization'
? `Bearer ${settings.authToken}` :
settings.authToken,
}
: {}),
...this.#appendRawAuthHeaders(),
},
body: JSON.stringify({
limit: pageSize,
Expand Down

0 comments on commit e7659c9

Please sign in to comment.