mirror of
https://github.com/geoffsee/open-gsio.git
synced 2025-09-08 22:56:46 +00:00

Update README deployment steps and add deploy:secrets script to package.json update local inference script and README update lockfile reconfigure package scripts for development update test execution pass server tests Update README with revised Bun commands and workspace details remove pnpm package manager designator create bun server
97 lines
2.4 KiB
TypeScript
97 lines
2.4 KiB
TypeScript
export class Utils {
|
|
static getSeason(date: string): string {
|
|
const hemispheres = {
|
|
Northern: ["Winter", "Spring", "Summer", "Autumn"],
|
|
Southern: ["Summer", "Autumn", "Winter", "Spring"],
|
|
};
|
|
const d = new Date(date);
|
|
const month = d.getMonth();
|
|
const day = d.getDate();
|
|
const hemisphere = "Northern";
|
|
|
|
if (month < 2 || (month === 2 && day <= 20) || month === 11)
|
|
return hemispheres[hemisphere][0];
|
|
if (month < 5 || (month === 5 && day <= 21))
|
|
return hemispheres[hemisphere][1];
|
|
if (month < 8 || (month === 8 && day <= 22))
|
|
return hemispheres[hemisphere][2];
|
|
return hemispheres[hemisphere][3];
|
|
}
|
|
static getTimezone(timezone) {
|
|
if (timezone) {
|
|
return timezone;
|
|
}
|
|
return Intl.DateTimeFormat().resolvedOptions().timeZone;
|
|
}
|
|
|
|
static getCurrentDate() {
|
|
return new Date().toISOString();
|
|
}
|
|
|
|
static isAssetUrl(url) {
|
|
const { pathname } = new URL(url);
|
|
return pathname.startsWith("/assets/");
|
|
}
|
|
|
|
static selectEquitably({ a, b, c, d }, itemCount = 9) {
|
|
const sources = [a, b, c, d];
|
|
const result = {};
|
|
|
|
let combinedItems = [];
|
|
sources.forEach((source, index) => {
|
|
combinedItems.push(
|
|
...Object.keys(source).map((key) => ({ source: index, key })),
|
|
);
|
|
});
|
|
|
|
combinedItems = combinedItems.sort(() => Math.random() - 0.5);
|
|
|
|
let selectedCount = 0;
|
|
while (selectedCount < itemCount && combinedItems.length > 0) {
|
|
const { source, key } = combinedItems.shift();
|
|
const sourceObject = sources[source];
|
|
|
|
if (!result[key]) {
|
|
result[key] = sourceObject[key];
|
|
selectedCount++;
|
|
}
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
static normalizeWithBlanks<T extends Normalize.ChatMessage>(msgs: T[]): T[] {
|
|
const out: T[] = [];
|
|
|
|
// In local mode first turn expected to be user.
|
|
let expected: Normalize.Role = "user";
|
|
|
|
for (const m of msgs) {
|
|
while (m.role !== expected) {
|
|
// Insert blanks to match expected sequence user/assistant/user...
|
|
out.push(Normalize.makeBlank(expected) as T);
|
|
expected = expected === "user" ? "assistant" : "user";
|
|
}
|
|
|
|
out.push(m);
|
|
expected = expected === "user" ? "assistant" : "user";
|
|
}
|
|
|
|
return out;
|
|
}
|
|
|
|
}
|
|
|
|
module Normalize {
|
|
export type Role = "user" | "assistant";
|
|
|
|
export interface ChatMessage extends Record<any, any> {
|
|
role: Role;
|
|
}
|
|
|
|
export const makeBlank = (role: Role): ChatMessage => ({
|
|
role,
|
|
content: ""
|
|
});
|
|
}
|