« Ruby On Rails » : différence entre les versions

De Lea Linux
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
 
Aucun résumé des modifications
Ligne 8 : Ligne 8 :


== Avant propos ==
== Avant propos ==
Ruby On Rails (RoR) est un framework web écrit en ruby. Ce document vous présente comment faire un petit projet Ruby On Rails.


On supposera installé et correctement configuré :
On supposera installé et correctement configuré :
Ligne 27 : Ligne 29 :
</code>
</code>
Le répertoire monsite vient d'être créé ainsi que la structure initiale du projet. Entrez maintenant dans ce répertoire.
Le répertoire monsite vient d'être créé ainsi que la structure initiale du projet. Entrez maintenant dans ce répertoire.
 
Normalement, il devrait contenir les fichiers et répertoires suivants :
<code>app
<code>app
components
components
Ligne 193 : Ligne 195 :


=== Edition des modèles ===
=== Edition des modèles ===
Intéressons-nous aux fichiers <code>./app/models/auteur.rb</code> et <code>./app/models/livre.rb</code>. Ces classes héritant de ActiveRecord::Base, presque tout est déjà fait. Nous allons juste ajouter la relation : "un auteur écrit plusieurs livres". Cette relation se traduit dans <code>./app/models/auteur.rb</code> par :
<code>class Auteur < ActiveRecord::Base
has_many :livre
end</code>
En contrepartie, on peut avoir besoin d'accéder à l'auteur d'un livre. Modifions donc <code>./app/models/livre.rb</code> en :
<code>class Livre < ActiveRecord::Base
belongs_to :auteur
end</code>
Et voilà ! Ca devrait suffir pour les modèles. En effet, Rails fera tout seul le lien entre les deux tables grâce à auteur_id.
== Création d'un contrôleur ==
Tout d'abord, utilisons, comme pour les modèles, le script <code>./script/generate</code> :
<code>$ ./script/generate controller bibliotheque
      exists  app/controllers/
      exists  app/helpers/
      create  app/views/bibliotheque
      exists  test/functional/
      create  app/controllers/bibliotheque_controller.rb
      create  test/functional/bibliotheque_controller_test.rb
      create  app/helpers/bibliotheque_helper.rb</code>
Editons maintenant <code>./app/controllers/bibliotheque_controller.rb</code>. Par défaut, vous avez :
<code>class BibliothequeController < ApplicationController
end</code>


Nous allons créer des actions. Un contrôleur peut comporter plusieurs actions.
<code>class BibliothequeController < ApplicationController
def index
listeAuteur
render_action 'listeAuteur'
end


def listeAuteur
@auteurs = Auteur.find(:all, :order => "nom,prenom")
end
def ajoutAuteur
param = @params['auteur']
auteur = Auteur.new(param)
if auteur.save
flash[:ok] = "L'auteur a &eacute;t&eacute; ajout&eacute;"
else
flash[:error] = "Probl&egrave;me à l'ajout de l'auteur"
end
# ajoutAuteur n'a pas besoin de vue. Une fois l'auteur ajouté
# on réaffiche la liste
redirect_to :action => 'listeAuteur'
end
end
</code>


== Création du/des controleur(s) ==
L'action index est l'action par défaut. L'action listeAuteur donnera la liste des auteurs. On constate ici qu'on peut largement se passer d'écrire du SQL dans Rails. @auteurs est une variable qui contiendra tous les auteurs.


== Mise en place des vues ==
== Mise en place des vues ==
=== Le layout ===
Tout d'abord, créons une layout. Le layout est la structure commune à toutes les pages. Ils se trouvent dans <code>./app/views/layouts/</code>.
<code>$ touch app/views/layouts/bibliotheque.rhtml
</code>
Editons maintenant ce fichier :
<code><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//FR" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
        <title>Biblioth&egrave;que - <%= controller.action_name %></title>
        <meta name="author" content="GEDsismik">
        <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15">
</head>
<body>
        <h1>Biblioth&egrave;que</h1>
        <br/>
        <div class="all">
        <p style="color: green"><%= flash[:notice] %></p>
        <%= @content_for_layout %>
        </div>
