diff --git a/packages/sequelize/README.md b/packages/sequelize/README.md new file mode 100644 index 000000000..edc03f059 --- /dev/null +++ b/packages/sequelize/README.md @@ -0,0 +1,7 @@ +### Quick info + +1. Recommended to use combination of Sequelize and Sequelize-Typescript packages +2. Session model needs to implement all properties from ISession interface +3. Mark "key" property of Session model as unique (it's required for Sequelize "upsert" method to work) + +Code, docs and examples will be updates ASAP diff --git a/packages/sequelize/src/ISession.ts b/packages/sequelize/src/ISession.ts new file mode 100644 index 000000000..93b827a45 --- /dev/null +++ b/packages/sequelize/src/ISession.ts @@ -0,0 +1,5 @@ +export interface ISession { + id: number; + key: string; + value: string; +} diff --git a/packages/sequelize/src/index.ts b/packages/sequelize/src/index.ts new file mode 100644 index 000000000..fc6c11d5a --- /dev/null +++ b/packages/sequelize/src/index.ts @@ -0,0 +1,28 @@ +import { StorageAdapter } from 'grammy' +import { Repository } from 'sequelize-typescript' + +export class SequelizeAdapter implements StorageAdapter { + private repository: Repository + + constructor (options: { repository: Repository }) { + this.repository = options.repository + } + + async read (key: string) { + const session = await this.repository.findOne({ where: { key: key } }) + if (session === null || session === undefined) { + return undefined + } + return JSON.parse(session.value) as unknown as T + } + + async write (key: string, value: T) { + const jsonValue = JSON.stringify(value) + await this.repository.upsert({key: key, value: jsonValue}) + } + + async delete (key: string) { + await this.repository.destroy({ where: { key: key } }) + } + +}