@e22m4u/js-repository-mongodb-adapter
Version:
MongoDB адаптер для @e22m4u/js-repository
80 lines (59 loc) • 1.85 kB
Markdown
## @e22m4u/js-repository-mongodb-adapter
MongoDB адаптер для [@e22m4u/js-repository](https://www.npmjs.com/package/@e22m4u/js-repository)
## Установка
```bash
npm install @e22m4u/js-repository-mongodb-adapter
```
## Параметры
Все указанные параметры опциональны:
| название | значение по умолчанию |
|----------|-----------------------|
| protocol | `'mongodb'` |
| host | `'127.0.0.1'` |
| port | `27017` |
| database | `'database'` |
| username | `undefined` |
| password | `undefined` |
Пример:
```js
import {DatabaseSchema} from '@e22m4u/js-repository';
const dbs = new DatabaseSchema();
// объявление источника
dbs.defineDatasource({
name: 'myMongo', // название источника
adapter: 'mongodb', // имя адаптера
// параметры
host: '127.0.0.1',
port: 27017,
database: 'myDatabase',
});
// объявление модели
dbs.defineModel({
name: 'user', // название модели
datasource: 'myMongo', // используемый источник (см. выше)
properties: { // поля модели
name: 'string',
surname: 'string',
},
});
// получаем репозиторий по названию модели и создаем запись
const userRep = dbs.getRepository('user');
const user = await userRep.create({name: 'John', surname: 'Doe'});
console.log(user);
// {
// id: '64f3454e5e0893c13f9bf47e',
// name: 'John',
// surname: 'Doe',
// }
```
## Тесты
Запуск контейнера `mongo:latest` скриптом `setup.sh`
```bash
./setup.sh
```
Выполнение тестов
```bash
npm run test
```
## Лицензия
MIT