Skip to content

3rd Web Project - Ecole 42 : Popcorn-time like website - stream and download movies scrapped from YTS and 1337x

Notifications You must be signed in to change notification settings

nristorc/Hypertube

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HYPERTUBE - ECOLE 42

Projet réalisé dans le cadre de notre formation à l'école 42 - dernier projet de la branche Web avant stage
Objectifs: Framework MVC - Omniauth - Background jobs - Internationalisation
Compétences: Group & interpersonal - Web - DB & Data\

Documentation API: Postman

Credit to: acoulomb - akarasso - dlaurent - nristorc

Technologies utilisées

  • API RESTful
  • Serveur: NodeJS - Framework Express
  • Client: ReactJS - Redux
  • Base de données: MongoDB

Table des matières

Preview

Vidéo de présentation Hypertube

Login Page Screen 1

Films Populaires (Home) Films Populaires (Home)

Recherche Recherche

Page Film Page Film

Page Utilisateur Page utilisateur

Watchlist Watchlist

Introduction

Ce projet propose de créer une application web permettant à un utilisateur de rechercher et visionner des vidéos. Le lecteur sera directement intégré au site, et les vidéos seront téléchargées au travers du protocole BitTorrent. Le moteur de recherche interrogera plusieurs sources externes de votre choix, comme par exemple http://www.legittorrents.info. Une fois un élément sélectionné, il sera téléchargé sur le serveur et diffusé sur le player web en même temps. Autrement dit, le lecteur ne se contentera pas d’afficher la vidéo une fois le téléchargement complété, mais sera capable de streamer directement le flux.

Consignes générales

Tous les framework, micro-framework, librairies etc... sont autorisés dans la limite où ils ne servent pas à créer un flux vidéo à partir d’un torrent. :warning: Par exemple, des librairies comme webtorrent, pulsar ou peerflix sont interdites. :iphone: Votre site devra être présentable sur mobile, et garder une mise en page acceptable sur de petites résolutions.

Partie utilisateur

  • L’application doit permettre à un utilisateur de s’inscrire avec:

    • adresse email
    • login
    • photo de profil
    • nom
    • prénom
    • mot de passe
  • ⚠️ L’utilisateur doit pouvoir s’inscrire et se connecter via Omniauth.

    • Deux stratégie obligatoire, 42 et une autre au choix.
  • L’utilisateur doit être capable de se connecter avec:

    • login
    • mot de passe
  • Il doit également pouvoir recevoir un mail de réinitialisation de son mot de passe en cas d’oubli.

  • L’utilisateur doit pouvoir se déconnecter en un seul clic depuis n’importe quelle page du site.

  • ⚠️ L’utilisateur doit pouvoir sélectionner une langue préférée par défaut l’anglais.

  • L’utilisateur doit pouvoir Modifier son adresse email, sa photo de profil et ses informations.

  • Consulter le profil d’un autre utilisateur. C’est à dire afficher sa photo de profil, ses informations. *L’ email, en revanche, doit rester privé.

Partie bibliothèque

⚠️ Cette partie ne doit être accessible qu’aux utilisateurs connectés.

ℹ️ Cette partie doit présenter au minimum :

  • Un champ de recherche.
  • Une liste de miniatures.

Recherche

Le moteur de recherche devra interroger au moins deux sources externes de votre choix, et retourner l’ensemble des résultats sous la forme de miniatures. Vous devez limiter les résultats aux vidéos uniquement.

Miniatures

  • Si une recherche a été faite, les résultats doivent s’afficher sous la forme d’une liste de miniatures, triées par nom.

  • Si aucune recherche n’a été faite, vous devrez afficher les médias les plus populaires de vos sources externes, triés selon le critère de votre choix (téléchargements, peers, seeders, etc...).

  • ℹ️ Une miniature doit être composée de:

    • nom de la vidéo
    • année de production
    • note
    • image de couverture

⚠️ Vous devrez différencier les vidéos vues des vidéos non-vues, de la manière de votre choix.

⚠️ La liste devra être paginée, à chaque fin de page, la suivante doit être automatiquement chargée de manière asynchrone. Autrement dit, il ne doit pas y avoir de lien pour chaque page.

ℹ️ La liste devra être triable et filtrable selon des critères tels que le nom, le genre, un intervalle de note, un intervalle d’année de production, etc...

Partie vidéo

⚠️ Cette partie ne doit être accessible qu’aux utilisateurs connectés.

Cette section devra présenter le détail d’une vidéo, c’est à dire:

  • afficher le player de la vidéo.
  • ℹ️ si disponible
    • le résumé
    • le casting (au moins producteur, réalisateur, acteurs principaux, etc...)
    • l’année de production
    • la durée
    • la note
    • une image de couverture et tout ce qui vous semblerait pertinent.

⚠️ Vous devez également donner aux utilisateurs la possibilité de laisser un commentaire sur la vidéo, et afficher la liste des commentaires précédents.

ℹ️ Lancer la vidéo sur le navigateur doit - si le fichier n’a pas déjà été téléchargé précédemment - lancer le téléchargement du torrent associé sur le serveur, et streamer le flux vidéo depuis ce dernier dès que suffisament de données sont téléchargées pour assurer la lecture intégrale de la vidéo sans interruption. Bien évidemment, tout le traitement doit être fait en arrière plan de manière non-bloquante.

ℹ️ Une fois un film téléchargé intégralement, il doit être sauvegardé sur le serveur, de manière à ne pas re-télécharger un film plusieurs fois. :warning: Si un film n’est pas visionné pendant un mois, il devra être supprimé.

⚠️ Si des sous-titres anglais sont disponibles pour cette vidéo, ils devront être téléchargés et sélectionnables sur le player vidéo. De même, si la langue de la vidéo ne correspond pas à la langue préférée de l’utilisateur, et que des sous-titres sont disponibles pour cette langue, ils devront également être téléchargés et sélectionnables.

Si la vidéo n’est pas nativement lisible pour le navigateur(c-ad que ce n’est ni dump4, ni du webm). vous devrez la convertir à la volée dans un format acceptable. Le support du format mkv est un minimum.

Partie bonus

  • Ajouter des stratégies Omniauth supplémentaires. done : Github, Gitlab, Facebook
  • Gérer différentes résolutions de vidéo.
  • Développer une API RESTful. done
  • Streamer la vidéo via l’API MediaStream.

Bonus supplémentaires effectués

  • Creation d'un server d'authentification indépendant done: methode password et authorization_code
  • Documentation API done
  • Marquer les films à voir plus tard par l'utilisateur (watchlist)

About

3rd Web Project - Ecole 42 : Popcorn-time like website - stream and download movies scrapped from YTS and 1337x

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published