</body>
</html></code>
C'est du Ruby embarqué dans du HTML. Pour ceux qui connaissent, c'est un peu le même principe que le PHP. On écrit du HTML et aux endroits où on veut mettre du ruby, on place le code dans une balise <code><% #code %></code>. Si on veut afficher la sortie du code, on place le code dans une balise <code><%= #code %></code>.
<code><%= @content_for_layout %></code> affichera la partie propre à l'action.
=== La vue ===
Les vues sont dans un répertoire de la forme <code>./app/views/<contrôleur>/</code> et porte le nom <code><action>.rhtml</code>
Créons donc le fichier <code>./app/views/bibliotheque/listeAuteur.rhtml</code> :
<code><h2>Liste des auteurs</h2>
<ul>
<%
@auteurs.each do |auteur|
%><li><%= auteur.nom + " " + auteur.prenom %></li><%
end
%>
</ul>
<h2>Ajout d'un auteur</h2>
<%= start_form_tag :action => "ajoutAuteur" %>
<p><label>Pr&eacute;nom : <%= text_field 'auteur', 'prenom' %></label></p>
<p><label>Nom : <%= text_field 'auteur', 'nom' %></label></p>
<%= submit_tag("Ajouter") %>
<%= end_form_tag %></code>
== WebRick ==
Vous disposez d'un serveur de test appellé WebRick. Pour le lancez, tapez <code>./script/server </code>
<code>$ ./script/server
=> Booting WEBrick...
=> Rails application started on http://0.0.0.0:3000
=> Ctrl-C to shutdown server; call with --help for options
[2006-10-19 18:32:57] INFO  WEBrick 1.3.1
[2006-10-19 18:32:57] INFO  ruby 1.8.5 (2006-08-25) [i686-linux]
[2006-10-19 18:32:57] INFO  WEBrick::HTTPServer#start: pid=26166 port=3000</code>
Par défaut, ce serveur écoute le port 3000. Ouvrez donc un navigateur et tapez : <code>http://localhost:3000</code>.
Normalement, vous devriez obtenir une page de test. Les url de Rails par défaut se décompose de la sorte <code>http://localhost:3000/<contrôleur>/<action>[/<parametres>]</code>. Tapez donc dans votre navigateur <code>http://localhost:3000/bibliotheque/listeAuteur</code>.
== Les environnements ==
= Copyright =
Copyright &copy; 19/10/2006, GEDsismik
{{CC-BY-NC-SA}}

Version du 19 octobre 2006 à 21:01

Ruby On Rails

Ruby On Rails
Monter un projet Ruby On Rails (RoR) pas à pas.

Avant propos

Ruby On Rails (RoR) est un framework web écrit en ruby. Ce document vous présente comment faire un petit projet Ruby On Rails.

On supposera installé et correctement configuré :

