Compare commits

...

2 Commits

Author SHA1 Message Date
Nikita Dezzpil Orlov
bcefbb7425 chore(release): 1.3.3 2021-10-13 14:56:17 +03:00
Nikita Dezzpil Orlov
e1d03577dd fix: Потерялась зависимость rfdc
fix: Исправить опечатку number_
fix: Фикс в монге, коллекцию не надо создавать до проверки уникального ключа
fix: Заменить TypeError на ErrStorage в mongo
fix: Исправить collectionName в сигнатуре remove
2021-10-13 14:56:11 +03:00
8 changed files with 38 additions and 23 deletions

View File

@ -2,6 +2,13 @@
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
### [1.3.3](https://git.archive.systems/Dezzpil/ivanovna.orm/compare/v1.3.2...v1.3.3) (2021-10-13)
### Bug Fixes
* Потерялась зависимость rfdc ([e1d0357](https://git.archive.systems/Dezzpil/ivanovna.orm/commit/e1d03577dd973c6e651a8d175fbabcf5a8c1fd53))
### [1.3.2](https://git.archive.systems/Dezzpil/ivanovna.orm/compare/v1.3.1...v1.3.2) (2021-10-05) ### [1.3.2](https://git.archive.systems/Dezzpil/ivanovna.orm/compare/v1.3.1...v1.3.2) (2021-10-05)

9
orm.d.ts vendored
View File

@ -1,10 +1,13 @@
/** @public */ /** @public */
export declare abstract class Data { export declare abstract class Data {
[key: string]: any; [key: string]: any;
/**
* @deprecated use fromObject()
*/
static assign(vo: Data, values: ValuesObject): Data; static assign(vo: Data, values: ValuesObject): Data;
set(key: string, value: any): void; set(key: string, value: any): void;
fromObject(object: ValuesObject): void; fromObject(object: ValuesObject): void;
toObject(exclude?: string[]): Record<string, any>; toObject(exclude?: string[]): ValuesObject;
abstract uniqKey(): string; abstract uniqKey(): string;
} }
@ -99,13 +102,13 @@ declare abstract class Storage_2 {
abstract save(name: string, uniqKey: string, data: Record<string, any>): Promise<string>; abstract save(name: string, uniqKey: string, data: Record<string, any>): Promise<string>;
abstract createSession(): StorageSession; abstract createSession(): StorageSession;
abstract count(name: string, query?: Record<string, any>): Promise<number>; abstract count(name: string, query?: Record<string, any>): Promise<number>;
abstract remove(collectionName: string, uniqKeyName: string, uniqKey: string): Promise<boolean>; abstract remove(name: string, uniqKey: string, uniqVal: string | number): Promise<boolean>;
} }
export { Storage_2 as Storage } export { Storage_2 as Storage }
/** @public */ /** @public */
export declare interface StorageCursor { export declare interface StorageCursor {
limit(number_: number): StorageCursor; limit(number: number): StorageCursor;
sort(parameters: Record<string, any>): StorageCursor; sort(parameters: Record<string, any>): StorageCursor;
skip(offset: number): StorageCursor; skip(offset: number): StorageCursor;
toArray(): Promise<any[]>; toArray(): Promise<any[]>;

14
package-lock.json generated
View File

@ -1,13 +1,16 @@
{ {
"name": "ivna-orm", "name": "ivna-orm",
"version": "1.3.2", "version": "1.3.3",
"lockfileVersion": 2, "lockfileVersion": 2,
"requires": true, "requires": true,
"packages": { "packages": {
"": { "": {
"name": "ivna-orm", "name": "ivna-orm",
"version": "1.3.2", "version": "1.3.3",
"license": "ISC", "license": "ISC",
"dependencies": {
"rfdc": "^1.3.0"
},
"devDependencies": { "devDependencies": {
"@jest/test-sequencer": "^27.2.3", "@jest/test-sequencer": "^27.2.3",
"@microsoft/api-extractor": "^7.18.11", "@microsoft/api-extractor": "^7.18.11",
@ -21,7 +24,6 @@
"jest-teamcity": "^1.10.0", "jest-teamcity": "^1.10.0",
"nanoid": "^3.1.28", "nanoid": "^3.1.28",
"prettier": "^2.4.1", "prettier": "^2.4.1",
"rfdc": "^1.3.0",
"standard-version": "^9.3.1", "standard-version": "^9.3.1",
"ts-jest": "^27.0.5", "ts-jest": "^27.0.5",
"ts-node": "^10.2.1", "ts-node": "^10.2.1",
@ -5658,8 +5660,7 @@
"node_modules/rfdc": { "node_modules/rfdc": {
"version": "1.3.0", "version": "1.3.0",
"resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz",
"integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA=="
"dev": true
}, },
"node_modules/rimraf": { "node_modules/rimraf": {
"version": "3.0.2", "version": "3.0.2",
@ -11393,8 +11394,7 @@
"rfdc": { "rfdc": {
"version": "1.3.0", "version": "1.3.0",
"resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz",
"integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA=="
"dev": true
}, },
"rimraf": { "rimraf": {
"version": "3.0.2", "version": "3.0.2",

View File

@ -1,6 +1,6 @@
{ {
"name": "ivna-orm", "name": "ivna-orm",
"version": "1.3.2", "version": "1.3.3",
"description": "Mini ORM for convenience", "description": "Mini ORM for convenience",
"main": "dist/index.js", "main": "dist/index.js",
"files": [ "files": [
@ -43,7 +43,6 @@
"jest-teamcity": "^1.10.0", "jest-teamcity": "^1.10.0",
"nanoid": "^3.1.28", "nanoid": "^3.1.28",
"prettier": "^2.4.1", "prettier": "^2.4.1",
"rfdc": "^1.3.0",
"standard-version": "^9.3.1", "standard-version": "^9.3.1",
"ts-jest": "^27.0.5", "ts-jest": "^27.0.5",
"ts-node": "^10.2.1", "ts-node": "^10.2.1",
@ -60,5 +59,8 @@
"semi": false, "semi": false,
"singleQuote": true, "singleQuote": true,
"tabWidth": 4 "tabWidth": 4
},
"dependencies": {
"rfdc": "^1.3.0"
} }
} }

View File

@ -7,6 +7,9 @@ export type ValuesObject = Record<string, any>
export abstract class Data { export abstract class Data {
[key: string]: any [key: string]: any
/**
* @deprecated use fromObject()
*/
static assign(vo: Data, values: ValuesObject): Data { static assign(vo: Data, values: ValuesObject): Data {
for (const key of Object.getOwnPropertyNames(values)) { for (const key of Object.getOwnPropertyNames(values)) {
vo[key] = values[key] vo[key] = values[key]
@ -26,7 +29,7 @@ export abstract class Data {
} }
} }
toObject(exclude: string[] = []): Record<string, any> { toObject(exclude: string[] = []): ValuesObject {
const object = {} as ValuesObject const object = {} as ValuesObject
for (const key of Object.getOwnPropertyNames(this)) { for (const key of Object.getOwnPropertyNames(this)) {
if (key.startsWith('__')) { if (key.startsWith('__')) {

View File

@ -1,6 +1,6 @@
/** @public */ /** @public */
export interface StorageCursor { export interface StorageCursor {
limit(number_: number): StorageCursor limit(number: number): StorageCursor
sort(parameters: Record<string, any>): StorageCursor sort(parameters: Record<string, any>): StorageCursor
skip(offset: number): StorageCursor skip(offset: number): StorageCursor
toArray(): Promise<any[]> toArray(): Promise<any[]>
@ -28,7 +28,7 @@ export abstract class Storage {
abstract count(name: string, query?: Record<string, any>): Promise<number> abstract count(name: string, query?: Record<string, any>): Promise<number>
abstract remove(collectionName: string, uniqKeyName: string, uniqKey: string): Promise<boolean> abstract remove(name: string, uniqKey: string, uniqVal: string | number): Promise<boolean>
} }
/** @public */ /** @public */

View File

@ -1,5 +1,5 @@
import { ClientSession, MongoClient, TransactionOptions } from 'mongodb' import { ClientSession, MongoClient, TransactionOptions } from 'mongodb'
import { Storage, StorageCursor, StorageSession } from '../storage' import { ErrStorage, Storage, StorageCursor, StorageSession } from '../storage'
import { ErrEntityHasNoUniqKeyValue } from '../entity' import { ErrEntityHasNoUniqKeyValue } from '../entity'
/** @public */ /** @public */
@ -36,8 +36,8 @@ export class MongoStorage extends Storage {
async save(collectionName: string, uniqKey: string, data: Record<string, any>): Promise<string> { async save(collectionName: string, uniqKey: string, data: Record<string, any>): Promise<string> {
await this._connect() await this._connect()
const id = data[uniqKey] const id = data[uniqKey]
const coll = await this._client.db().collection(collectionName)
if (id !== null && id !== undefined) { if (id !== null && id !== undefined) {
const coll = await this._client.db().collection(collectionName)
const filter = { [uniqKey]: id } const filter = { [uniqKey]: id }
const result = await coll.findOneAndReplace(filter, data, { upsert: true }) const result = await coll.findOneAndReplace(filter, data, { upsert: true })
if (result.lastErrorObject) { if (result.lastErrorObject) {
@ -48,7 +48,7 @@ export class MongoStorage extends Storage {
return result.lastErrorObject.upserted return result.lastErrorObject.upserted
} }
throw new TypeError(`can not save data to ${collectionName} with result ${result}`) throw new ErrStorage(`can not save data to ${collectionName} with result ${result}`)
} else { } else {
// Нельзя сохранить сущность без значения уникального ключа // Нельзя сохранить сущность без значения уникального ключа
// const result = await coll.insertOne(data) // const result = await coll.insertOne(data)
@ -70,8 +70,8 @@ export class MongoStorage extends Storage {
return this._client return this._client
} }
async remove(collectionName: string, uniqKeyName: string, uniqKey: string): Promise<boolean> { async remove(name: string, uniqKeyName: string, uniqKey: string): Promise<boolean> {
const coll = await this._client.db().collection(collectionName) const coll = await this._client.db().collection(name)
const result = await coll.deleteOne({ [uniqKeyName]: uniqKey }) const result = await coll.deleteOne({ [uniqKeyName]: uniqKey })
return Promise.resolve(result.acknowledged) return Promise.resolve(result.acknowledged)
} }

View File

@ -9,8 +9,8 @@ export class MapCursor implements StorageCursor {
this._map = map this._map = map
} }
limit(number_: number): StorageCursor { limit(number: number): StorageCursor {
this._limit = number_ this._limit = number
return this return this
} }
@ -67,7 +67,7 @@ export class MapStorage extends Storage {
return Promise.resolve(0) return Promise.resolve(0)
} }
async remove(collectionName: string, uniqKeyName: string, uniqKey: string): Promise<boolean> { async remove(name: string, uniqKeyName: string, uniqKey: string): Promise<boolean> {
return Promise.resolve(true) return Promise.resolve(true)
} }