Ruby on Rails
Ruby on Rails, également appelé RoR ou Rails, est un framework web libre écrit en Ruby. Il suit le motif de conception modèle-vue-contrôleur (MVC). Il propose une structure qui permet de développer rapidement et intuitivement. Cependant, il impose un grand niveau d'abstraction dans la programmation qui apporte en contrepartie l'économie d'écrire soi-même la plupart des routines obligatoires d'une application web.
Créateur | David Heinemeier Hansson |
---|---|
Développé par | David Heinemeier Hansson et la core team[1] |
Première version | |
Dépôt | github.com/rails/rails |
Assurance qualité | Intégration continue |
Écrit en | Ruby |
Environnement | Multiplate-forme |
Type | Framework Web |
Licence | Licence MIT |
Site web | rubyonrails.org |
Des sites célèbres qui utilisent Ruby on Rails sont Airbnb, Bloomberg, Crunchbase, Dribbble[2], indiexpo, GitHub[3], Twitch, Twitter[4], et aussi Shopify.
Philosophie
modifierRails est basé sur deux principes fondamentaux :
- Ne vous répétez pas : tenter autant que possible de n'avoir des éléments de l'application qu'à un seul endroit. L'architecture MVC et la métaprogrammation en Ruby peuvent faciliter cela ;
- Convention plutôt que configuration : ne préciser les éléments de configuration que s'ils ne respectent pas les conventions établies. Rails exploite cela en proposant des comportements par défaut pour la plupart de ses fonctionnalités. Cette vision sera conservée, même après la fusion avec Merb et la future modularisation du framework.
Au démarrage d'un projet Rails, peu d'éléments de configuration sont présents. Il ne contient généralement que l'identifiant et le mot de passe d'accès à la base de données, incontournables en MySQL par exemple. Toutefois on peut commencer un projet sans rien configurer, avec l'utilisation par défaut de SQLite.
Les fichiers de configuration sont de type YAML.
Histoire
modifierLa première version de Ruby on Rails date de juillet 2004. Le framework a été extrait de Basecamp[5], un outil de gestion de projets développé par David Heinemeier Hansson.
La première version stable (1.0) est sortie le .
À partir de cette date, Ruby on Rails a marqué le monde du développement web. On a vu pousser un ensemble de frameworks web Rails-like (notamment CakePHP, Symfony et CodeIgniter dans le monde PHP).
Une preview release de la version 2.0 a été annoncée[6] le . Rails 2.0 apporte principalement[6] :
- les ressources qui fournissent une architecture REST ;
- une différenciation plus claire entre les formats et les convertisseurs (un fichier
.rhtml
devient un fichier.html.erb
, c'est-à-dire un fichier interprété par eruby et dont le résultat est de l'HTML) ; - la possibilité d'utiliser des modèles comme URL (par exemple
redirect_to(person)
) ; - la gestion d'authentification HTTP basique ;
- une protection contre les attaques CSRF ;
- l'interception plus simple d'exceptions génériques ;
- le cache du résultat de certaines requêtes SQL ;
- une simplification de l'écriture de migration ;
- le déplacement dans des plugins de tous les act_as_* et des modules de base de données propriétaires ;
- le début de l'abandon de SOAP au profit de REST ;
- un nouveau système pour le déboguer qui remplace les breakpoints.
Rails 2.3 apporte l'usage du middleware Rack qui permet de gérer des requêtes de niveau serveur, et intègre un reverse proxy. Une autre modification importante est la gestion des formulaires enfants d'un objet parent (nested form).
Rails 3 est la rencontre entre Rails et Merb[7]. À la suite d'une réécriture complète, agnostique (l'API générale est déconnectée d'une bibliothèque particulière). La version 3.0 est sortie le [8].
La version 4 est sortie le et conseille l'usage de Ruby 2[9].
Rails 5 est sortie le [10]. Rails 8, la dernière version majeure, est sortie le [11].
L'architecture modèle-vue-contrôleur
modifierRails fournit des outils pour construire une architecture MVC :
- Les modèles sont les classes assurant la gestion des données. En général la structure de ces classes est déterminée automatiquement par Rails à partir d'une base de données. Les relations entre les tables sont explicitement spécifiées (has_many belongs_to). Spécifier ces relations permet à ActiveRecord de précharger des éléments de classes enfants ou parent.
- Les vues correspondent à la manière d'afficher les informations à l'utilisateur. Il s'agit généralement d'une combinaison de code HTML et de Ruby dans des fichiers .html.erb. Il est aussi possible de les programmer en Ruby pur avec Builder[12]. Enfin il existe une multitude de plugins de systèmes d'écriture de HTML simplifié, le plus connu est le HAML.
- Les contrôleurs réagissent aux actions des utilisateurs, ils vont chercher les données dans la base et les mettent à disposition des vues.
Rails permet de créer rapidement des squelettes d'un contrôleur ou d'un modèle ou d'une vue. Il s'agit généralement de code de type échafaudage (ou scaffold) qui assurent des opérations courantes sur le modèle comme l'ajout, la modification et la suppression d'enregistrements. Ces bouts de codes initiaux peuvent être adapté aux besoins spécifiques de l'application.
Rails propose également ActionMailer pour la gestion d'envoi ou réception de courriels et ActionWebService pour SOAP et XML-RPC, ainsi que ActiveRessource pour une interrogation par Web Service de type RESTful.
Rails et Ajax
modifierAjax permet de réaliser des pages dynamiques avec JavaScript et XML / JSON pour envoyer des requêtes au serveur sans recharger la page dans le navigateur. Rails offre plusieurs méthodes afin de simplifier l'utilisation d'Ajax[13]. L'apport des RJS est de permettre la génération de code JavaScript, depuis un code Ruby.
Serveur Web
modifierRails peut fonctionner avec WEBrick, le serveur HTTP fourni avec Ruby. Cette méthode est souvent utilisée pour le développement et les tests. En production, Apache, lighttpd ou encore nginx avec Mongrel ou thin sont recommandés. Il est également possible d'utiliser Unicorn, très performant dans un environnement dédié.
L'usage de FastCGI n'est plus recommandé à partir de la release 2.3. En effet la bibliothèque initiale mod_ruby avec Apache a été retravaillée, et l'interface avec Apache utilise maintenant Passenger[14]. Passenger est aussi disponible pour nginx.
Gestion de courriels (envoi et réception)
modifierLes courriels sont générés au niveau des vues. On peut ainsi créer une vue au format texte, et une vue HTML, envoyées dans le même courriel.
La gestion des pièces jointes est aussi supportée et facile d'emploi.
En ce qui concerne la gestion des courriels entrants, il est possible de créer un utilisateur virtuel dans Postfix ou sendmail. Mais le plus aisé est de contrôler une boîte mail par IMAP avec la bibliothèque native de ruby. La gestion des pièces jointes des courriels entrants utilise le même principe que les courriels générés[15].
Bases de données
modifierPlusieurs systèmes de gestion de base de données sont supportés : SQLite, MySQL, MariaDB, PostgreSQL, DB2, Oracle, Microsoft SQL Server et MongoDB.
Par défaut, SQLite3 est utilisé.
Distribution
modifierRuby on Rails est installé via le package manager RubyGems : gem install rails[16]. Le code source est également disponible sur git[17].
La distribution Instant Rails[18] propose une version pré-configurée pour Microsoft Windows de Ruby, Rails, Apache et MySQL .
Le projet Locomotive[19] proposait une installation simplifiée pour Mac OS X. Mais RoR est inclus dans les versions client et serveur de Mac OS X 10.5[20].
Ruby on Rails est également inclus dans de nombreuses distributions GNU/Linux.
RVM permet d'installer plusieurs versions de Ruby et de Rails sur la même machine. Bundler permet de gérer finement les gems d'un projet et de savoir ce qu'il est possible de mettre à jour sans casser l'application. Lorsque la mise à jour casse quelque chose dans la compatibilité et les dépendances, l'installateur averti l'usager. Si une recette manuelle est connue pour la migration, elle sera expliquée.
Éditeurs
modifier- Vim
- rails.vim[21]
- GNU Emacs
- Rinari[22], un mode Rails pour Emacs.
- meta-mode, un multi-mode majeur pour Emacs qui s'adapte localement à l'environnement dans lequel vous évoluez.
- Un mode arborescent pointer-cliquer-éditer qui permet de naviguer très rapidement, par exemple dans une architecture MVC.
- TextMate
- Aquamacs
- NetBeans
- Redcar
- Aptana
- RubyMine
- Visual Studio Code
- Sublime Text
- Atom
- Geany
- Cloud9
Voir aussi
modifierBibliographie
modifier- Dave Thomas, David Heinemeier Hansson (trad. de l'anglais), Ruby on Rails, Paris, Eyrolles, , 590 p. (ISBN 2-212-11746-9), traduction du livre Agile Web Development with Rails
- Lucas Carlson et Leonard Richardson, Ruby par l'exemple, , 867 p. (ISBN 978-2-84177-347-3)
- Eric Sarrion, Pratique de Ruby On Rails, Paris/Cambridge/Cologne etc., O'Reilly, , 579 p. (ISBN 978-2-84177-388-6)
Articles connexes
modifier- Ajax
- Radiant CMS et Redmine, des SGC utilisant RoR
Liens externes
modifier- (en) (en) Site officiel
- (en) Ruby on Rails sur GitHub
Notes et références
modifier- (en) Core team behind Ruby on Rails
- https://appsearch.org/blog/django-vs-ruby-on-rails/
- https://se-radio.net/2021/08/episode-471-jason-meller-on-choosing-the-right-tech-stack-for-a-greenfield-project/
- (en) « Breaking the Monolith at Twitch : Part One », sur twitch.tv (consulté le ).
- (en) Site officiel de Basecamp
- (en) Rails 2.0: Preview Release
- Article sur Merb et sur Rails, 24 décembre 2008
- (en) David, « Rails 3.0 : It’s ready! », sur rubyonrails.org, (consulté le ).
- (en) dhh, « Rails 4.0 : Final version released! », sur rubyonrails.org, (consulté le ).
- (en) dhh, « Rails 5.0 : Action Cable, API mode, and so much more », sur rubyonrails.org, (consulté le ).
- (en) dhh, « Toutes les versions de rails », sur rubygems.org, (consulté le ).
- (en) Projet Builder sur Rubyforge
- (en) Ajax on Rails
- (en) site de Passenger
- (en) ActionMailer API
- mais aussi aux formats zip et tarball Téléchargement sur le site officiel
- GitHub
- Site officiel d'Instant Rails
- Site officiel
- (en) Ruby on Rails will ship with OS X 10.5 (Leopard)
- (en) Rails sous Vim
- (en) « New Rinari package on marmalade-repo.org », Rails On Emacs, 18 octobre 2011.