diff --git a/src/contracts-api/stream.ts b/src/contracts-api/stream.ts index a2f19e7..5220074 100644 --- a/src/contracts-api/stream.ts +++ b/src/contracts-api/stream.ts @@ -515,4 +515,35 @@ export class Stream { ) .throw(); } + + /** + * A custom method that accepts the procedure name and the input of GetRecordInput + * Returns the result of the procedure in the same format as StreamRecord + * I.e. a custom procedure named "get_price" that returns a list of date_value and value + * can be called with customGetProcedure("get_price", { dateFrom: "2021-01-01", dateTo: "2021-01-31" }) + */ + public async customGetProcedure( + procedure: string, + input: GetRecordInput, + ): Promise { + const result = await this.call<{ date_value: string; value: string }[]>( + procedure, + [ + ActionInput.fromObject({ + $date_from: input.dateFrom, + $date_to: input.dateTo, + $frozen_at: input.frozenAt, + $base_date: input.baseDate, + }), + ], + ); + return result + .mapRight((result) => + result.map((row) => ({ + dateValue: row.date_value, + value: row.value, + })), + ) + .throw(); + } } diff --git a/tests/integration/primitiveStream.test.ts b/tests/integration/primitiveStream.test.ts index 1800c82..6cc5a36 100644 --- a/tests/integration/primitiveStream.test.ts +++ b/tests/integration/primitiveStream.test.ts @@ -57,6 +57,20 @@ describe.sequential( expect(records[0].value).toBe("1.000000000000000000"); expect(records[0].dateValue).toBe("2020-01-01"); + // Use Custom Procedure with the same name "get_record" + const customRecords = await primitiveStream.customGetProcedure( + "get_record", + { + dateFrom: "2020-01-01", + dateTo: "2021-01-01", + }, + ); + + // Verify record content from the custom procedure + expect(customRecords.length).toBe(1); + expect(customRecords[0].value).toBe("1.000000000000000000"); + expect(customRecords[0].dateValue).toBe("2020-01-01"); + // Query index const index = await primitiveStream.getIndex({ dateFrom: "2020-01-01",