TenantAtlas/apps/platform/.pnpm-store/v10/files/e1/70d52bca4e35067cb8470b3d086c422ef2c8d7f948f63bc45278822ab8f3cfbc7ba88138cba0af9be413331f70ee2cfaf2e71fdb6f7e11d22218b665515b2f
Ahmed Darrazi 9f74f7a658
Some checks failed
PR Fast Feedback / fast-feedback (pull_request) Failing after 51s
feat: compress governance operator outcomes
2026-04-19 14:15:11 +02:00

49 lines
1.3 KiB
Plaintext

import { entityKind } from "../../entity.js";
import { SQL, sql } from "../../sql/sql.js";
class MySqlCountBuilder extends SQL {
constructor(params) {
super(MySqlCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);
this.params = params;
this.mapWith(Number);
this.session = params.session;
this.sql = MySqlCountBuilder.buildCount(
params.source,
params.filters
);
}
sql;
static [entityKind] = "MySqlCountBuilder";
[Symbol.toStringTag] = "MySqlCountBuilder";
session;
static buildEmbeddedCount(source, filters) {
return sql`(select count(*) from ${source}${sql.raw(" where ").if(filters)}${filters})`;
}
static buildCount(source, filters) {
return sql`select count(*) as count from ${source}${sql.raw(" where ").if(filters)}${filters}`;
}
then(onfulfilled, onrejected) {
return Promise.resolve(this.session.count(this.sql)).then(
onfulfilled,
onrejected
);
}
catch(onRejected) {
return this.then(void 0, onRejected);
}
finally(onFinally) {
return this.then(
(value) => {
onFinally?.();
return value;
},
(reason) => {
onFinally?.();
throw reason;
}
);
}
}
export {
MySqlCountBuilder
};
//# sourceMappingURL=count.js.map