Skip to content

Commit

Permalink
feat: Add datastore count API (#93)
Browse files Browse the repository at this point in the history
* Docs: Add datastore.count/query field descriptions
  • Loading branch information
cyungslack authored Mar 13, 2024
1 parent fcb40ae commit 185ddda
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 3 deletions.
53 changes: 50 additions & 3 deletions src/typed-method-types/apps.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,22 @@ import {
} from "../types.ts";

// apps.datastore Types
type DynamoQueryArgs = {
/**
* @description A query filter expression
* @see {@link https://api.slack.com/automation/datastores-retrieve#filter-expressions}.
*/
expression?: string;
/**
* @description A map of attributes referenced in `expression`
*/
"expression_attributes"?: Record<string, string>;
/**
* @description A map of values referenced in `expression`
*/
"expression_values"?: Record<string, string | boolean | number>;
};

export type DatastoreSchema = {
name: string;
// deno-lint-ignore no-explicit-any
Expand Down Expand Up @@ -182,14 +198,12 @@ export type DatastoreQueryArgs<
> =
& BaseMethodArgs
& CursorPaginationArgs
& DynamoQueryArgs
& {
/**
* @description The name of the datastore
*/
datastore: Schema["name"];
expression?: string;
"expression_attributes"?: Record<string, string>;
"expression_values"?: Record<string, string | boolean | number>;
};

export type DatastoreQueryResponse<
Expand All @@ -208,6 +222,33 @@ export type DatastoreQueryResponse<
items: DatastoreItem<Schema>[];
};

export type DatastoreCountArgs<
Schema extends DatastoreSchema,
> =
& BaseMethodArgs
& DynamoQueryArgs
& {
/**
* @description The name of the datastore
*/
datastore: Schema["name"];
};

export type DatastoreCountResponse<
Schema extends DatastoreSchema,
> =
& BaseResponse
& {
/**
* @description The name of the datastore
*/
datastore: Schema["name"];
/**
* @description The number of items matching your query
*/
count: number;
};

export type DatastoreDeleteArgs<
Schema extends DatastoreSchema,
> =
Expand Down Expand Up @@ -293,6 +334,11 @@ export type AppsDatastoreQuery = {
args: DatastoreQueryArgs<Schema>,
): Promise<DatastoreQueryResponse<Schema>>;
};
export type AppsDatastoreCount = {
<Schema extends DatastoreSchema>(
args: DatastoreCountArgs<Schema>,
): Promise<DatastoreCountResponse<Schema>>;
};
export type AppsDatastoreDelete = {
<Schema extends DatastoreSchema>(
args: DatastoreDeleteArgs<Schema>,
Expand Down Expand Up @@ -368,6 +414,7 @@ export type TypedAppsMethodTypes = {
bulkPut: AppsDatastoreBulkPut;
update: AppsDatastoreUpdate;
query: AppsDatastoreQuery;
count: AppsDatastoreCount;
delete: AppsDatastoreDelete;
bulkDelete: AppsDatastoreBulkDelete;
};
Expand Down
1 change: 1 addition & 0 deletions src/typed-method-types/mod.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ export const methodsWithCustomTypes = [
"apps.datastore.bulkPut",
"apps.datastore.update",
"apps.datastore.query",
"apps.datastore.count",
"apps.auth.external.get",
"apps.auth.external.delete",
"chat.postMessage",
Expand Down
1 change: 1 addition & 0 deletions src/typed-method-types/typed-method-tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ Deno.test("Custom Type Methods are valid functions", () => {
assertEquals(typeof client.apps.datastore.bulkPut, "function");
assertEquals(typeof client.apps.datastore.update, "function");
assertEquals(typeof client.apps.datastore.query, "function");
assertEquals(typeof client.apps.datastore.count, "function");
assertEquals(typeof client.apps.auth.external.get, "function");
assertEquals(typeof client.apps.auth.external.delete, "function");
assertEquals(typeof client.workflows.triggers.create, "function");
Expand Down

0 comments on commit 185ddda

Please sign in to comment.