UNPKG

openai

Version:

The official TypeScript library for the OpenAI API

65 lines (54 loc) 2.07 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { OpenAIError } from '../../core/error'; import { encodeUTF8 } from './bytes'; export const toBase64 = (data: string | Uint8Array | null | undefined): string => { if (!data) return ''; if (typeof (globalThis as any).Buffer !== 'undefined') { return (globalThis as any).Buffer.from(data).toString('base64'); } if (typeof data === 'string') { data = encodeUTF8(data); } if (typeof btoa !== 'undefined') { return btoa(String.fromCharCode.apply(null, data as any)); } throw new OpenAIError('Cannot generate base64 string; Expected `Buffer` or `btoa` to be defined'); }; export const fromBase64 = (str: string): Uint8Array => { if (typeof (globalThis as any).Buffer !== 'undefined') { const buf = (globalThis as any).Buffer.from(str, 'base64'); return new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength); } if (typeof atob !== 'undefined') { const bstr = atob(str); const buf = new Uint8Array(bstr.length); for (let i = 0; i < bstr.length; i++) { buf[i] = bstr.charCodeAt(i); } return buf; } throw new OpenAIError('Cannot decode base64 string; Expected `Buffer` or `atob` to be defined'); }; /** * Converts a Base64 encoded string to a Float32Array. * @param base64Str - The Base64 encoded string. * @returns An Array of numbers interpreted as Float32 values. */ export const toFloat32Array = (base64Str: string): Array<number> => { if (typeof Buffer !== 'undefined') { // for Node.js environment const buf = Buffer.from(base64Str, 'base64'); return Array.from( new Float32Array(buf.buffer, buf.byteOffset, buf.length / Float32Array.BYTES_PER_ELEMENT), ); } else { // for legacy web platform APIs const binaryStr = atob(base64Str); const len = binaryStr.length; const bytes = new Uint8Array(len); for (let i = 0; i < len; i++) { bytes[i] = binaryStr.charCodeAt(i); } return Array.from(new Float32Array(bytes.buffer)); } };