- un SGBD supporté par RoR (personnellement, j'utilise MySQL)
- Ruby
- Rails et ses dépendances

Il vous faudra aussi des notions de ruby.

Mise en place de l'environnement

$ rails monsite

     create  
     create  app/controllers
     create  app/helpers
     create  app/models
     create  app/views/layouts

[...] Le répertoire monsite vient d'être créé ainsi que la structure initiale du projet. Entrez maintenant dans ce répertoire. Normalement, il devrait contenir les fichiers et répertoires suivants : app components config db doc lib log public Rakefile README script test tmp vendor

Configuration

Si vous n'avez pas de base de donnée, créez-en : mysql> create database monsite_development; mysql> create database monsite_test; mysql> create database monsite_production;

Note : J'en ai crée 3 pour pouvoir utiliser 3 environnements différents. Une seule peut suffir, ca dépend de ce que vous voulez faire.

Nous allons ensuite éditer ./config/database.yml. Vous avez 3 environnements de pré-configurées de la sorte : production:

 adapter: mysql
 database: monsite_production
 username: root
 password:
 host: localhost

Editez-le en fonction des paramètres de votre base de donnée production:

 adapter: mysql
 database: monsite_production
 username: gedsismik
 password: mypassord
 host: localhost
 socket: /var/run/mysql/mysql.sock

Note : Sous Slackware, j'ai du ajouter la ligne socket: /var/run/mysql/mysql.sock sinon il ne trouve pas la socket MySQL.

Modèle MVC

Ruby On Rails utilise le motif de conception MVC (modèle-vue-contrôleur). Je m'explique : dans un projet RoR, vous séparez :

- les modèles (répertoire ./app/models) : ce qui concerne les données. Dans notre cas, c'est donc principalement les tables des bases de données.
- les vues (répertoire ./app/views) : ce qui concerne l'interface. Dans notre cas, il s'agit de la présentation des pages (en HTML et Ruby embarqué, nous verrons ça plus tard).
- les contrôleurs (répertoire ./app/controllers) : concerne la gestion des évenements. Dans notre cas, ce sont les classes qui feront le lien entre les tables (models) et le html (views). Ce qui revient aux appels aux tables via les modèles et la création de variables dont le contenu sera affiché dans les vues.

Pour palier à certaines fonctions qui ne peuvent pas suivre le modèle MVC à la lettre, Rails dispose d'une partie appelée helpers (./app/helpers) qui contient des classes accessibles aux vues et qui contient du code ayant accès aux modèles sans passer par les contrôleurs.

Création des modèles

Génération des fichiers relatifs à la table

On va utilisez le script ./script/generate pour générer la première table.

$ ./script/generate model livre

     exists  app/models/
     exists  test/unit/
     exists  test/fixtures/
     create  app/models/livre.rb
     create  test/unit/livre_test.rb
     create  test/fixtures/livres.yml
     create  db/migrate
     create  db/migrate/001_create_livres.rb

$ ./script/generate model auteur

     exists  app/models/
     exists  test/unit/
     exists  test/fixtures/
     create  app/models/auteur.rb
     create  test/unit/auteur_test.rb
     create  test/fixtures/auteurs.yml
     exists  db/migrate
     create  db/migrate/002_create_auteurs.rb

Fichiers de migration

Les fichiers de migration/création de table se trouvent dans ./db/migrate. Il va falloir les éditez pour ajoutez les champs que vous voulez.

Note : ne faites pas de champ "id", ils sont automatiquement créés et gérer par Rails.

Fichier ./db/migrate/001_create_livres.rb

class CreateLivres < ActiveRecord::Migration def self.up create_table :livres do |t| t.column :titre, :string, :null => false t.column :auteur_id, :integer, :null => false t.column :quantite, :integer, :default => "1" end end

def self.down drop_table :livres end end

Fichier ./db/migrate/002_create_auteurs.rb

class CreateAuteurs < ActiveRecord::Migration def self.up create_table :auteurs do |t| t.column :nom, :string t.column :prenom, :string end end

def self.down drop_table :auteurs end end


Notez que vous pouvez réunir les deux fichiers en un seul :

./db/migrate/001_initial.rb class Initial < ActiveRecord::Migration def self.up create_table :livres do |t| t.column :titre, :string, :null => false t.column :auteur_id, :integer, :null => false t.column :quantite, :integer, :default => "1" end create_table :auteurs do |t| t.column :nom, :string, :null => false t.column :prenom, :string end end

def self.down drop_table :livres drop_table :auteurs end

end

Génération des tables

Toujours dans le repertoire monsite, exécutez rake migrate. $ rake migrate (in /home/gedsismik/monsite)

CreateLivres: migrating ==================================================

-- create_table(:livres)

  -> 0.0441s

CreateLivres: migrated (0.0442s) =========================================

CreateAuteurs: migrating =================================================

-- create_table(:auteurs)

  -> 0.0457s

CreateAuteurs: migrated (0.0458s) ========================================

Si vous regardez dans votre base de donnée, vous trouverez donc 3 tables :

- auteurs
- livres
- schema_info

Cette dernière table contient en fait la version de la base de donnée. Les versions sont incrémentées lors du ./script/generate model <nom table> et sont contenus dans le nom du fichier ./db/migrate/001_initial.rb est donc la version 1 de la base.

Edition des modèles

Intéressons-nous aux fichiers ./app/models/auteur.rb et ./app/models/livre.rb. Ces classes héritant de ActiveRecord::Base, presque tout est déjà fait. Nous allons juste ajouter la relation : "un auteur écrit plusieurs livres". Cette relation se traduit dans ./app/models/auteur.rb par : class Auteur < ActiveRecord::Base has_many :livre end

En contrepartie, on peut avoir besoin d'accéder à l'auteur d'un livre. Modifions donc ./app/models/livre.rb en : class Livre < ActiveRecord::Base belongs_to :auteur end

Et voilà ! Ca devrait suffir pour les modèles. En effet, Rails fera tout seul le lien entre les deux tables grâce à auteur_id.

Création d'un contrôleur

Tout d'abord, utilisons, comme pour les modèles, le script ./script/generate : $ ./script/generate controller bibliotheque

     exists  app/controllers/
     exists  app/helpers/
     create  app/views/bibliotheque
     exists  test/functional/
     create  app/controllers/bibliotheque_controller.rb
     create  test/functional/bibliotheque_controller_test.rb
     create  app/helpers/bibliotheque_helper.rb

Editons maintenant ./app/controllers/bibliotheque_controller.rb. Par défaut, vous avez : class BibliothequeController < ApplicationController end

Nous allons créer des actions. Un contrôleur peut comporter plusieurs actions. class BibliothequeController < ApplicationController def index listeAuteur render_action 'listeAuteur' end

def listeAuteur @auteurs = Auteur.find(:all, :order => "nom,prenom") end

def ajoutAuteur param = @params['auteur'] auteur = Auteur.new(param) if auteur.save flash[:ok] = "L'auteur a été ajouté" else flash[:error] = "Problème à l'ajout de l'auteur" end # ajoutAuteur n'a pas besoin de vue. Une fois l'auteur ajouté # on réaffiche la liste redirect_to :action => 'listeAuteur' end end

L'action index est l'action par défaut. L'action listeAuteur donnera la liste des auteurs. On constate ici qu'on peut largement se passer d'écrire du SQL dans Rails. @auteurs est une variable qui contiendra tous les auteurs.

Mise en place des vues

Le layout

Tout d'abord, créons une layout. Le layout est la structure commune à toutes les pages. Ils se trouvent dans ./app/views/layouts/. $ touch app/views/layouts/bibliotheque.rhtml Editons maintenant ce fichier : <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//FR" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head>

       <title>Bibliothèque - <%= controller.action_name %></title>
       <meta name="author" content="GEDsismik">
       <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15">

</head> <body>

Bibliothèque

       

<%= flash[:notice] %>

       <%= @content_for_layout %>

</body> </html> C'est du Ruby embarqué dans du HTML. Pour ceux qui connaissent, c'est un peu le même principe que le PHP. On écrit du HTML et aux endroits où on veut mettre du ruby, on place le code dans une balise <% #code %>. Si on veut afficher la sortie du code, on place le code dans une balise <%= #code %>.

<%= @content_for_layout %> affichera la partie propre à l'action.

La vue

Les vues sont dans un répertoire de la forme ./app/views/<contrôleur>/ et porte le nom <action>.rhtml

Créons donc le fichier ./app/views/bibliotheque/listeAuteur.rhtml :

Liste des auteurs

    <% @auteurs.each do |auteur| %>
  • <%= auteur.nom + " " + auteur.prenom %>
  • <% end %>

Ajout d'un auteur

<%= start_form_tag :action => "ajoutAuteur" %>

<label>Prénom : <%= text_field 'auteur', 'prenom' %></label>

<label>Nom : <%= text_field 'auteur', 'nom' %></label>

<%= submit_tag("Ajouter") %> <%= end_form_tag %>

WebRick

Vous disposez d'un serveur de test appellé WebRick. Pour le lancez, tapez ./script/server $ ./script/server => Booting WEBrick... => Rails application started on http://0.0.0.0:3000 => Ctrl-C to shutdown server; call with --help for options [2006-10-19 18:32:57] INFO WEBrick 1.3.1 [2006-10-19 18:32:57] INFO ruby 1.8.5 (2006-08-25) [i686-linux] [2006-10-19 18:32:57] INFO WEBrick::HTTPServer#start: pid=26166 port=3000

Par défaut, ce serveur écoute le port 3000. Ouvrez donc un navigateur et tapez : http://localhost:3000. Normalement, vous devriez obtenir une page de test. Les url de Rails par défaut se décompose de la sorte http://localhost:3000/<contrôleur>/<action>[/<parametres>]. Tapez donc dans votre navigateur http://localhost:3000/bibliotheque/listeAuteur.

Les environnements

Copyright

Copyright © 19/10/2006, GEDsismik

Creative Commons License
Creative Commons Attribution iconCreative Commons Share Alike iconCreative Commons Noncommercial
Ce document est publié sous licence Creative Commons
Attribution, Partage à l'identique, Contexte non commercial 2.0 :
http://creativecommons.org/licenses/by-nc-sa/2.0/fr/