fireberry-api-client 1.0.0-beta.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/README.md +441 -0
- package/dist/excludedFields-CGXgZN8Y.d.cts +278 -0
- package/dist/excludedFields-CGXgZN8Y.d.ts +278 -0
- package/dist/fieldTypes-BLzJTzpI.d.cts +67 -0
- package/dist/fieldTypes-BLzJTzpI.d.ts +67 -0
- package/dist/index.cjs +1597 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +871 -0
- package/dist/index.d.ts +871 -0
- package/dist/index.js +1586 -0
- package/dist/index.js.map +1 -0
- package/dist/sdk/index.cjs +1041 -0
- package/dist/sdk/index.cjs.map +1 -0
- package/dist/sdk/index.d.cts +372 -0
- package/dist/sdk/index.d.ts +372 -0
- package/dist/sdk/index.js +1022 -0
- package/dist/sdk/index.js.map +1 -0
- package/dist/utils/index.cjs +796 -0
- package/dist/utils/index.cjs.map +1 -0
- package/dist/utils/index.d.cts +73 -0
- package/dist/utils/index.d.ts +73 -0
- package/dist/utils/index.js +767 -0
- package/dist/utils/index.js.map +1 -0
- package/package.json +61 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/utils/queryBuilder.ts","../../src/utils/fieldMapping.ts","../../src/constants/objectIds.ts","../../src/constants/objectNames.ts","../../src/constants/excludedFields.ts","../../src/constants/fieldTypes.ts","../../src/utils/fieldTypes.ts","../../src/sdk/index.ts"],"names":[],"mappings":"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","file":"index.cjs","sourcesContent":["import type { QueryOperator } from '../types/query';\r\n\r\n/**\r\n * Escapes special characters in query values to prevent query injection.\r\n * This is a security measure to ensure user-provided values cannot modify\r\n * the query structure or inject additional query logic.\r\n *\r\n * @param value - The value to escape\r\n * @returns Escaped value safe for use in Fireberry queries\r\n */\r\nexport function escapeQueryValue(value: string): string {\r\n if (!value) {\r\n return '';\r\n }\r\n // Escape backslashes first to avoid double-escaping\r\n let escaped = value.replace(/\\\\/g, '\\\\\\\\');\r\n // Escape parentheses which could break out of conditions\r\n escaped = escaped.replace(/\\(/g, '\\\\(');\r\n escaped = escaped.replace(/\\)/g, '\\\\)');\r\n // Escape logical operators that could inject additional conditions\r\n // Using word boundaries to only match standalone operators\r\n escaped = escaped.replace(/\\bor\\b/gi, '\\\\or');\r\n escaped = escaped.replace(/\\band\\b/gi, '\\\\and');\r\n return escaped;\r\n}\r\n\r\n/**\r\n * Sanitizes a query string to ensure proper syntax for the Fireberry API\r\n * Handles common syntax issues and removes extraneous elements\r\n *\r\n * @param query - Query string to sanitize\r\n * @returns Sanitized query string\r\n */\r\nexport function sanitizeQuery(query: string): string {\r\n if (!query) {\r\n return '';\r\n }\r\n\r\n // First, protect special operators from being modified\r\n // Temporarily mark is-null and is-not-null operators\r\n query = query.replace(\r\n /\\(\\s*([a-zA-Z0-9_]+)\\s+(is-null|is-not-null)\\s*\\)/g,\r\n '($1 __SPECIAL_OPERATOR__$2)',\r\n );\r\n\r\n // Also protect text operators like start-with, not-start-with\r\n query = query.replace(\r\n /\\(\\s*([a-zA-Z0-9_]+)\\s+(start-with|not-start-with)\\s+([^)]+)\\s*\\)/g,\r\n '($1 __TEXT_OPERATOR__$2 $3)',\r\n );\r\n\r\n // Fix missing operators: (field value) -> (field = value)\r\n query = query.replace(\r\n /\\(\\s*([a-zA-Z0-9_]+(?:field|Field|system|System)[0-9]*)\\s+(?!__SPECIAL_OPERATOR__|__TEXT_OPERATOR__)([^()<>=!]+)\\s*\\)/g,\r\n '($1 = $2)',\r\n );\r\n\r\n // Fix with a more general pattern for any field-value pair without operator\r\n query = query.replace(\r\n /\\(\\s*([a-zA-Z0-9_]+)\\s+(?!__SPECIAL_OPERATOR__|__TEXT_OPERATOR__|<=|>=|!=|<|>|=\\s)([^()<>]+)\\s*\\)/g,\r\n '($1 = $2)',\r\n );\r\n\r\n // Restore special operators\r\n query = query.replace(/__SPECIAL_OPERATOR__/g, '');\r\n query = query.replace(/__TEXT_OPERATOR__/g, '');\r\n\r\n // Remove parentheses containing only a comparison operator\r\n query = query.replace(/\\(\\s*(?:<=|>=|!=|<|>|=)\\s*\\)/g, '');\r\n // Remove parentheses containing only text operators\r\n query = query.replace(/\\(\\s*(?:start-with|not-start-with)\\s*\\)/gi, '');\r\n // Remove parentheses containing only logical operators (AND/OR)\r\n query = query.replace(/\\(\\s*(?:and|or)\\s*\\)/gi, '');\r\n // Remove empty parentheses\r\n query = query.replace(/\\(\\s*\\)/g, '');\r\n // Remove logical operators without operands at start/end\r\n query = query.replace(/^\\s*(and|or)\\s*/gi, '');\r\n query = query.replace(/\\s*(and|or)\\s*$/gi, '');\r\n // Remove redundant nested parentheses: ((x)) -> (x)\r\n const nestedPattern = /\\(\\s*\\(([^()]+)\\)\\s*\\)/g;\r\n while (nestedPattern.test(query)) {\r\n query = query.replace(nestedPattern, '($1)');\r\n }\r\n // Collapse multiple spaces\r\n query = query.replace(/\\s+/g, ' ');\r\n return query.trim();\r\n}\r\n\r\n/**\r\n * Condition builder for fluent query construction\r\n */\r\nexport interface ConditionBuilder {\r\n /** Equals comparison (=) */\r\n equals(value: string | number): QueryBuilder;\r\n /** Not equals comparison (!=) */\r\n notEquals(value: string | number): QueryBuilder;\r\n /** Less than comparison (<) - works with numbers and dates */\r\n lessThan(value: string | number): QueryBuilder;\r\n /** Greater than comparison (>) - works with numbers and dates */\r\n greaterThan(value: string | number): QueryBuilder;\r\n /** Less than or equal (<=) - works with numbers ONLY (not dates!) */\r\n lessThanOrEqual(value: string | number): QueryBuilder;\r\n /** Greater than or equal (>=) - works with numbers ONLY (not dates!) */\r\n greaterThanOrEqual(value: string | number): QueryBuilder;\r\n /** Contains value (translates to start-with %value) */\r\n contains(value: string): QueryBuilder;\r\n /** Does not contain value (translates to not-start-with %value) */\r\n notContains(value: string): QueryBuilder;\r\n /** Starts with value (start-with) */\r\n startsWith(value: string): QueryBuilder;\r\n /** Does not start with value (not-start-with) */\r\n notStartsWith(value: string): QueryBuilder;\r\n /** Field is null (is-null) */\r\n isNull(): QueryBuilder;\r\n /** Field is not null (is-not-null) */\r\n isNotNull(): QueryBuilder;\r\n}\r\n\r\n/**\r\n * Internal representation of a query condition\r\n */\r\ninterface QueryCondition {\r\n field: string;\r\n operator: QueryOperator;\r\n value?: string;\r\n}\r\n\r\n/**\r\n * Fluent query builder for constructing Fireberry queries\r\n *\r\n * @example\r\n * ```typescript\r\n * // Build a query string\r\n * const query = new QueryBuilder()\r\n * .where('statuscode').equals('1')\r\n * .and()\r\n * .where('emailaddress1').contains('@example.com')\r\n * .build();\r\n * // Output: \"(statuscode = 1) and (emailaddress1 start-with %@example.com)\"\r\n *\r\n * // With select and execute (requires client)\r\n * const result = await new QueryBuilder(client)\r\n * .objectType('1')\r\n * .select('accountid', 'name', 'emailaddress1')\r\n * .where('statuscode').equals('1')\r\n * .limit(100)\r\n * .execute();\r\n * ```\r\n */\r\n/**\r\n * Client interface for query execution\r\n */\r\ninterface QueryClient {\r\n query(options: {\r\n objectType: string;\r\n fields: string[];\r\n query: string;\r\n showRealValue: boolean;\r\n sortBy?: string;\r\n sortType?: 'asc' | 'desc';\r\n limit?: number;\r\n page?: number;\r\n signal?: AbortSignal;\r\n }): Promise<QueryResult>;\r\n}\r\n\r\n/**\r\n * Query result type\r\n */\r\ninterface QueryResult {\r\n records: Record<string, unknown>[];\r\n total: number;\r\n success: boolean;\r\n}\r\n\r\nexport class QueryBuilder {\r\n private conditions: QueryCondition[] = [];\r\n private joinOperators: ('and' | 'or')[] = [];\r\n private currentField: string | null = null;\r\n private selectedFields: string[] = [];\r\n private objectTypeId: string | null = null;\r\n private sortByField: string | null = null;\r\n private sortDirection: 'asc' | 'desc' = 'desc';\r\n private limitValue: number | null = null;\r\n private pageNumber: number = 1;\r\n private showRealValueFlag: boolean = true;\r\n private client: QueryClient | null = null;\r\n\r\n /**\r\n * Creates a new QueryBuilder\r\n * @param client - Optional FireberryClient for executing queries\r\n */\r\n constructor(client?: QueryClient) {\r\n this.client = client ?? null;\r\n }\r\n\r\n /**\r\n * Sets the object type for the query\r\n * @param objectType - Object type ID (e.g., '1' for Account)\r\n */\r\n objectType(objectType: string | number): this {\r\n this.objectTypeId = String(objectType);\r\n return this;\r\n }\r\n\r\n /**\r\n * Adds fields to select\r\n * @param fields - Field names to select\r\n */\r\n select(...fields: string[]): this {\r\n this.selectedFields.push(...fields);\r\n return this;\r\n }\r\n\r\n /**\r\n * Starts a new WHERE condition\r\n * @param field - Field name to filter on\r\n */\r\n where(field: string): ConditionBuilder {\r\n this.currentField = field;\r\n return this.createConditionBuilder();\r\n }\r\n\r\n /**\r\n * Adds an AND logical operator\r\n */\r\n and(): this {\r\n if (this.conditions.length > 0) {\r\n this.joinOperators.push('and');\r\n }\r\n return this;\r\n }\r\n\r\n /**\r\n * Adds an OR logical operator\r\n */\r\n or(): this {\r\n if (this.conditions.length > 0) {\r\n this.joinOperators.push('or');\r\n }\r\n return this;\r\n }\r\n\r\n /**\r\n * Sets the sort field and direction\r\n * @param field - Field to sort by\r\n * @param direction - Sort direction ('asc' or 'desc')\r\n */\r\n sortBy(field: string, direction: 'asc' | 'desc' = 'desc'): this {\r\n this.sortByField = field;\r\n this.sortDirection = direction;\r\n return this;\r\n }\r\n\r\n /**\r\n * Sets the maximum number of records to return\r\n * @param count - Maximum record count\r\n */\r\n limit(count: number): this {\r\n this.limitValue = count;\r\n return this;\r\n }\r\n\r\n /**\r\n * Sets the page number for pagination\r\n * @param page - Page number (1-based)\r\n */\r\n page(page: number): this {\r\n this.pageNumber = page;\r\n return this;\r\n }\r\n\r\n /**\r\n * Controls whether to show real values (labels) for dropdown fields\r\n * @param show - Whether to show real values (default: true)\r\n */\r\n showRealValue(show: boolean): this {\r\n this.showRealValueFlag = show;\r\n return this;\r\n }\r\n\r\n /**\r\n * Builds the query string from conditions\r\n * @returns The built query string\r\n */\r\n build(): string {\r\n if (this.conditions.length === 0) {\r\n return '';\r\n }\r\n\r\n const parts: string[] = [];\r\n\r\n for (let i = 0; i < this.conditions.length; i++) {\r\n const condition = this.conditions[i];\r\n let conditionStr: string;\r\n\r\n if (condition.operator === 'is-null' || condition.operator === 'is-not-null') {\r\n conditionStr = `(${condition.field} ${condition.operator})`;\r\n } else {\r\n const escapedValue = escapeQueryValue(condition.value || '');\r\n conditionStr = `(${condition.field} ${condition.operator} ${escapedValue})`;\r\n }\r\n\r\n parts.push(conditionStr);\r\n\r\n // Add join operator if there's a next condition\r\n if (i < this.joinOperators.length) {\r\n parts.push(this.joinOperators[i]);\r\n }\r\n }\r\n\r\n return parts.join(' ');\r\n }\r\n\r\n /**\r\n * Returns the selected fields array\r\n * Useful for inspecting the query configuration\r\n */\r\n getFields(): string[] {\r\n return [...this.selectedFields];\r\n }\r\n\r\n /**\r\n * Converts the query builder state to a payload compatible with @fireberry/sdk\r\n *\r\n * @returns Object with `fields` (comma-separated string) and `query` (filter string)\r\n *\r\n * @example\r\n * ```typescript\r\n * import FireberryClientSDK from '@fireberry/sdk/client';\r\n * import { QueryBuilder } from 'fireberry-api-client';\r\n *\r\n * const sdk = new FireberryClientSDK();\r\n * await sdk.initializeContext();\r\n *\r\n * const payload = new QueryBuilder()\r\n * .select('accountid', 'accountname')\r\n * .where('statuscode').equals('1')\r\n * .toSDKPayload();\r\n *\r\n * // Use with SDK\r\n * const results = await sdk.api.query(1, payload);\r\n * ```\r\n */\r\n toSDKPayload(): { fields: string; query: string; page_size?: number; page_number?: number } {\r\n const payload: { fields: string; query: string; page_size?: number; page_number?: number } = {\r\n fields: this.selectedFields.length > 0 ? this.selectedFields.join(',') : '*',\r\n query: this.build(),\r\n };\r\n\r\n if (this.limitValue !== null) {\r\n payload.page_size = this.limitValue;\r\n }\r\n\r\n if (this.pageNumber > 1) {\r\n payload.page_number = this.pageNumber;\r\n }\r\n\r\n return payload;\r\n }\r\n\r\n /**\r\n * Executes the query (requires client to be set)\r\n * @param signal - Optional AbortSignal for cancellation\r\n * @returns Query results\r\n */\r\n async execute(signal?: AbortSignal): Promise<QueryResult> {\r\n if (!this.client) {\r\n throw new Error('QueryBuilder requires a client to execute queries. Pass a FireberryClient to the constructor.');\r\n }\r\n\r\n if (!this.objectTypeId) {\r\n throw new Error('Object type is required. Use .objectType() before executing.');\r\n }\r\n\r\n const queryOptions: Parameters<QueryClient['query']>[0] = {\r\n objectType: this.objectTypeId,\r\n fields: this.selectedFields.length > 0 ? this.selectedFields : ['*'],\r\n query: this.build(),\r\n showRealValue: this.showRealValueFlag,\r\n };\r\n\r\n if (this.sortByField) {\r\n queryOptions.sortBy = this.sortByField;\r\n queryOptions.sortType = this.sortDirection;\r\n }\r\n\r\n if (this.limitValue !== null) {\r\n queryOptions.limit = this.limitValue;\r\n }\r\n\r\n if (this.pageNumber > 1) {\r\n queryOptions.page = this.pageNumber;\r\n }\r\n\r\n if (signal) {\r\n queryOptions.signal = signal;\r\n }\r\n\r\n return this.client.query(queryOptions);\r\n }\r\n\r\n /**\r\n * Creates a condition builder for the current field\r\n */\r\n private createConditionBuilder(): ConditionBuilder {\r\n const field = this.currentField!;\r\n\r\n return {\r\n equals: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '=', String(value));\r\n return this;\r\n },\r\n notEquals: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '!=', String(value));\r\n return this;\r\n },\r\n lessThan: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '<', String(value));\r\n return this;\r\n },\r\n greaterThan: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '>', String(value));\r\n return this;\r\n },\r\n lessThanOrEqual: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '<=', String(value));\r\n return this;\r\n },\r\n greaterThanOrEqual: (value: string | number): QueryBuilder => {\r\n this.addCondition(field, '>=', String(value));\r\n return this;\r\n },\r\n contains: (value: string): QueryBuilder => {\r\n // Contains translates to \"start-with %value\"\r\n this.addCondition(field, 'start-with', `%${value}`);\r\n return this;\r\n },\r\n notContains: (value: string): QueryBuilder => {\r\n // Not contains translates to \"not-start-with %value\"\r\n this.addCondition(field, 'not-start-with', `%${value}`);\r\n return this;\r\n },\r\n startsWith: (value: string): QueryBuilder => {\r\n this.addCondition(field, 'start-with', value);\r\n return this;\r\n },\r\n notStartsWith: (value: string): QueryBuilder => {\r\n this.addCondition(field, 'not-start-with', value);\r\n return this;\r\n },\r\n isNull: (): QueryBuilder => {\r\n this.addCondition(field, 'is-null');\r\n return this;\r\n },\r\n isNotNull: (): QueryBuilder => {\r\n this.addCondition(field, 'is-not-null');\r\n return this;\r\n },\r\n };\r\n }\r\n\r\n /**\r\n * Adds a condition to the query\r\n */\r\n private addCondition(field: string, operator: QueryOperator, value?: string): void {\r\n this.conditions.push({ field, operator, value });\r\n this.currentField = null;\r\n }\r\n}\r\n","/**\r\n * Special field name mappings that don't follow standard patterns\r\n * Key: original field name, Value: corresponding label field\r\n */\r\nconst SPECIAL_LABEL_FIELD_MAPPINGS: Record<string, string> = {\r\n objectid: 'objecttitle',\r\n lastactionid: 'lastactiontitle',\r\n wfruleid: 'rulename', // Object 55 (Workflow Rules)\r\n noteid: 'subject', // Object 7 (Note) - noteid maps to subject\r\n};\r\n\r\n/**\r\n * Fields ending with \"id\" that should NOT have \"id\" replaced with \"name\"\r\n * These fields will use the default append \"name\" behavior instead\r\n */\r\nconst EXCLUDED_ID_FIELDS: string[] = [\r\n 'businessunitid', // → businessunitidname (not businessunitname)\r\n 'crmuserid', // → no name field exists\r\n 'languageid', // → languageidname (not languagename)\r\n];\r\n\r\n/**\r\n * Fields ending with \"code\" that should NOT have \"code\" removed\r\n * These fields will use the default append \"name\" behavior instead\r\n */\r\nconst EXCLUDED_CODE_FIELDS: string[] = [\r\n 'duplicaterecordcode', // → duplicaterecordcodename (not duplicaterecord)\r\n];\r\n\r\n/**\r\n * Fields that have NO corresponding label field at all\r\n * These fields should not have any name transformation applied\r\n * Return empty string to signal \"no label field exists\"\r\n */\r\nconst FIELDS_WITHOUT_LABEL_FIELD: string[] = [\r\n 'systemfieldid', // Object 73 - no name field exists\r\n 'fieldobjecttype', // Object 73 - base field doesn't exist, only *name exists\r\n 'invoiceid', // Objects 78, 81 - no name field exists\r\n 'calllogid', // Object 100 - no name field exists (primary key)\r\n 'attendanceclockid', // Object 101 - no name field exists (primary key)\r\n 'activitylogid', // Object 102 - no name field exists (primary key)\r\n 'conversationid', // Object 104 - no name field exists (primary key)\r\n 'texttemplateid', // Text Template - no name field exists (primary key)\r\n 'smstemplateid', // Object 110 - no name field exists (primary key)\r\n 'deletedby', // Object 7 - no name field exists\r\n 'recordid', // Object 7 - no name field exists\r\n 'objecttypecode', // Object 7 - no name field exists\r\n];\r\n\r\n/**\r\n * Object-type specific overrides for field name transformations\r\n * Key: object type ID, Value: { excludedIdFields, excludedCodeFields }\r\n */\r\nconst OBJECT_TYPE_OVERRIDES: Record<\r\n number,\r\n { excludedIdFields?: string[]; excludedCodeFields?: string[] }\r\n> = {\r\n // CRM Orders (13) - uses *idname and *codename patterns\r\n 13: {\r\n excludedIdFields: ['ownerid', 'accountid', 'printtemplateid', 'pcfaccountid'],\r\n excludedCodeFields: [\r\n 'rounddiscountcode',\r\n 'taxincludecode',\r\n 'currencycode',\r\n 'transmissioncode',\r\n 'creditrejectioncode1',\r\n 'creditrejectioncode2',\r\n 'apartmentcode1',\r\n 'apartmentcode2',\r\n 'restrictioncode1',\r\n 'restrictioncode2',\r\n 'casescode1',\r\n 'casescode2',\r\n 'returncode1',\r\n 'returncode2',\r\n 'statuscode',\r\n ],\r\n },\r\n // Products (14)\r\n 14: {\r\n excludedCodeFields: ['categorycode'], // → categoryname (not category)\r\n },\r\n // CRM Order Items (17) - uses *idname pattern\r\n 17: {\r\n excludedIdFields: ['crmorderid', 'productid', 'ownerid'],\r\n },\r\n // Email Templates (20)\r\n 20: {\r\n excludedIdFields: ['mdobjectid'],\r\n },\r\n // Print Templates (27)\r\n 27: {\r\n excludedIdFields: ['mdobjectid'],\r\n },\r\n // System Fields (73) - uses *idname pattern\r\n 73: {\r\n excludedIdFields: ['mdobjectid', 'ownerid'],\r\n },\r\n // Invoices (78) - uses *codename and *idname patterns extensively\r\n 78: {\r\n excludedIdFields: [\r\n 'crmorderid',\r\n 'invoicereceiptid',\r\n 'accountid',\r\n 'ownerid',\r\n 'invoicerenoid',\r\n ],\r\n excludedCodeFields: [\r\n 'taxincludecode',\r\n 'depositcode',\r\n 'rounddiscountcode',\r\n 'currencycode',\r\n 'statecode',\r\n 'invoicetypecode',\r\n ],\r\n },\r\n // Invoice No (81) - uses *codename and *idname patterns extensively\r\n 81: {\r\n excludedIdFields: [\r\n 'ownerid',\r\n 'invoicecreditid',\r\n 'crmorderid',\r\n 'invoicereceiptid',\r\n 'invoicedeliveryid',\r\n 'accountid',\r\n ],\r\n excludedCodeFields: ['currencycode', 'rounddiscountcode', 'statecode', 'taxincludecode'],\r\n },\r\n // Invoice Draft (82) - uses *codename and *idname patterns extensively\r\n 82: {\r\n excludedIdFields: ['accountid', 'crmorderid', 'ownerid', 'invoicerenoid'],\r\n excludedCodeFields: ['taxincludecode', 'statecode', 'rounddiscountcode', 'currencycode'],\r\n },\r\n // Invoice Receipt (83) - uses *codename and *idname patterns\r\n 83: {\r\n excludedIdFields: ['invoicenoid', 'crmorderid', 'ownerid', 'accountid'],\r\n excludedCodeFields: ['statecode', 'currencycode'],\r\n },\r\n // Invoice Tax Receipt (84) - uses *codename and *idname patterns\r\n 84: {\r\n excludedIdFields: ['crmorderid', 'ownerid', 'invoicecreditid', 'accountid'],\r\n excludedCodeFields: ['rounddiscountcode', 'statecode', 'taxincludecode', 'currencycode'],\r\n },\r\n // Invoice Credit (85) - uses *codename and *idname patterns\r\n 85: {\r\n excludedIdFields: ['ownerid', 'crmorderid', 'accountid'],\r\n excludedCodeFields: ['taxincludecode', 'rounddiscountcode', 'currencycode', 'statecode'],\r\n },\r\n // Invoice (86) - uses *codename and *idname patterns\r\n 86: {\r\n excludedIdFields: ['accountid', 'ownerid', 'crmorderid'],\r\n excludedCodeFields: ['statecode', 'rounddiscountcode', 'currencycode', 'taxincludecode'],\r\n },\r\n // Call Log (100) - uses *idname pattern\r\n 100: {\r\n excludedIdFields: ['contactid', 'leadid', 'accountid', 'ownerid'],\r\n },\r\n // Attendance Clock (101) - uses *idname pattern\r\n 101: {\r\n excludedIdFields: ['ownerid'],\r\n },\r\n // Activity Log (102) - uses *idname and *codename patterns\r\n 102: {\r\n excludedIdFields: ['contactid', 'ownerid'],\r\n excludedCodeFields: ['objecttypecode', 'typecode', 'resultcode'],\r\n },\r\n // Conversation (104) - uses *idname pattern\r\n 104: {\r\n excludedIdFields: ['leadid', 'ownerid', 'contactid', 'accountid'],\r\n },\r\n // Text Template (106) - uses *idname pattern\r\n 106: {\r\n excludedIdFields: ['ownerid'],\r\n },\r\n // SMS Template (110) - uses *idname pattern\r\n 110: {\r\n excludedIdFields: ['ownerid'],\r\n },\r\n};\r\n\r\n/**\r\n * Converts a field API name to its corresponding label field.\r\n *\r\n * Rules:\r\n * - Special mappings (e.g., objectid → objecttitle)\r\n * - Fields starting with \"pcf\" (custom fields): append \"name\" → pcf_field → pcf_fieldname\r\n * - Fields ending with \"code\" (unless excluded): remove \"code\" → statuscode → status\r\n * - Fields ending with \"id\" (unless excluded): replace \"id\" with \"name\" → accountid → accountname\r\n * - All other fields: append \"name\"\r\n *\r\n * @param fieldName - The field API name\r\n * @param objectType - The object type ID (required for object-specific overrides)\r\n * @returns The corresponding label field, or empty string if no label field exists\r\n */\r\nexport function getLabelFieldForField(fieldName: string, objectType: string | number): string {\r\n // Check special mappings first\r\n if (SPECIAL_LABEL_FIELD_MAPPINGS[fieldName]) {\r\n return SPECIAL_LABEL_FIELD_MAPPINGS[fieldName];\r\n }\r\n\r\n // Check if field has no label field at all - return empty string\r\n if (FIELDS_WITHOUT_LABEL_FIELD.includes(fieldName)) {\r\n return '';\r\n }\r\n\r\n // Check for custom object primary keys (customobject{N}id pattern) → name\r\n if (/^customobject\\d+id$/.test(fieldName)) {\r\n return 'name';\r\n }\r\n\r\n // Custom fields (pcf prefix) - just append \"name\"\r\n if (fieldName.startsWith('pcf')) {\r\n return `${fieldName}name`;\r\n }\r\n\r\n // Get object-type specific overrides\r\n const objectTypeNum =\r\n typeof objectType === 'string' ? parseInt(objectType, 10) : objectType;\r\n const overrides = OBJECT_TYPE_OVERRIDES[objectTypeNum] || null;\r\n\r\n // For custom objects (1000+), add default exclusions\r\n const isCustomObject = objectTypeNum >= 1000;\r\n const customObjectExclusions = isCustomObject ? ['ownerid'] : [];\r\n\r\n // Combine global and object-specific exclusions\r\n const excludedCodeFields = [\r\n ...EXCLUDED_CODE_FIELDS,\r\n ...(overrides?.excludedCodeFields || []),\r\n ];\r\n const excludedIdFields = [\r\n ...EXCLUDED_ID_FIELDS,\r\n ...(overrides?.excludedIdFields || []),\r\n ...customObjectExclusions,\r\n ];\r\n\r\n // Remove \"code\" suffix (unless excluded) → statuscode → status\r\n if (fieldName.endsWith('code') && !excludedCodeFields.includes(fieldName)) {\r\n return fieldName.slice(0, -4);\r\n }\r\n\r\n // Replace \"id\" suffix with \"name\" (unless excluded) → accountid → accountname\r\n if (fieldName.endsWith('id') && !excludedIdFields.includes(fieldName)) {\r\n return fieldName.slice(0, -2) + 'name';\r\n }\r\n\r\n // Default: append \"name\"\r\n return `${fieldName}name`;\r\n}\r\n","/**\r\n * Object Type ID to Primary Key Field Mapping\r\n * Maps Fireberry object type IDs to their primary key field names\r\n */\r\nexport const OBJECT_ID_MAP: Record<number, string> = {\r\n 1: 'accountid',\r\n 2: 'contactid',\r\n 3: 'leadid',\r\n 4: 'opportunityid',\r\n 5: 'casesid',\r\n 6: 'activityid',\r\n 7: 'noteid',\r\n 8: 'competitorid',\r\n 9: 'crmuserid',\r\n 10: 'taskid',\r\n 13: 'crmorderid',\r\n 14: 'productid',\r\n 17: 'crmorderitemid',\r\n 20: 'emailtemplateid',\r\n 23: 'businessunitid',\r\n 27: 'printtemplateid',\r\n 28: 'contractid',\r\n 33: 'accountproductid',\r\n 46: 'projectid',\r\n 67: 'campaignid',\r\n 76: 'articleid',\r\n 86: 'invoiceid',\r\n 101: 'attendanceclockid',\r\n 102: 'activitylogid',\r\n 104: 'conversationid',\r\n 114: 'calendarresourceid',\r\n};\r\n\r\n/**\r\n * Gets the primary key field name for a given object type\r\n *\r\n * @param objectTypeId - The numeric object type ID\r\n * @returns The correct ID field name for the object type\r\n */\r\nexport function getObjectIdFieldName(objectTypeId: string | number): string {\r\n const objectTypeNum =\r\n typeof objectTypeId === 'string' ? parseInt(objectTypeId, 10) : objectTypeId;\r\n\r\n // Check if it's a mapped base object\r\n if (OBJECT_ID_MAP[objectTypeNum]) {\r\n return OBJECT_ID_MAP[objectTypeNum];\r\n }\r\n\r\n // For custom objects (1000 and up), use the pattern customobjectXid\r\n if (objectTypeNum >= 1000) {\r\n return `customobject${objectTypeNum}id`;\r\n }\r\n\r\n // Fallback to generic 'id' for unmapped objects\r\n return 'id';\r\n}\r\n","/**\r\n * Object Type ID to Name Field Mapping\r\n * Maps Fireberry object type IDs to their display name field\r\n */\r\nexport const OBJECT_NAME_MAP: Record<number, string> = {\r\n 1: 'accountname', // Account\r\n 2: 'fullname', // Contact\r\n 3: 'fullname', // Lead\r\n 4: 'name', // Opportunity\r\n 5: 'title', // Case\r\n 6: 'subject', // Activity\r\n 7: 'subject', // Note\r\n 8: 'name', // Competitor\r\n 9: 'fullname', // CRM User\r\n 10: 'subject', // Task\r\n 13: 'name', // CRM Order\r\n 14: 'productname', // Product\r\n 17: 'productname', // CRM Order Item\r\n 20: 'name', // Email Template\r\n 23: 'name', // Business Unit\r\n 27: 'name', // Print Template\r\n 28: 'name', // Contract\r\n 33: 'productname', // Account Product\r\n 46: 'name', // Project\r\n 67: 'name', // Campaign\r\n 76: 'title', // Article\r\n 86: 'name', // Invoice\r\n 101: 'name', // Attendance Clock\r\n 102: 'subject', // Activity Log\r\n 104: 'subject', // Conversation\r\n 114: 'name', // Calendar Resource\r\n};\r\n\r\n/**\r\n * Gets the display name field for a given object type\r\n *\r\n * @param objectTypeId - The numeric object type ID\r\n * @returns The name field for the object type\r\n */\r\nexport function getNameFieldByObjectType(objectTypeId: string | number): string {\r\n const objectTypeNum =\r\n typeof objectTypeId === 'string' ? parseInt(objectTypeId, 10) : objectTypeId;\r\n\r\n // Check if it's a mapped base object\r\n if (OBJECT_NAME_MAP[objectTypeNum]) {\r\n return OBJECT_NAME_MAP[objectTypeNum];\r\n }\r\n\r\n // For custom objects (1000 and up), use 'name'\r\n if (objectTypeNum >= 1000) {\r\n return 'name';\r\n }\r\n\r\n // Fallback to 'name' for unmapped objects\r\n return 'name';\r\n}\r\n","/**\r\n * Fields to exclude from queries when using '*' (all fields) for specific object types\r\n * These fields cause API errors when queried\r\n */\r\nexport const EXCLUDED_FIELDS_FOR_STAR_QUERY: Record<string, string[]> = {\r\n '7': ['deletedon', 'deletedby'], // Note\r\n '8': ['deletedon', 'deletedby'], // Competitor\r\n '114': ['deletedon', 'deletedby'], // Calendar Resource\r\n '115': ['deletedon', 'deletedby'], // Customer Journey\r\n '116': ['deletedon', 'deletedby'], // Profile\r\n '117': ['deletedon', 'deletedby'], // Landing Page\r\n};\r\n\r\n/**\r\n * Checks if a field should be excluded from star queries for a given object type\r\n *\r\n * @param objectType - The object type ID\r\n * @param fieldName - The field name to check\r\n * @returns True if the field should be excluded\r\n */\r\nexport function isExcludedFromStarQuery(objectType: string | number, fieldName: string): boolean {\r\n const objectTypeStr = String(objectType);\r\n const excludedFields = EXCLUDED_FIELDS_FOR_STAR_QUERY[objectTypeStr];\r\n return excludedFields ? excludedFields.includes(fieldName) : false;\r\n}\r\n\r\n/**\r\n * Gets the list of excluded fields for a given object type\r\n *\r\n * @param objectType - The object type ID\r\n * @returns Array of field names to exclude, or empty array if none\r\n */\r\nexport function getExcludedFieldsForStarQuery(objectType: string | number): string[] {\r\n const objectTypeStr = String(objectType);\r\n return EXCLUDED_FIELDS_FOR_STAR_QUERY[objectTypeStr] || [];\r\n}\r\n","/**\r\n * Field Type System IDs from Fireberry CRM\r\n * These UUIDs identify different field types in the metadata API\r\n */\r\nexport const FIELD_TYPE_IDS = {\r\n DROPDOWN: 'b4919f2e-2996-48e4-a03c-ba39fb64386c',\r\n LOOKUP: 'a8fcdf65-91bc-46fd-82f6-1234758345a1',\r\n EMAIL: 'c713d2f7-8fa9-43c3-8062-f07486eaf567',\r\n TEXT: 'a1e7ed6f-5083-477b-b44c-9943a6181359',\r\n URL: 'c820d32f-44df-4c2a-9c1e-18734e864fd5',\r\n LONG_TEXT: '80108f9d-1e75-40fa-9fa9-02be4ddc1da1',\r\n DATETIME: 'ce972d02-5013-46d4-9d1d-f09df1ac346a',\r\n DATE: '83bf530c-e04c-462b-9ffc-a46f750fc072',\r\n HTML: 'ed2ad39d-32fc-4585-8f5b-2e93463f050a',\r\n TELEPHONE: '3f62f67a-1cee-403a-bec6-aa02a9804edb',\r\n NUMERIC: '6a34bfe3-fece-4da1-9136-a7b1e5ae3319',\r\n} as const;\r\n\r\n/**\r\n * Human-readable mappings for field types\r\n * Used for display purposes\r\n */\r\nexport const FIELD_TYPE_MAPPINGS: Record<string, string> = {\r\n [FIELD_TYPE_IDS.DROPDOWN]: 'Dropdown',\r\n [FIELD_TYPE_IDS.EMAIL]: 'Email',\r\n [FIELD_TYPE_IDS.TEXT]: 'Text',\r\n [FIELD_TYPE_IDS.LOOKUP]: 'Lookup',\r\n [FIELD_TYPE_IDS.URL]: 'URL',\r\n [FIELD_TYPE_IDS.LONG_TEXT]: 'Long Text',\r\n [FIELD_TYPE_IDS.DATETIME]: 'DateTime',\r\n [FIELD_TYPE_IDS.DATE]: 'Date',\r\n [FIELD_TYPE_IDS.HTML]: 'HTML',\r\n [FIELD_TYPE_IDS.TELEPHONE]: 'Telephone',\r\n [FIELD_TYPE_IDS.NUMERIC]: 'Number',\r\n};\r\n","import { FIELD_TYPE_IDS } from '../constants/fieldTypes';\r\n\r\n/**\r\n * Checks if a field is a dropdown type based on its systemFieldTypeId\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a dropdown\r\n */\r\nexport function isDropdownField(systemFieldTypeId: string): boolean {\r\n return systemFieldTypeId === FIELD_TYPE_IDS.DROPDOWN;\r\n}\r\n\r\n/**\r\n * Checks if a field is a lookup type based on its systemFieldTypeId\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a lookup\r\n */\r\nexport function isLookupField(systemFieldTypeId: string): boolean {\r\n return systemFieldTypeId === FIELD_TYPE_IDS.LOOKUP;\r\n}\r\n\r\n/**\r\n * Checks if a field is a dropdown or lookup type\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a dropdown or lookup\r\n */\r\nexport function isDropdownOrLookupField(systemFieldTypeId: string): boolean {\r\n return isDropdownField(systemFieldTypeId) || isLookupField(systemFieldTypeId);\r\n}\r\n\r\n/**\r\n * Checks if a field is a text type\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a text field\r\n */\r\nexport function isTextField(systemFieldTypeId: string): boolean {\r\n return systemFieldTypeId === FIELD_TYPE_IDS.TEXT;\r\n}\r\n\r\n/**\r\n * Checks if a field is a numeric type\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a numeric field\r\n */\r\nexport function isNumericField(systemFieldTypeId: string): boolean {\r\n return systemFieldTypeId === FIELD_TYPE_IDS.NUMERIC;\r\n}\r\n\r\n/**\r\n * Checks if a field is a date type (date or datetime)\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns True if the field is a date or datetime field\r\n */\r\nexport function isDateField(systemFieldTypeId: string): boolean {\r\n return (\r\n systemFieldTypeId === FIELD_TYPE_IDS.DATE ||\r\n systemFieldTypeId === FIELD_TYPE_IDS.DATETIME\r\n );\r\n}\r\n\r\n/**\r\n * Gets the field type name from its system ID\r\n *\r\n * @param systemFieldTypeId - The system field type ID from metadata\r\n * @returns Human-readable field type name, or 'Unknown' if not found\r\n */\r\nexport function getFieldTypeName(systemFieldTypeId: string): string {\r\n const typeMap: Record<string, string> = {\r\n [FIELD_TYPE_IDS.DROPDOWN]: 'Dropdown',\r\n [FIELD_TYPE_IDS.LOOKUP]: 'Lookup',\r\n [FIELD_TYPE_IDS.EMAIL]: 'Email',\r\n [FIELD_TYPE_IDS.TEXT]: 'Text',\r\n [FIELD_TYPE_IDS.URL]: 'URL',\r\n [FIELD_TYPE_IDS.LONG_TEXT]: 'Long Text',\r\n [FIELD_TYPE_IDS.DATETIME]: 'DateTime',\r\n [FIELD_TYPE_IDS.DATE]: 'Date',\r\n [FIELD_TYPE_IDS.HTML]: 'HTML',\r\n [FIELD_TYPE_IDS.TELEPHONE]: 'Telephone',\r\n [FIELD_TYPE_IDS.NUMERIC]: 'Number',\r\n };\r\n return typeMap[systemFieldTypeId] || 'Unknown';\r\n}\r\n","/**\r\n * SDK Adapter for @fireberry/sdk\r\n *\r\n * This module provides utilities to enhance the Fireberry SDK with\r\n * QueryBuilder and field mapping capabilities from fireberry-api-client.\r\n *\r\n * @example\r\n * ```typescript\r\n * import FireberryClientSDK from '@fireberry/sdk/client';\r\n * import { createSDKQueryBuilder, EnhancedSDK } from 'fireberry-api-client/sdk';\r\n *\r\n * // Option 1: Use query builder factory\r\n * const sdk = new FireberryClientSDK();\r\n * await sdk.initializeContext();\r\n *\r\n * const queryBuilder = createSDKQueryBuilder(sdk);\r\n * const results = await queryBuilder(1)\r\n * .select('accountid', 'accountname', 'statuscode')\r\n * .where('statuscode').equals('1')\r\n * .execute();\r\n *\r\n * // Option 2: Use enhanced SDK wrapper\r\n * const enhanced = EnhancedSDK.create(sdk);\r\n * const results = await enhanced\r\n * .query(1)\r\n * .select('accountid', 'accountname')\r\n * .where('statuscode').equals('1')\r\n * .execute();\r\n * ```\r\n *\r\n * @packageDocumentation\r\n */\r\n\r\nimport type {\r\n FireberrySDKClient,\r\n FireberrySDKAPI,\r\n SDKQueryPayload,\r\n SDKResponseData,\r\n SDKContext,\r\n} from '../types/sdk';\r\nimport { QueryBuilder, escapeQueryValue, sanitizeQuery, type ConditionBuilder } from '../utils/queryBuilder';\r\nimport { getLabelFieldForField } from '../utils/fieldMapping';\r\nimport { getObjectIdFieldName, getNameFieldByObjectType } from '../utils/objectMapping';\r\nimport { getExcludedFieldsForStarQuery } from '../constants/excludedFields';\r\nimport {\r\n isDropdownField,\r\n isLookupField,\r\n isDropdownOrLookupField,\r\n} from '../utils/fieldTypes';\r\n\r\n// Re-export types for convenience\r\nexport type {\r\n FireberrySDKClient,\r\n FireberrySDKAPI,\r\n SDKQueryPayload,\r\n SDKResponseData,\r\n SDKContext,\r\n} from '../types/sdk';\r\n\r\n/**\r\n * Condition builder that returns SDKQueryBuilder for fluent chaining\r\n */\r\ninterface SDKConditionBuilder {\r\n equals(value: string | number): SDKQueryBuilder;\r\n notEquals(value: string | number): SDKQueryBuilder;\r\n lessThan(value: string | number): SDKQueryBuilder;\r\n greaterThan(value: string | number): SDKQueryBuilder;\r\n lessThanOrEqual(value: string | number): SDKQueryBuilder;\r\n greaterThanOrEqual(value: string | number): SDKQueryBuilder;\r\n contains(value: string): SDKQueryBuilder;\r\n notContains(value: string): SDKQueryBuilder;\r\n startsWith(value: string): SDKQueryBuilder;\r\n notStartsWith(value: string): SDKQueryBuilder;\r\n isNull(): SDKQueryBuilder;\r\n isNotNull(): SDKQueryBuilder;\r\n}\r\n\r\n/**\r\n * SDK-compatible query builder that executes via the Fireberry SDK\r\n */\r\nexport class SDKQueryBuilder {\r\n private builder: QueryBuilder;\r\n private objectTypeId: number | string;\r\n private sdk: FireberrySDKAPI;\r\n private selectedFields: string[] = [];\r\n private pageSizeValue?: number;\r\n private pageNum: number = 1;\r\n\r\n constructor(sdk: FireberrySDKAPI, objectType: number | string) {\r\n this.sdk = sdk;\r\n this.objectTypeId = objectType;\r\n this.builder = new QueryBuilder();\r\n }\r\n\r\n /**\r\n * Select fields to return\r\n * @param fields - Field names to include in results\r\n */\r\n select(...fields: string[]): this {\r\n this.selectedFields.push(...fields);\r\n return this;\r\n }\r\n\r\n /**\r\n * Select fields with their label fields automatically included\r\n * Useful for dropdown and lookup fields where you want both ID and display value\r\n * @param fields - Field names to include\r\n */\r\n selectWithLabels(...fields: string[]): this {\r\n const objectType = typeof this.objectTypeId === 'string'\r\n ? parseInt(this.objectTypeId, 10)\r\n : this.objectTypeId;\r\n\r\n for (const field of fields) {\r\n if (!this.selectedFields.includes(field)) {\r\n this.selectedFields.push(field);\r\n }\r\n const labelField = getLabelFieldForField(field, objectType);\r\n if (labelField && !this.selectedFields.includes(labelField)) {\r\n this.selectedFields.push(labelField);\r\n }\r\n }\r\n return this;\r\n }\r\n\r\n /**\r\n * Start a WHERE condition\r\n * @param field - Field name to filter on\r\n */\r\n where(field: string): SDKConditionBuilder {\r\n const innerBuilder = this.builder.where(field);\r\n // Wrap the inner condition builder to return this SDKQueryBuilder\r\n return {\r\n equals: (value: string | number) => { innerBuilder.equals(value); return this; },\r\n notEquals: (value: string | number) => { innerBuilder.notEquals(value); return this; },\r\n lessThan: (value: string | number) => { innerBuilder.lessThan(value); return this; },\r\n greaterThan: (value: string | number) => { innerBuilder.greaterThan(value); return this; },\r\n lessThanOrEqual: (value: string | number) => { innerBuilder.lessThanOrEqual(value); return this; },\r\n greaterThanOrEqual: (value: string | number) => { innerBuilder.greaterThanOrEqual(value); return this; },\r\n contains: (value: string) => { innerBuilder.contains(value); return this; },\r\n notContains: (value: string) => { innerBuilder.notContains(value); return this; },\r\n startsWith: (value: string) => { innerBuilder.startsWith(value); return this; },\r\n notStartsWith: (value: string) => { innerBuilder.notStartsWith(value); return this; },\r\n isNull: () => { innerBuilder.isNull(); return this; },\r\n isNotNull: () => { innerBuilder.isNotNull(); return this; },\r\n };\r\n }\r\n\r\n /**\r\n * Add AND logical operator\r\n */\r\n and(): this {\r\n this.builder.and();\r\n return this;\r\n }\r\n\r\n /**\r\n * Add OR logical operator\r\n */\r\n or(): this {\r\n this.builder.or();\r\n return this;\r\n }\r\n\r\n /**\r\n * Set page size for pagination\r\n * @param size - Number of records per page\r\n */\r\n pageSize(size: number): this {\r\n this.pageSizeValue = size;\r\n return this;\r\n }\r\n\r\n /**\r\n * Set page number for pagination\r\n * @param page - Page number (1-based)\r\n */\r\n page(page: number): this {\r\n this.pageNum = page;\r\n return this;\r\n }\r\n\r\n /**\r\n * Build the query payload without executing\r\n * Useful if you want to modify the payload before sending\r\n */\r\n toQueryPayload(): SDKQueryPayload {\r\n const payload: SDKQueryPayload = {\r\n fields: this.selectedFields.length > 0\r\n ? this.selectedFields.join(',')\r\n : '*',\r\n query: this.builder.build(),\r\n };\r\n\r\n if (this.pageSizeValue !== undefined) {\r\n payload.page_size = this.pageSizeValue;\r\n }\r\n\r\n if (this.pageNum > 1) {\r\n payload.page_number = this.pageNum;\r\n }\r\n\r\n return payload;\r\n }\r\n\r\n /**\r\n * Execute the query via the SDK\r\n */\r\n async execute<T = Record<string, unknown>>(): Promise<SDKResponseData<T>> {\r\n const payload = this.toQueryPayload();\r\n return this.sdk.query(this.objectTypeId, payload) as Promise<SDKResponseData<T>>;\r\n }\r\n}\r\n\r\n/**\r\n * Creates a query builder factory bound to a Fireberry SDK instance\r\n *\r\n * @param sdk - Fireberry SDK client or API instance\r\n * @returns Factory function that creates SDKQueryBuilder instances\r\n *\r\n * @example\r\n * ```typescript\r\n * import FireberryClientSDK from '@fireberry/sdk/client';\r\n * import { createSDKQueryBuilder } from 'fireberry-api-client/sdk';\r\n *\r\n * const sdk = new FireberryClientSDK();\r\n * await sdk.initializeContext();\r\n *\r\n * const queryBuilder = createSDKQueryBuilder(sdk);\r\n *\r\n * // Query accounts where status is active\r\n * const results = await queryBuilder(1) // 1 = Account object type\r\n * .select('accountid', 'accountname', 'statuscode', 'status')\r\n * .where('statuscode').equals('1')\r\n * .pageSize(50)\r\n * .execute();\r\n * ```\r\n */\r\nexport function createSDKQueryBuilder(\r\n sdk: FireberrySDKClient | FireberrySDKAPI\r\n): (objectType: number | string) => SDKQueryBuilder {\r\n const api = 'api' in sdk ? sdk.api : sdk;\r\n\r\n return (objectType: number | string) => new SDKQueryBuilder(api, objectType);\r\n}\r\n\r\n/**\r\n * Enhanced SDK wrapper that combines Fireberry SDK with utility functions\r\n * Provides a more feature-rich API for working with Fireberry data\r\n */\r\nexport class EnhancedSDK<TData = Record<string, unknown>> {\r\n private sdk: FireberrySDKClient<TData>;\r\n\r\n private constructor(sdk: FireberrySDKClient<TData>) {\r\n this.sdk = sdk;\r\n }\r\n\r\n /**\r\n * Create an EnhancedSDK wrapper around an existing SDK instance\r\n * The SDK should already be initialized with context\r\n *\r\n * @param sdk - Initialized Fireberry SDK client\r\n */\r\n static create<T = Record<string, unknown>>(\r\n sdk: FireberrySDKClient<T>\r\n ): EnhancedSDK<T> {\r\n return new EnhancedSDK(sdk);\r\n }\r\n\r\n /**\r\n * Get the current context (user and record info)\r\n */\r\n get context(): SDKContext | null {\r\n return this.sdk.context;\r\n }\r\n\r\n /**\r\n * Get the underlying SDK API for direct access\r\n */\r\n get api(): FireberrySDKAPI<TData> {\r\n return this.sdk.api;\r\n }\r\n\r\n /**\r\n * Get the current user ID from context\r\n */\r\n get userId(): string | undefined {\r\n return this.context?.user?.id;\r\n }\r\n\r\n /**\r\n * Get the current user's full name from context\r\n */\r\n get userFullName(): string | undefined {\r\n return this.context?.user?.fullName;\r\n }\r\n\r\n /**\r\n * Get the current record ID from context\r\n */\r\n get recordId(): string | undefined {\r\n return this.context?.record?.id;\r\n }\r\n\r\n /**\r\n * Get the current record's object type from context\r\n */\r\n get recordType(): number | undefined {\r\n return this.context?.record?.type;\r\n }\r\n\r\n /**\r\n * Start building a query for an object type\r\n *\r\n * @param objectType - Object type ID (e.g., 1 for Account, 2 for Contact)\r\n * @returns SDKQueryBuilder for fluent query construction\r\n *\r\n * @example\r\n * ```typescript\r\n * const results = await enhanced\r\n * .query(1)\r\n * .select('accountid', 'accountname')\r\n * .where('ownerid').equals(enhanced.userId)\r\n * .execute();\r\n * ```\r\n */\r\n query(objectType: number | string): SDKQueryBuilder {\r\n // Cast is safe - SDKQueryBuilder only uses the query method which has the same signature\r\n return new SDKQueryBuilder(this.sdk.api as FireberrySDKAPI, objectType);\r\n }\r\n\r\n /**\r\n * Get the primary key field name for an object type\r\n *\r\n * @param objectType - Object type ID\r\n * @returns Primary key field name (e.g., 'accountid' for type 1)\r\n *\r\n * @example\r\n * ```typescript\r\n * const idField = enhanced.getIdField(1); // 'accountid'\r\n * const idField = enhanced.getIdField(2); // 'contactid'\r\n * ```\r\n */\r\n getIdField(objectType: number | string): string {\r\n return getObjectIdFieldName(objectType);\r\n }\r\n\r\n /**\r\n * Get the display name field for an object type\r\n *\r\n * @param objectType - Object type ID\r\n * @returns Name field (e.g., 'accountname' for type 1, 'fullname' for type 2)\r\n *\r\n * @example\r\n * ```typescript\r\n * const nameField = enhanced.getNameField(1); // 'accountname'\r\n * const nameField = enhanced.getNameField(2); // 'fullname'\r\n * ```\r\n */\r\n getNameField(objectType: number | string): string {\r\n return getNameFieldByObjectType(objectType);\r\n }\r\n\r\n /**\r\n * Get the label field for a dropdown or lookup field\r\n *\r\n * @param fieldName - API field name\r\n * @param objectType - Object type ID\r\n * @returns Label field name, or empty string if not applicable\r\n *\r\n * @example\r\n * ```typescript\r\n * const labelField = enhanced.getLabelField('statuscode', 1); // 'status'\r\n * const labelField = enhanced.getLabelField('ownerid', 1); // 'ownername'\r\n * ```\r\n */\r\n getLabelField(fieldName: string, objectType: number | string): string {\r\n return getLabelFieldForField(fieldName, objectType);\r\n }\r\n\r\n /**\r\n * Get fields that should be excluded from * (star) queries for an object type\r\n * Some fields cause API errors when included in broad queries\r\n *\r\n * @param objectType - Object type ID\r\n * @returns Array of field names to exclude\r\n */\r\n getExcludedFields(objectType: number | string): string[] {\r\n return getExcludedFieldsForStarQuery(objectType);\r\n }\r\n\r\n /**\r\n * Expand field list to include label fields for dropdowns and lookups\r\n *\r\n * @param fields - Original field list\r\n * @param objectType - Object type ID\r\n * @returns Expanded field list with label fields\r\n *\r\n * @example\r\n * ```typescript\r\n * const fields = enhanced.expandFieldsWithLabels(['statuscode', 'ownerid'], 1);\r\n * // Returns: ['statuscode', 'status', 'ownerid', 'ownername']\r\n * ```\r\n */\r\n expandFieldsWithLabels(fields: string[], objectType: number | string): string[] {\r\n const result: string[] = [];\r\n for (const field of fields) {\r\n if (!result.includes(field)) {\r\n result.push(field);\r\n }\r\n const labelField = getLabelFieldForField(field, objectType);\r\n if (labelField && !result.includes(labelField)) {\r\n result.push(labelField);\r\n }\r\n }\r\n return result;\r\n }\r\n\r\n /**\r\n * Create a record\r\n *\r\n * @param objectType - Object type ID\r\n * @param data - Record data\r\n */\r\n create<T extends Record<string, unknown>>(\r\n objectType: number | string,\r\n data: T\r\n ): Promise<SDKResponseData<TData>> {\r\n return this.sdk.api.create(objectType, data);\r\n }\r\n\r\n /**\r\n * Update a record\r\n *\r\n * @param objectType - Object type ID\r\n * @param recordId - Record ID to update\r\n * @param data - Updated field values\r\n */\r\n update<T extends Record<string, unknown>>(\r\n objectType: number | string,\r\n recordId: string,\r\n data: T\r\n ): Promise<SDKResponseData<TData>> {\r\n return this.sdk.api.update(objectType, recordId, data);\r\n }\r\n\r\n /**\r\n * Delete a record\r\n *\r\n * @param objectType - Object type ID\r\n * @param recordId - Record ID to delete\r\n */\r\n delete(\r\n objectType: number | string,\r\n recordId: string\r\n ): Promise<SDKResponseData<TData>> {\r\n return this.sdk.api.delete(objectType, recordId);\r\n }\r\n\r\n /**\r\n * Clean up the underlying SDK\r\n */\r\n destroy(): void {\r\n this.sdk.destroy();\r\n }\r\n}\r\n\r\n// Re-export utilities that work standalone with the SDK\r\nexport {\r\n // Query utilities\r\n QueryBuilder,\r\n escapeQueryValue,\r\n sanitizeQuery,\r\n type ConditionBuilder,\r\n // Field utilities\r\n getLabelFieldForField,\r\n getObjectIdFieldName,\r\n getNameFieldByObjectType,\r\n getExcludedFieldsForStarQuery,\r\n // Type detection\r\n isDropdownField,\r\n isLookupField,\r\n isDropdownOrLookupField,\r\n};\r\n\r\n// Re-export constants\r\nexport {\r\n FIELD_TYPE_IDS,\r\n FIELD_TYPE_MAPPINGS,\r\n OBJECT_ID_MAP,\r\n OBJECT_NAME_MAP,\r\n EXCLUDED_FIELDS_FOR_STAR_QUERY,\r\n} from '../constants';\r\n"]}
|
|
@@ -0,0 +1,372 @@
|
|
|
1
|
+
export { C as ConditionBuilder, E as EXCLUDED_FIELDS_FOR_STAR_QUERY, F as FIELD_TYPE_IDS, a as FIELD_TYPE_MAPPINGS, O as OBJECT_ID_MAP, b as OBJECT_NAME_MAP, Q as QueryBuilder, e as escapeQueryValue, d as getExcludedFieldsForStarQuery, c as getNameFieldByObjectType, g as getObjectIdFieldName, s as sanitizeQuery } from '../excludedFields-CGXgZN8Y.cjs';
|
|
2
|
+
export { g as getLabelFieldForField, i as isDropdownField, b as isDropdownOrLookupField, a as isLookupField } from '../fieldTypes-BLzJTzpI.cjs';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Type definitions for @fireberry/sdk compatibility
|
|
6
|
+
* These types mirror the Fireberry SDK's API for seamless integration
|
|
7
|
+
*/
|
|
8
|
+
/**
|
|
9
|
+
* Query payload expected by the Fireberry SDK
|
|
10
|
+
*/
|
|
11
|
+
interface SDKQueryPayload {
|
|
12
|
+
/** Comma-separated field names to return */
|
|
13
|
+
fields: string;
|
|
14
|
+
/** Query filter string */
|
|
15
|
+
query: string;
|
|
16
|
+
/** Number of records per page */
|
|
17
|
+
page_size?: number;
|
|
18
|
+
/** Page number (1-based) */
|
|
19
|
+
page_number?: number;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Response error from SDK
|
|
23
|
+
*/
|
|
24
|
+
interface SDKResponseError {
|
|
25
|
+
data: Record<string, unknown> & {
|
|
26
|
+
Message?: string;
|
|
27
|
+
};
|
|
28
|
+
status: number;
|
|
29
|
+
statusText: string;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Response data from SDK operations
|
|
33
|
+
*/
|
|
34
|
+
interface SDKResponseData<T = Record<string, unknown>> {
|
|
35
|
+
type?: string;
|
|
36
|
+
success: boolean;
|
|
37
|
+
data: T & {
|
|
38
|
+
requestId?: string;
|
|
39
|
+
};
|
|
40
|
+
error?: SDKResponseError;
|
|
41
|
+
isParentReady: boolean;
|
|
42
|
+
requestId: string;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Record details from SDK context
|
|
46
|
+
*/
|
|
47
|
+
interface SDKRecordDetails {
|
|
48
|
+
type?: number;
|
|
49
|
+
id?: string;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* User details from SDK context
|
|
53
|
+
*/
|
|
54
|
+
interface SDKUserDetails {
|
|
55
|
+
fullName?: string;
|
|
56
|
+
id?: string;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* SDK context information
|
|
60
|
+
*/
|
|
61
|
+
interface SDKContext {
|
|
62
|
+
user: SDKUserDetails;
|
|
63
|
+
record: SDKRecordDetails;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Generic payload type for create/update operations
|
|
67
|
+
*/
|
|
68
|
+
type SDKPayload = Record<string, unknown>;
|
|
69
|
+
/**
|
|
70
|
+
* Fireberry SDK API interface
|
|
71
|
+
* Matches the API surface of @fireberry/sdk
|
|
72
|
+
*/
|
|
73
|
+
interface FireberrySDKAPI<TData = Record<string, unknown>> {
|
|
74
|
+
/** Query records with filtering and pagination */
|
|
75
|
+
query: (objectType: string | number, payload: SDKQueryPayload) => Promise<SDKResponseData<TData>>;
|
|
76
|
+
/** Create a new record */
|
|
77
|
+
create: <T extends SDKPayload>(objectType: string | number, payload: T) => Promise<SDKResponseData<TData>>;
|
|
78
|
+
/** Delete a record by ID */
|
|
79
|
+
delete: (objectType: string | number, recordId: string) => Promise<SDKResponseData<TData>>;
|
|
80
|
+
/** Update an existing record */
|
|
81
|
+
update: <T extends SDKPayload>(objectType: string | number, recordId: string, payload: T) => Promise<SDKResponseData<TData>>;
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Fireberry SDK Client interface
|
|
85
|
+
* Matches the structure of FireberryClientSDK from @fireberry/sdk
|
|
86
|
+
*/
|
|
87
|
+
interface FireberrySDKClient<TData = Record<string, unknown>> {
|
|
88
|
+
/** Access to CRUD API methods */
|
|
89
|
+
readonly api: FireberrySDKAPI<TData>;
|
|
90
|
+
/** Current context (record and user info) - null if not initialized */
|
|
91
|
+
readonly context: SDKContext | null;
|
|
92
|
+
/** Initialize context from parent Fireberry window */
|
|
93
|
+
initializeContext(): Promise<FireberrySDKClient<TData>>;
|
|
94
|
+
/** Clean up event listeners and pending requests */
|
|
95
|
+
destroy(): void;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* SDK Adapter for @fireberry/sdk
|
|
100
|
+
*
|
|
101
|
+
* This module provides utilities to enhance the Fireberry SDK with
|
|
102
|
+
* QueryBuilder and field mapping capabilities from fireberry-api-client.
|
|
103
|
+
*
|
|
104
|
+
* @example
|
|
105
|
+
* ```typescript
|
|
106
|
+
* import FireberryClientSDK from '@fireberry/sdk/client';
|
|
107
|
+
* import { createSDKQueryBuilder, EnhancedSDK } from 'fireberry-api-client/sdk';
|
|
108
|
+
*
|
|
109
|
+
* // Option 1: Use query builder factory
|
|
110
|
+
* const sdk = new FireberryClientSDK();
|
|
111
|
+
* await sdk.initializeContext();
|
|
112
|
+
*
|
|
113
|
+
* const queryBuilder = createSDKQueryBuilder(sdk);
|
|
114
|
+
* const results = await queryBuilder(1)
|
|
115
|
+
* .select('accountid', 'accountname', 'statuscode')
|
|
116
|
+
* .where('statuscode').equals('1')
|
|
117
|
+
* .execute();
|
|
118
|
+
*
|
|
119
|
+
* // Option 2: Use enhanced SDK wrapper
|
|
120
|
+
* const enhanced = EnhancedSDK.create(sdk);
|
|
121
|
+
* const results = await enhanced
|
|
122
|
+
* .query(1)
|
|
123
|
+
* .select('accountid', 'accountname')
|
|
124
|
+
* .where('statuscode').equals('1')
|
|
125
|
+
* .execute();
|
|
126
|
+
* ```
|
|
127
|
+
*
|
|
128
|
+
* @packageDocumentation
|
|
129
|
+
*/
|
|
130
|
+
|
|
131
|
+
/**
|
|
132
|
+
* Condition builder that returns SDKQueryBuilder for fluent chaining
|
|
133
|
+
*/
|
|
134
|
+
interface SDKConditionBuilder {
|
|
135
|
+
equals(value: string | number): SDKQueryBuilder;
|
|
136
|
+
notEquals(value: string | number): SDKQueryBuilder;
|
|
137
|
+
lessThan(value: string | number): SDKQueryBuilder;
|
|
138
|
+
greaterThan(value: string | number): SDKQueryBuilder;
|
|
139
|
+
lessThanOrEqual(value: string | number): SDKQueryBuilder;
|
|
140
|
+
greaterThanOrEqual(value: string | number): SDKQueryBuilder;
|
|
141
|
+
contains(value: string): SDKQueryBuilder;
|
|
142
|
+
notContains(value: string): SDKQueryBuilder;
|
|
143
|
+
startsWith(value: string): SDKQueryBuilder;
|
|
144
|
+
notStartsWith(value: string): SDKQueryBuilder;
|
|
145
|
+
isNull(): SDKQueryBuilder;
|
|
146
|
+
isNotNull(): SDKQueryBuilder;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* SDK-compatible query builder that executes via the Fireberry SDK
|
|
150
|
+
*/
|
|
151
|
+
declare class SDKQueryBuilder {
|
|
152
|
+
private builder;
|
|
153
|
+
private objectTypeId;
|
|
154
|
+
private sdk;
|
|
155
|
+
private selectedFields;
|
|
156
|
+
private pageSizeValue?;
|
|
157
|
+
private pageNum;
|
|
158
|
+
constructor(sdk: FireberrySDKAPI, objectType: number | string);
|
|
159
|
+
/**
|
|
160
|
+
* Select fields to return
|
|
161
|
+
* @param fields - Field names to include in results
|
|
162
|
+
*/
|
|
163
|
+
select(...fields: string[]): this;
|
|
164
|
+
/**
|
|
165
|
+
* Select fields with their label fields automatically included
|
|
166
|
+
* Useful for dropdown and lookup fields where you want both ID and display value
|
|
167
|
+
* @param fields - Field names to include
|
|
168
|
+
*/
|
|
169
|
+
selectWithLabels(...fields: string[]): this;
|
|
170
|
+
/**
|
|
171
|
+
* Start a WHERE condition
|
|
172
|
+
* @param field - Field name to filter on
|
|
173
|
+
*/
|
|
174
|
+
where(field: string): SDKConditionBuilder;
|
|
175
|
+
/**
|
|
176
|
+
* Add AND logical operator
|
|
177
|
+
*/
|
|
178
|
+
and(): this;
|
|
179
|
+
/**
|
|
180
|
+
* Add OR logical operator
|
|
181
|
+
*/
|
|
182
|
+
or(): this;
|
|
183
|
+
/**
|
|
184
|
+
* Set page size for pagination
|
|
185
|
+
* @param size - Number of records per page
|
|
186
|
+
*/
|
|
187
|
+
pageSize(size: number): this;
|
|
188
|
+
/**
|
|
189
|
+
* Set page number for pagination
|
|
190
|
+
* @param page - Page number (1-based)
|
|
191
|
+
*/
|
|
192
|
+
page(page: number): this;
|
|
193
|
+
/**
|
|
194
|
+
* Build the query payload without executing
|
|
195
|
+
* Useful if you want to modify the payload before sending
|
|
196
|
+
*/
|
|
197
|
+
toQueryPayload(): SDKQueryPayload;
|
|
198
|
+
/**
|
|
199
|
+
* Execute the query via the SDK
|
|
200
|
+
*/
|
|
201
|
+
execute<T = Record<string, unknown>>(): Promise<SDKResponseData<T>>;
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Creates a query builder factory bound to a Fireberry SDK instance
|
|
205
|
+
*
|
|
206
|
+
* @param sdk - Fireberry SDK client or API instance
|
|
207
|
+
* @returns Factory function that creates SDKQueryBuilder instances
|
|
208
|
+
*
|
|
209
|
+
* @example
|
|
210
|
+
* ```typescript
|
|
211
|
+
* import FireberryClientSDK from '@fireberry/sdk/client';
|
|
212
|
+
* import { createSDKQueryBuilder } from 'fireberry-api-client/sdk';
|
|
213
|
+
*
|
|
214
|
+
* const sdk = new FireberryClientSDK();
|
|
215
|
+
* await sdk.initializeContext();
|
|
216
|
+
*
|
|
217
|
+
* const queryBuilder = createSDKQueryBuilder(sdk);
|
|
218
|
+
*
|
|
219
|
+
* // Query accounts where status is active
|
|
220
|
+
* const results = await queryBuilder(1) // 1 = Account object type
|
|
221
|
+
* .select('accountid', 'accountname', 'statuscode', 'status')
|
|
222
|
+
* .where('statuscode').equals('1')
|
|
223
|
+
* .pageSize(50)
|
|
224
|
+
* .execute();
|
|
225
|
+
* ```
|
|
226
|
+
*/
|
|
227
|
+
declare function createSDKQueryBuilder(sdk: FireberrySDKClient | FireberrySDKAPI): (objectType: number | string) => SDKQueryBuilder;
|
|
228
|
+
/**
|
|
229
|
+
* Enhanced SDK wrapper that combines Fireberry SDK with utility functions
|
|
230
|
+
* Provides a more feature-rich API for working with Fireberry data
|
|
231
|
+
*/
|
|
232
|
+
declare class EnhancedSDK<TData = Record<string, unknown>> {
|
|
233
|
+
private sdk;
|
|
234
|
+
private constructor();
|
|
235
|
+
/**
|
|
236
|
+
* Create an EnhancedSDK wrapper around an existing SDK instance
|
|
237
|
+
* The SDK should already be initialized with context
|
|
238
|
+
*
|
|
239
|
+
* @param sdk - Initialized Fireberry SDK client
|
|
240
|
+
*/
|
|
241
|
+
static create<T = Record<string, unknown>>(sdk: FireberrySDKClient<T>): EnhancedSDK<T>;
|
|
242
|
+
/**
|
|
243
|
+
* Get the current context (user and record info)
|
|
244
|
+
*/
|
|
245
|
+
get context(): SDKContext | null;
|
|
246
|
+
/**
|
|
247
|
+
* Get the underlying SDK API for direct access
|
|
248
|
+
*/
|
|
249
|
+
get api(): FireberrySDKAPI<TData>;
|
|
250
|
+
/**
|
|
251
|
+
* Get the current user ID from context
|
|
252
|
+
*/
|
|
253
|
+
get userId(): string | undefined;
|
|
254
|
+
/**
|
|
255
|
+
* Get the current user's full name from context
|
|
256
|
+
*/
|
|
257
|
+
get userFullName(): string | undefined;
|
|
258
|
+
/**
|
|
259
|
+
* Get the current record ID from context
|
|
260
|
+
*/
|
|
261
|
+
get recordId(): string | undefined;
|
|
262
|
+
/**
|
|
263
|
+
* Get the current record's object type from context
|
|
264
|
+
*/
|
|
265
|
+
get recordType(): number | undefined;
|
|
266
|
+
/**
|
|
267
|
+
* Start building a query for an object type
|
|
268
|
+
*
|
|
269
|
+
* @param objectType - Object type ID (e.g., 1 for Account, 2 for Contact)
|
|
270
|
+
* @returns SDKQueryBuilder for fluent query construction
|
|
271
|
+
*
|
|
272
|
+
* @example
|
|
273
|
+
* ```typescript
|
|
274
|
+
* const results = await enhanced
|
|
275
|
+
* .query(1)
|
|
276
|
+
* .select('accountid', 'accountname')
|
|
277
|
+
* .where('ownerid').equals(enhanced.userId)
|
|
278
|
+
* .execute();
|
|
279
|
+
* ```
|
|
280
|
+
*/
|
|
281
|
+
query(objectType: number | string): SDKQueryBuilder;
|
|
282
|
+
/**
|
|
283
|
+
* Get the primary key field name for an object type
|
|
284
|
+
*
|
|
285
|
+
* @param objectType - Object type ID
|
|
286
|
+
* @returns Primary key field name (e.g., 'accountid' for type 1)
|
|
287
|
+
*
|
|
288
|
+
* @example
|
|
289
|
+
* ```typescript
|
|
290
|
+
* const idField = enhanced.getIdField(1); // 'accountid'
|
|
291
|
+
* const idField = enhanced.getIdField(2); // 'contactid'
|
|
292
|
+
* ```
|
|
293
|
+
*/
|
|
294
|
+
getIdField(objectType: number | string): string;
|
|
295
|
+
/**
|
|
296
|
+
* Get the display name field for an object type
|
|
297
|
+
*
|
|
298
|
+
* @param objectType - Object type ID
|
|
299
|
+
* @returns Name field (e.g., 'accountname' for type 1, 'fullname' for type 2)
|
|
300
|
+
*
|
|
301
|
+
* @example
|
|
302
|
+
* ```typescript
|
|
303
|
+
* const nameField = enhanced.getNameField(1); // 'accountname'
|
|
304
|
+
* const nameField = enhanced.getNameField(2); // 'fullname'
|
|
305
|
+
* ```
|
|
306
|
+
*/
|
|
307
|
+
getNameField(objectType: number | string): string;
|
|
308
|
+
/**
|
|
309
|
+
* Get the label field for a dropdown or lookup field
|
|
310
|
+
*
|
|
311
|
+
* @param fieldName - API field name
|
|
312
|
+
* @param objectType - Object type ID
|
|
313
|
+
* @returns Label field name, or empty string if not applicable
|
|
314
|
+
*
|
|
315
|
+
* @example
|
|
316
|
+
* ```typescript
|
|
317
|
+
* const labelField = enhanced.getLabelField('statuscode', 1); // 'status'
|
|
318
|
+
* const labelField = enhanced.getLabelField('ownerid', 1); // 'ownername'
|
|
319
|
+
* ```
|
|
320
|
+
*/
|
|
321
|
+
getLabelField(fieldName: string, objectType: number | string): string;
|
|
322
|
+
/**
|
|
323
|
+
* Get fields that should be excluded from * (star) queries for an object type
|
|
324
|
+
* Some fields cause API errors when included in broad queries
|
|
325
|
+
*
|
|
326
|
+
* @param objectType - Object type ID
|
|
327
|
+
* @returns Array of field names to exclude
|
|
328
|
+
*/
|
|
329
|
+
getExcludedFields(objectType: number | string): string[];
|
|
330
|
+
/**
|
|
331
|
+
* Expand field list to include label fields for dropdowns and lookups
|
|
332
|
+
*
|
|
333
|
+
* @param fields - Original field list
|
|
334
|
+
* @param objectType - Object type ID
|
|
335
|
+
* @returns Expanded field list with label fields
|
|
336
|
+
*
|
|
337
|
+
* @example
|
|
338
|
+
* ```typescript
|
|
339
|
+
* const fields = enhanced.expandFieldsWithLabels(['statuscode', 'ownerid'], 1);
|
|
340
|
+
* // Returns: ['statuscode', 'status', 'ownerid', 'ownername']
|
|
341
|
+
* ```
|
|
342
|
+
*/
|
|
343
|
+
expandFieldsWithLabels(fields: string[], objectType: number | string): string[];
|
|
344
|
+
/**
|
|
345
|
+
* Create a record
|
|
346
|
+
*
|
|
347
|
+
* @param objectType - Object type ID
|
|
348
|
+
* @param data - Record data
|
|
349
|
+
*/
|
|
350
|
+
create<T extends Record<string, unknown>>(objectType: number | string, data: T): Promise<SDKResponseData<TData>>;
|
|
351
|
+
/**
|
|
352
|
+
* Update a record
|
|
353
|
+
*
|
|
354
|
+
* @param objectType - Object type ID
|
|
355
|
+
* @param recordId - Record ID to update
|
|
356
|
+
* @param data - Updated field values
|
|
357
|
+
*/
|
|
358
|
+
update<T extends Record<string, unknown>>(objectType: number | string, recordId: string, data: T): Promise<SDKResponseData<TData>>;
|
|
359
|
+
/**
|
|
360
|
+
* Delete a record
|
|
361
|
+
*
|
|
362
|
+
* @param objectType - Object type ID
|
|
363
|
+
* @param recordId - Record ID to delete
|
|
364
|
+
*/
|
|
365
|
+
delete(objectType: number | string, recordId: string): Promise<SDKResponseData<TData>>;
|
|
366
|
+
/**
|
|
367
|
+
* Clean up the underlying SDK
|
|
368
|
+
*/
|
|
369
|
+
destroy(): void;
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
export { EnhancedSDK, type FireberrySDKAPI, type FireberrySDKClient, type SDKContext, SDKQueryBuilder, type SDKQueryPayload, type SDKResponseData, createSDKQueryBuilder };
|