Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahmedadelfahim/objectionjs-repository
Repository pattern implementation on top of KnexJS and ObjectionJS
https://github.com/ahmedadelfahim/objectionjs-repository
database knexjs nodejs objectionjs repository-pattern
Last synced: 9 days ago
JSON representation
Repository pattern implementation on top of KnexJS and ObjectionJS
- Host: GitHub
- URL: https://github.com/ahmedadelfahim/objectionjs-repository
- Owner: AhmedAdelFahim
- License: mit
- Created: 2023-02-23T08:25:22.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-11-14T13:14:15.000Z (about 2 months ago)
- Last Synced: 2024-12-15T07:35:56.475Z (19 days ago)
- Topics: database, knexjs, nodejs, objectionjs, repository-pattern
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/objectionjs-repository
- Size: 646 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ObjectionJS Repository
ObjectionJS Repository is repository pattern implementation on top of [KnexJS](https://www.npmjs.com/package/knex) and [ObjectionJS](https://www.npmjs.com/package/objection)
[![Latest Stable Version](https://img.shields.io/npm/v/objectionjs-repository.svg?style=for-the-badge)](https://www.npmjs.com/package/objectionjs-repository)
[![License](https://img.shields.io/npm/l/objectionjs-repository.svg?style=for-the-badge)](https://www.npmjs.com/package/objectionjs-repository)
[![NPM Downloads](https://img.shields.io/npm/dt/objectionjs-repository.svg?style=for-the-badge)](https://www.npmjs.com/package/objectionjs-repository)
[![NPM Downloads](https://img.shields.io/npm/dm/objectionjs-repository.svg?style=for-the-badge)](https://www.npmjs.com/package/objectionjs-repository)
## Content1. [Installation](https://www.npmjs.com/package/objectionjs-repository#installation)
1. [Usage](https://www.npmjs.com/package/objectionjs-repository#usage)
1. [API](https://www.npmjs.com/package/objectionjs-repository#api)
1. [getOne](https://www.npmjs.com/package/objectionjs-repository#getoneconditions-options)
1. [getAll](https://www.npmjs.com/package/objectionjs-repository#getallconditions-options)
1. [create](https://www.npmjs.com/package/objectionjs-repository#createdata-options)
1. [createMany](https://www.npmjs.com/package/objectionjs-repository#createmanydata-options)
1. [update](https://www.npmjs.com/package/objectionjs-repository#updateconditions-data-options)
1. [delete](https://www.npmjs.com/package/objectionjs-repository#deleteconditions-options)
1. [Options](https://www.npmjs.com/package/objectionjs-repository#options)
1. [Tests](https://www.npmjs.com/package/objectionjs-repository#tests)
1. [Support](https://www.npmjs.com/package/objectionjs-repository#support)## Installation
```bash
$ npm i objectionjs-repository
```## Usage
```javascript
// Define Interface
export interface IUser {
id: number;
age: number;
name: string;
}// Define Model
export default class User extends Model {
static get tableName() {
return TABLES.USER;
}
}// Define Repository
import { BaseRepository } from 'objectionjs-repository';export class UserRepository extends BaseRepository {
constructor(knexInstance: Knex) {
super(User, knexInstance);
}
}```
then you can use defined repository
```javascript
const userRepo = new UserRepository(knexInstance);
const user = await userRepo.getOne({ age: 25 })
```## API
#### getOne(conditions, [options])
conditions is object contains any column in this table.
options is **IFindingOptions**.
return selected row or undefined
#### getAll(conditions, [options])
conditions is object contains any column in this table.
options is **IFindingOptions**.
return selected rows or empty array.#### create(data, [options])
data to be inserted.
options is **ICreationOptions**.#### createMany(data, [options])
array to be inserted.
options is **ICreationOptions**.#### update(conditions, data, [options])
conditions is object contains any column in this table.
data to be updated.
options is **IUpdatingOptions**.#### delete(conditions, [options])
conditions is object contains any column in this table.
options is **IDeletionOptions**.## Options
#### IFindingOptions
```javascript
IFindingOptions {
// select specific columns
select?: string[];
// database Transaction
trx?: Knex.Transaction;
// lock selected rows or not
forUpdate?: boolean;
// select where column not in array
whereNotIn?: {
field: string;
values: any;
}[];
// select where column in array
whereIn?: {
field: string;
values: any;
}[];
// select where columns is null
whereNull?: string[];
// select where columns is not null
whereNotNull?: string[];
}
```#### ICreationOptions
```javascript
ICreationOptions {
// database Transaction
trx?: Knex.Transaction;
}
```#### IUpdatingOptions
```javascript
IUpdatingOptions {
// database Transaction
trx?: Knex.Transaction;
// select where column not in array
whereNotIn?: {
field: string;
values: any;
}[];
// select where column in array
whereIn?: {
field: string;
values: any;
}[];// select where columns is null
whereNull?: string[];
// select where columns is not null
whereNotNull?: string[];
}
```#### IDeletionOptions
```javascript
IDeletionOptions {
// database Transaction
trx?: Knex.Transaction;
// select where column not in array
whereNotIn?: {
field: string;
values: any;
}[];
// select where column in array
whereIn?: {
field: string;
values: any;
}[];
// select where columns is null
whereNull?: string[];
// select where columns is not null
whereNotNull?: string[];
}
```## Tests
To run the test suite, first install the dependencies and rename .env.sample to .env and set connection url for postgres database in .env then run `npm test`:
```bash
$ npm install
$ npm test
```## Support
Feel free to open issues on [github](https://github.com/AhmedAdelFahim/objectionjs-repository).