Ressources :
Vous travaillez pour une entreprise qui souhaite mettre en place un système de Storage as a service (STaaS), permettant de mettre à disposition de ses clients un stockage de fichiers à distance. Vous êtes en charge d'une partie de l'application web permettant de gérer ce service.
Les clients peuvent disposer d'espaces de stockage (nommés disques) permettant de stocker leurs données. Chaque disque est loué à un certain tarif par le client ; le tarif comprend :
Le client a la possibilité de changer de tarif à tout moment pour chaque disque, de façon à diminuer ou augmenter son quota, en fonction de ses besoins. L'historique des tarifs associés à un disque est conservé.
Le tarif courant appliqué à un disque est celui correspondant à la date la plus récente.
Chaque location de disque peut être associée à des services (backup, loadBalancer…).
L'historique d'occupation des disques est obtenu de manière automatisée par un script PHP lancé de manière quotidienne par une tâche CRON.
//TODO 4.1
Dans la table Disque_tarif, sont stockés les tarifs appliqués à un disque à partir d'une certaine date (champ startDate). Le tarif actuel d'un disque correspond donc au dernier tarif appliqué, celui dont la startDate est la plus récente.
En utilisant les relations définies sur les modèles, et en privilégiant une approche objet, implémentez la méthode retournant le tarif actuel d'un disque dans la classe ModelUtils :
/** * Retourne le tarif appliqué actuellement à $disque * @param Disque $disque * @return Tarif tarif actuel de $disque */ public static function getDisqueTarif($disque){ //TODO }
//TODO 4.2
A l'adresse MyDisques/index, on souhaite afficher les disques de l'utilisateur actuellement connecté.
L'utilisateur connecté est obtenu par l'appel de la méthode Auth::getUser($controller) où $controller est le contrôleur actif.
Elément | Indications |
---|---|
Contrôleur | MyDisques |
Action | index |
Utilisateur connecté | L'utilisateur connecté est obtenu par l'appel de la méthode Auth::getUser($controller) où $controller est le contrôleur actif. |
Occupation, Quota | le quota est obtenu sur le tarif actuel du disque, la classe ModelUtils permet de connaître l'occupation en cours du disque |
Composants visuels Bootstrap | on pourra utiliser les composants Phalcon-Jquery htmlProgressbar, htmlGlyphButton, htmlListgroup |
Accès à la config du cloud | Les disques clients sont localisés dans le dossier public/files de l'application, et les disques y sont localisés sous le nom : $cloud→prefix-[disque.nom]. Cette configuration est définie dans le fichier de config.php dans la variable cloud, accessible depuis les contrôleurs par $this→config→cloud |
Tailles en octets | Vous pourrez utiliser la méthode sizeConverter de ModelUtils |
Le style des progressbars doit donner une indication sur le taux d'occupation en % :
Style | Valeurs |
---|---|
info | de 0 à 10% |
success | de 10 à 50% |
warning | de 50 à 80% |
danger | plus de 80% |
Le composant HtmlProgressbar dispose d'une méthode setStyleLimits permettant de modifier le style de la progressbar en fonction de sa valeur
//TODO 4.3
Apportez les modifications aux relations du modèle Disque pour pouvoir accéder à ses services (ManyToMany ?).
A l'adresse Scan/:idDisque, afficher l'interface suivante :
Elément | Indications |
---|---|
Contrôleur | Scan |
Action | index |
Paramètre | idDisque |
Utilisateur connecté | L'utilisateur connecté est obtenu par l'appel de la méthode Auth::getUser($controller) où $controller est le contrôleur actif. |
Occupation, Quota | le quota est obtenu sur le tarif actuel du disque, la classe ModelUtils permet de connaître l'occupation en cours du disque |
Composants visuels Bootstrap | on pourra utiliser les composants Phalcon-Jquery htmlLabel, htmlGlyphButton, htmlListgroup |
L'indicateur d'occupation (htmlLabel) doit donner une indication sur le taux d'occupation en % :
Texte | Style | Valeurs |
---|---|---|
Peu occupé | info | de 0 à 10% |
RAS | success | de 10 à 50% |
Forte occupation | warning | de 50 à 80% |
Proche saturation | danger | plus de 80% |
//TODO 4.4.1
A partir de l'adresse Disques/frm
Afficher le formulaire de création d'un disque.
Soumettre le formulaire à l'adresse Disques/update pour créer le disque puis rediriger vers l'adresse Scan/index/:idDisque
Penser à le créer physiquement.
A partir de l'adresse Scan/index/:idDisque
Implémenter la modification du nom d'un Disque (avec renommage éventuel du dossier associé + vérification du nom)
URL | Accès | Résultat/message |
---|---|---|
Disques/index | Accessible uniquement pour un utilisateur connecté | Affiché message sur l'absence de connexion et proposer la connexion |
Scan/index/:idDisque | Accessible uniquement pour un disque appartenant à l'utilisateur connecté | Afficher un message d'erreur “Accès à une ressource non autorisée” |
Utiliser le dispatcher phalcon pour ce faire.