npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

nest-typeorm-factory

v1.0.1

Published

Here’s a comprehensive documentation for your `nestjs-handler-factory` package, highlighting installation, usage, and case scenarios for all API features.

Downloads

135

Readme

Here’s a comprehensive documentation for your nestjs-handler-factory package, highlighting installation, usage, and case scenarios for all API features.


NestJS Handler Factory Documentation

nestjs-handler-factory is a utility package designed to streamline CRUD operations and advanced filtering in NestJS applications that use TypeORM. This package provides convenient handler functions for retrieving, creating, updating, and deleting records, with support for filtering, pagination, sorting, field selection and populating inter-table relationships.


Table of Contents

  1. Installation
  2. Usage
  3. API Operations
  4. Advanced Query Options
  5. Error Handling
  6. Examples

Installation

To use nest-typeorm-factory in your NestJS project, install it via npm:

npm install nest-typeorm-factory

Ensure you have TypeORM set up in your project, as it’s required for the package to function with your repositories.


Usage

Import the package and utilize it within your NestJS service to handle common database operations.

Let's create 2 entities, one for Post, the other for User

The User

import { Entity, PrimaryGeneratedColumn, Column, OneToMany } from 'typeorm';
import { Post } from './post.entity';

@Entity()
export class User {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  name: string;

  @Column()
  email: string;

  @OneToMany(() => Post, post => post.user)
  posts: Post[];
}

The Post

import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from 'typeorm';
import { User } from './user.entity';

@Entity()
export class Post {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  title: string;

  @Column()
  content: string;

  @Column({ default:0 })
  reposts: number;

  @Column({ default: () => 'CURRENT_TIMESTAMP' })
  createdAt: Date;

  @ManyToOne(() => User, user => user.posts)
  user: User;
}

⚠️ Warning:
When creating your entities be sure to add createdAt field.

Step 1: Import the Package and Interfaces

import { Repository } from 'typeorm';
import { Injectable } from '@nestjs/common';

import { InjectRepository } from '@nestjs/typeorm';

//DTOs
import { CreatePostDto } from './dto/create-post.dto';
import { UpdatePostDto } from './dto/update-post.dto';

//Entities
import { Post } from './entities/post.entity';

//Package
import { factory, IQuery } from 'nest-typeorm-factory';

Step 2: Define a Service with Repository Injection

@Injectable()
export class PostService {
  constructor(
    @InjectRepository(Post) private postRepository: Repository<Post>
  ) {}

  // CRUD operations implemented using factory functions from nestjs-handler-factory
}

API Operations

Creating a Record

Use the createOne function to create a new record. This method takes a repository instance and the data to create as arguments.

async create(createPostDto: CreatePostDto) {
  return factory.createOne(this.postRepository, createPostDto);
}

Retrieving All Records with Filters

Retrieve a list of records with advanced query options by using getAll.

async findAll(query: Partial<IQuery>) {
  return factory.getAll(this.postRepository, query);
}

Retrieving a Single Record

Use getOne to retrieve a single record by its ID.

async findOne(id: string) {
  return factory.getOne(this.postRepository, id);
}

Updating a Record

Use updateOne to update an existing record by its ID.

async update(id: string, updatePostDto: UpdatePostDto) {
  return factory.updateOne(this.postRepository, id, updatePostDto);
}

Deleting a Record

Use deleteOne to delete a record by its ID.

async remove(id: string) {
  return factory.deleteOne(this.postRepository, id);
}

Controller Setup

Making use of the package, this is what your controller will look like.

import {
  Get,
  Post,
  Body,
  Query,
  Patch,
  Param,
  Delete,
  Controller,
} from '@nestjs/common';

import { PostService } from './post.service';
import { CreatePostDto } from './dto/create-post.dto';
import { UpdatePostDto } from './dto/update-post.dto';

import { IQuery } from 'nest-typeorm-factory';

@Controller('posts')
export class PostController {
  constructor(private readonly postService: PostService) {}

  @Post()
  async create(@Body() createPostDto: CreatePostDto) {
    return this.postService.create(createPostDto);
  }

