You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
35 lines
880 B
TypeScript
35 lines
880 B
TypeScript
import { query } from "./lib/clickhouse";
|
|
import { publicProcedure, RpcType, router } from "./trpc";
|
|
import { Object as ObjectT, String as StringT } from "@sinclair/typebox";
|
|
|
|
export const getChartData = publicProcedure
|
|
.input(
|
|
RpcType(
|
|
ObjectT({
|
|
underlying: StringT({ maxLength: 5 }),
|
|
lookbackPeriodStart: StringT(),
|
|
lookbackPeriodEnd: StringT(),
|
|
})
|
|
)
|
|
)
|
|
.query(async (opts) => {
|
|
const { underlying, lookbackPeriodStart, lookbackPeriodEnd } = opts.input;
|
|
return await query<[number, number]>(
|
|
`
|
|
SELECT
|
|
toUnixTimestamp(tsStart) as x,
|
|
open as y
|
|
FROM stock_aggregates
|
|
WHERE symbol = '${underlying}'
|
|
AND tsStart >= '${lookbackPeriodStart} 00:00:00'
|
|
AND tsStart <= '${lookbackPeriodEnd} 00:00:00'
|
|
ORDER BY x ASC
|
|
`,
|
|
"JSONEachRow"
|
|
);
|
|
});
|
|
|
|
export default router({
|
|
getChartData,
|
|
});
|