Pages concernant le mot-clef mvc

Les commandes à retenir sous symfony

samedi 18 juillet 2009

Les initialisations

Les initialisations ne contiennent pas de paramètres, a part le nom des objets qui sont créés (projet, appli, module)

Générer un projet

$ ./symfony init-project room-on-line

Générer une application

$ ./symfony init-app accountancy

Avec symfony, un projet peut contenir plusieurs applications. Dans cet exemple j’ai créé une application de facturation nommée : accountancy

Générer un module

$ ./symfony init-module accountancy customer
$ ./symfony propel-generate-crud accountancy customer Customer

Les applications contiennes à leur tour des modules. Ici j’ai ajouté le module client (customer), dans l’application de facturation (accountancy)

La seconde ligne permet de générer les actions de lecture et de modification de la base. Je ne comprends pas pourquoi elles ne sont pas faites systématiquement comme en rails…

Le modèle de données

Ici j’utiliserai propel.

Éditer le modèle de données

Il faut éditer le fichier : config/schema.yml

propel:
customer:
id:            ~
pays_id: { type: integer, foreignTable: customer, foreignReference: id}
name:         { type: varchar(255), required: true }
shortname:    { type: varchar(255) }
adress:       { type: varchar(255) }
zipcode:      { type: varchar(5)   }
city:         { type: varchar(255) }
phone:        { type: varchar(15)  }
booking:
id:            ~
customer_id:   ~
date:         { type: date         }
valuation:
id:            ~
date:         { type: date         }
comment:      { type: longvarchar  }
invoice:
id:            ~
booking_id:    ~
customer_id:   ~
number:       { type: integer      }
paid_at:      { type: date         }
is_paid:      { type: boolean      }
is_cancelled: { type: boolean      }

Maintenant que le modèle de données à été édité, on va construire le modèle de données en fonction de ce fichier schema.yml.

Construire tout (les formulaires, le sql…)

$ ./symfony propel:build-all

Symfony est désormais prêt à utiliser ce modèle de données, mais il n’a pas encore appliqué le modèle à la base de données.

Injecter le code SQL dans la base de données

$ ./symfony propel:insert-sql

La base de données contient maintenant les tables du projet.

Générer des actions de test

$ ./symfony propel:generate-module accountancy customer Customer

Je viens de créer les actions CRUD (Create Read Update Delete) du module client (customer).

Ce module se trouve dans l’application accountancy, et stocke ses données dans la base Customer.

Vider le cache

$ ./symfony cc
Symfony génère énormément de fichier cache pour améliorer ses performances. Le problème c’est que ce cache doit régulièrement être vidé, notamment avant de faire un commit sur un serveur de source comme subversion.

Internationaliser

Générer ou mettre à jour un fichier de langue
$ ./symfony i18n:extract --auto-save --auto-delete accountancy fr
Mon fichier i18n français pour l’application accountancy a été regénéré avec les valeurs des templates.