  @Get()
  async findAll(@Query() query: IQuery) {
    return this.postService.findAll(query);
  }

  @Get(':id')
  async findOne(@Param('id') id: string, @Query() query: IQuery) {
    return this.postService.findOne(id, query);
  }

  @Patch(':id')
  async update(@Param('id') id: string, @Body() updatePostDto: UpdatePostDto) {
    return this.postService.update(id, updatePostDto);
  }

  @Delete(':id')
  async remove(@Param('id') id: string) {
    return this.postService.remove(id);
  }
}

Advanced Query Options

Each function supports a set of advanced query options, which include filtering, sorting, pagination, and more.

Filtering

Filter results based on fields that are an exact match.

GET /posts?title=NestJS

Advanced Filtering

Filter results with advanced options like greater than, less than, greater than or equals, less than or equals.

GET /posts?gt=reposts,50
GET /posts?gte=reposts,50
GET /posts?lt=reposts,50
GET /posts?lte=reposts,50

Sorting

Sort records using asc-fieldName or desc-fieldName.

GET /posts?sort=asc-title

OR

GET /posts?sort=desc-createdAt

⚠️ Note:
If no sort parameter is passed in, it will sort by the createdAt property by default.

Field Selection

Limit the fields returned by specifying fields.

GET /posts?fields=title,createdAt

Pagination

Control pagination with page and limit.

GET /posts?page=2&limit=5

Searching

Use the search parameter to match keywords like so.

GET /posts?search=fieldA,searchTermA
GET /posts?search=title,JavaScri

Multiple Field Searching

You can also search against multiple fields.

GET /posts?search=fieldA,searchTermA-fieldB,searchTermB
GET /posts?search=title,JavaScri-content,variables

Range Queries

Retrieve records that have the value of a particular field within a range.

GET /posts?range=reposts,5-50

Populate Relationship

Populate Inter Table relationships while querying records. This works for all kinds of relationships, i.e One-To-One, Many-To-One, One-To-Many and Many-To-Many

GET /posts?relations=user

Populate Multiple Relationships

Supposing our entity has multiple relationships with other tables. This is how we'll do it

GET /posts?relations=user,fieldB,fieldC

The same also works for getting a resource by id

GET /posts/{id}?relations=user
GET /posts/{id}?relations=user,fieldB,fieldC

Combining Multiple API Features

You can combine multiple API features together like so

GET /posts?title=JavaScri&reposts=5&relations=user&page=2&sort=desc-createdAt

Error Handling

The package provides consistent error handling with descriptive messages for missing records, invalid parameters, and other common issues.

Common Errors

  1. 404 Not Found - Record does not exist.
  2. 400 Bad Request - Invalid parameters provided.

Examples

Create Post

Request

POST /posts
Content-Type: application/json

{
  "title": "My NestJS Post",
  "content": "Exploring the nestjs-handler-factory package."
  "userId": "67890"
}

Response

{
  "status": "success",
  "data": {
    "id": "12345",
    "title": "My NestJS Post",
    "content": "Exploring the nestjs-handler-factory package."
    "user": {
      "id": "67890",
      "name": "John Doe",
      "email": "[email protected]"
    }
  }
}

Get All Posts with Filters

Request

GET /posts?sort=asc-title&page=1&limit=10&search=title,NestJS

Response

{
  "status": "success",
  "data": [
    {
      "id": "12345",
      "title": "My NestJS Post",
      "createdAt": "2023-11-01T10:00:00Z"
    }
  ]
}

Update Post

Request

PATCH /posts/12345
Content-Type: application/json

{
  "title": "Updated NestJS Post Title"
}

Response

{
  "status": "success",
  "data": {
    "id": "12345",
    "title": "Updated NestJS Post Title",
    "updatedAt": "2023-11-01T10:30:00Z"
  }
}

Delete Post

Request

DELETE /posts/12345

Response

{
  "status": "success",
  "message": "Post deleted successfully"
}

License

nestjs-handler-factory is open-source software licensed under the MIT License.


For issues or contributions, visit GitHub Repository.