Skip to content

This is a movie project that aims to create a GraphQL web service with various features similar to Netflix. It is built using GraphQL, TypeScript, and Prisma ORM. The project provides functionality to manage movies, categories, actors, directors, comments, and more.

License

Notifications You must be signed in to change notification settings

BaseMax/MovieTSGraphQL

Repository files navigation

MovieTSGraphQL

MovieTSGraphQL is a GraphQL web service built using NestJS, Prisma ORM, PostgreSQL, and Minio. The project provides functionality to manage movies, categories, actors, directors, comments, and more. It aims to create a web service with various features similar to Netflix.

Demo

Features

  • Manage movies, categories, actors, directors, comments, and more.
  • Secure authentication and authorization system.
  • GraphQL API for easy integration with any frontend framework.
  • Optimized for high performance and scalability.

Authentication

Authentication is done through an Authorization Header using a Bearer token. The token can be obtained by calling the login and register mutations.

Once the token is obtained, it needs to be included in the Authorization Header of all subsequent GraphQL requests. The app validates the token and restricts access to certain mutations and queries based on the token's permissions.

Some mutations and queries require higher privileges, such as a specific role, to be executed. These operations can only be performed by users with the required privileges.

example Header :

Authorization: Bearer <token>

File upload

This app supports file upload through a dedicated endpoint at /upload/<type>/<name-prefix>. The uploaded file will be resized to a specific size based on the chosen type. Currently, the supported types and sizes are:

  • avatar: { width: 512, height: 512 }
  • gallery: { width: 1920, height: 1080 }
  • backdrop: { width: 1920, height: 1080 }
  • poster: { width: 600, height: 900 }

To upload a file, you should make a POST request to the /upload/<type>/<name-prefix> endpoint with the file contents as the request body. The request body should be a binary file, not multipart form data.

The <type> parameter specifies the type of the uploaded file, while the <name-prefix> parameter is used to generate a unique filename for the uploaded file. The uploaded file will be resized and saved to the server, and the response will contain a JSON object with the URL of the uploaded file. For example:

{"url":"/poster/testtt-cliiy9tkb000015ln9byqftw4.jpeg"}

You can use the returned URL wherever a file is required in your application.

Stack

  • NestJS: A Node.js framework for building efficient and scalable server-side applications. It provides a modular architecture that allows developers to easily organize their code and use a wide range of plugins.
  • Prisma ORM: A modern database toolkit that provides a type-safe and intuitive way to access databases. It supports multiple databases and provides features like migrations, schema generation, and query building.
  • PostgreSQL: A powerful open-source relational database management system that provides features like triggers, transactions, and foreign key constraints. It is widely used in enterprise applications.
  • Minio: A high-performance distributed object storage server that provides features like versioning, lifecycle management, and access control. It is compatible with Amazon S3 API and provides a scalable and cost-effective solution for storing and retrieving large amounts of data.

Usage

To use this project, follow these steps:

  1. Clone this repository:
git clone https://github.com/BaseMax/MovieTSGraphQL
  1. Install dependencies:
npm install
  1. Run the app using Docker Compose:
sudo docker-compose -f docker-compose.dev.yml up

This will start the app in development mode, with hot-reloading enabled. The GraphQL playground will be available at http://localhost:3000/graphql.

  1. Attach to the container:
sudo docker exec -it movietsgraphql-app-1 bash
  1. Create an admin account:
dsconfig

npx nest start --entryFile create-admin.js

It will prompt you for an email, password, and name to create the superuser account.

Examples

Here are some example GraphQL queries and mutations that can be used with this project:

  1. Get all genres:
query {
  genres {
    id
    name
  }
}
  1. Get a specific genre:
query {
  genre(id: "1") {
    id
    name
  }
}
  1. Search for artists:
query {
  searchArtists(input: {text: "Tom"}) {
    total
    artists {
      id
      name
    }
  }
}
  1. Get a specific movie:
query {
  movie(id: "1") {
    id
    name
    plot
    description
    imdbScore
    imdbRef
    duration
    releaseDate
    backdrop
    poster
    gallery
    genres {
      id
      name
    }
    artists {
      artist {
        id
        name
      }
      contribution
    }
    downloadableAssets {
      title
      link
      type
    }
    languages {
      tag
      for
    }
  }
}
  1. Create a new movie:
mutation {
  createMovie(input: {
    name: "Movie Name"
    plot: "Movie Plot"
    description: "Movie Description"
    imdbScore: 8.5
    imdbRef: "https://www.imdb.com/title/tt1375666/"
    duration: 120
    releaseDate: "2022-01-01T00:00:00Z"
    backdrop: "/backdrop/backdrop.jpeg"
    poster: "/poster/poster.jpeg"
    gallery: ["/gallery/gallery1.jpeg", "/gallery/gallery2.jpeg"]
    genreIds: ["1", "2"]
    artists: [{
      artistId: "1"
      contribution: director
    }]
    downloadableAssets: [{
      title: "Subtitle"
      link: "/subtitle/subtitle.vtt"
      type: subtitle
    }]
    languages: [{
      tag: "en-US"
      for: original
    }]
  }) {
    id
    name
  }
}
  1. Update a movie:
mutation {
  updateMovie(input: {
    id: "1"
    name: "New Movie Name"
    plot: "New Movie Plot"
    description: "New Movie Description"
    imdbScore: 9.0
    imdbRef: "https://www.imdb.com/title/tt1375667/"
    duration: 150
    releaseDate: "2022-02-02T00:00:00Z"
    backdrop: "/backdrop/newbackdrop.jpeg"
    poster: "/poster/newposter.jpeg"
    gallery: ["/gallery/newgallery1.jpeg", "/gallery/newgallery2.jpeg"]
    genreIds: ["2", "3"]
    artists: [{
      artistId: "2"
      contribution: actor
    }]
    downloadableAssets: [{
      title: "Sound"
      link: "/sound/sound.mp3"
      type: sound
    }]
    languages: [{
      tag: "fr-FR"
      for: dub
    }]
  }) {
    id
    name
  }
}

API Documentation

Here is a table describing all mutations and queries available in this project:

Type Name Arguments Return Type Description
Query user User! Returns the currently logged in user
Query genres [Genre!]! Returns a list of all genres
Query genre id: String! Genre Returns the genre with the specified ID
Query artist id: String! Artist Returns the artist with the specified ID
Query searchArtists input: SearchArtistInput! PaginatedArtist! Returns a list of artists that match the search criteria
Query movie id: String! Movie Returns the movie with the specified ID
Query searchMovie input: SearchMovieInput! PaginatedMovies! Returns a list of movies that match the search criteria
Query unapprovedComments pagination: CursorBasedPagination! [Comment!]! Returns a list of unapproved comments, with pagination
Mutation register input: RegisterUserInput! AuthPayload! Registers a new user
Mutation login input: LoginUserInput! AuthPayload! Logs in a user
Mutation changeRole userId: String!, role: Role! User! Changes the role of a user
Mutation createGenre input: CreateGenreInput! Genre! Creates a new genre
Mutation updateGenre input: UpdateGenreInput! Genre! Updates an existing genre
Mutation deleteArtist id: String! Boolean! Deletes an artist with the specified ID
Mutation createArtist input: CreateArtistInput! Artist! Creates a new artist
Mutation updateArtist input: UpdateArtistInput! Artist! Updates an existing artist
Mutation createMovie input: CreateMovieInput! Movie! Creates a new movie
Mutation updateMovie input: UpdateMovieInput! Movie! Updates an existing movie
Mutation deleteMovie id: String! Boolean! Deletes a movie with the specified ID
Mutation createComment input: CreateCommentInput! Comment! Creates a new comment
Mutation updateComment input: UpdateCommentInput! Comment! Updates an existing comment
Mutation deleteComment id: String! Boolean! Deletes a comment with the specified ID
Mutation approveComment id: String! Comment! Approves a comment with the specified ID

License

This project is licensed under the GPL-3 license. Contributions are welcome! Please submit any issues or pull requests to the GitHub repository.

About

This is a movie project that aims to create a GraphQL web service with various features similar to Netflix. It is built using GraphQL, TypeScript, and Prisma ORM. The project provides functionality to manage movies, categories, actors, directors, comments, and more.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •