De l’utilisation de Clonezilla

    13:15 5 06 2014

Deux articles intéressants sur l’utilisation de CloneZilla viennent d’être publiés sur le blog de la société AlliaForm. Pour rappel, clonezilla est une distribution linux permettant de gérer la sauvegarde / restauration de disques ou de partitions sous la forme d’images.

voici les liens vers les deux articles :

http://www.alliaform.fr/clonezilla-gestion-image-ordinateurs-salle-formation

http://www.alliaform.fr/personnaliser-clonezilla

Bonne lecture!



Soirée PHP exceptionnelle à Bordeaux le 4 Juin

    23:49 23 05 2012

A l’occasion du Forum PHP 2012, EPITECH Bordeaux et le Php User Group de Bordeaux s’associent pour vous proposer une soirée exceptionnelle de conférences gratuites le lundi 4 Juin à partir du 18h00.

IMPORTANT : Entrée gratuite sur inscription : http://www.eventbrite.fr/event/3605729835

Au programme :

Eric COLINET – Industrialisation PHP chez Orange
Le nombre d’applications d’importance écrites en PHP n’a cessé d’augmenter au sein de chez Orange (plus de 600). Aujourd’hui des entités internes de développement sont dédiées au développement de projets PHP, le groupe a donc dû s’adapter et mettre en place des procédures d’industrialisation prenant en compte l’historique de cette filière issue d’applications développées sur un coin de table.
Dans cette présentation nous verrons ce que le Centre de Compétences PHP apporte à l’industrialisation de cette filière afin de garantir un bon niveau de qualité et de performance dans un contexte humain et technique complexe et varié.
Nous verrons les divers problèmes rencontrés lors de l’adaptation des pratiques et habitudes de chacun afin que ce cheminement se passe dans les meilleures conditions.

Rasmus LERDORF – état de l’art de PHP en 2012

Rasmus Lerdorf, créateur de la plateforme  PHP, dressera l’  « Etat de l’art de PHP en 2012 » à la veille du forum PHP organisé par l’AFUP à Paris.

Cette conférence en anglais sera retransmise en direct depuis Paris dans le grand amphi d’Epitech Bordeaux.

Ces deux conférences seront suivis d’un cocktail permettant d’échanger entre professionnels du secteur dans le cadre agréable du campus technologique d’Epitech Bordeaux.

IMPORTANT : Entrée gratuite sur inscription : http://www.eventbrite.fr/event/3605729835



Apéro PHP à Bordeaux lundi 20 Février

    19:35 17 02 2012

Le PUG Bordeaux organise un nouvel apéro PHP au bar « La Cassolette » ce lundi 20 Février à partir de 19h.

Au programme :

  • création de l’antenne locale de l’AFUP
  • préparation du premier Dojo PHP
  • des bières et de la bonne humeur

Venez nombreux, moi j’y serais avec quelques goodies PHP à distribuer aux plus vaillants (stickers PHP et Elephpants, tours de cou,etc.. glanés lors de diverses conférences).

 

Plus d’infos sur le site du PUG : http://bordeauxpug.org/

 

 



C’est parti pour le forum PHP 2012

    18:06 17 01 2012

Le Forum PHP 2012 organisé tous les ans par l’AFUP vient d’être annoncé!

L’édition de cette année qui se déroulera les 5 et 6 Juin à la cité Universitaire Internationale aura pour thèmes « la performance, la qualité et les nouveaux usages ».

Pour ceux qui souhaitent y participer en tant que speaker, l’appel à conférencier est ouvert jusqu’au 29 février 2012 à cette adresse :

http://www.afup.org/pages/forumphp2012/appel-a-conferenciers.php

 

Maintenant organisé en alternance avec le PHP Tour, le Forum PHP quitte la période hivernale pour se dérouler dans un climat plus agréable et donc plus propice aux apéros ;-)

 



Free refond son site mobile en utilisant la méthodologie « La Rache »

    10:36 12 01 2012

Comme annoncé hier, free est en train de refondre son site http://mobile.free.fr afin de supporter la charge induite par leur annonce de forfait tout compris à 15,99€. JSP ne tenait pas le coup, qu’à cela ne tienne, on passe à PHP.

Les services sont montés et remis en ligne au fur et à mesure. Hier nous avons d’abord eu droit à la partie inscription pour les freenautes avec son lot de bugs notamment dans la validation des ribs (relevés d’identités bancaires) ce qui a rendu un paquet de monde hystérique au point de chercher des solutions pour générer de faux ribs permettant de valider leur inscription.

Ce matin c’est la partie inscription pour les non freenautes qui a été mise en ligne. Espérons que cela se déroule mieux pour eux.

En tout cas, ces mises en ligne nous permettent de comprendre un peu mieux comment fonctionnent les équipes de développement de Free. Si vous allez faire un tour sur la partie inscription pour les non frenautes (rapidement, car j’imagine que ce bug va vite disparaître), vous pourrez voir que le lien, en haut de page qui mène vers la section « Espace abonné » pointe en fait vers http://localhost:8080/moncompte/.

Quoi? Pas de tests chez Free? Du développement en local qui semble directement passer en production sans passer par un serveur de dev. ou de pré-prod?

Tout cela ressemble bien à la méthodologie « La Rache » qui permet de produire vite mais sans trop s’attarder sur la qualité du code :)

Ceci dit, et étant donné, d’une part, le contexte dans lequel ce site est redéveloppé et, d’autre part, la simplicité du code à produire, je crois que la décision peut se justifier.

J’en déduis également que la prochaine étape sera donc la remise en ligne de la partie « abonnés ».  Les premiers isncrits pourront  enfin valider que la procédure a bien été prise en compte correctement.

Quoi qu’il en soit, et en toute franchise, je tire mon chapeau à Free qui a pris un décision difficile (refonte du site) en un temps record et qui est pas loin de gagner son pari!



Surchargé, Free passe le site sur son offre mobile de Jsp vers PHP dans la nuit

    15:43 11 01 2012

Face à la surcharge de son site mobile et son incapacité à remonter la platforme, Free a migré le site de JSP vers PHP dans la nuit.
Apparemment, seule la partie réservée aux personnes déjà abonnées à la Freebox a été mise en ligne, les autres parties du site devraient arriver au fur et à mesure.

Encore un preuve de la haute performance et du Time To Market record de notre langage préféré!

Plus de détails :

http://www.journaldugeek.com/2012/01/11/free-mobile-24-heures-apres-refait-son-site/



créer un sommaire avec liens en utilisant FPDF

    13:15 18 12 2011

 

Dernier volet de mes tutoriels sur l’utilisation de FPDF avec PHP, nous allons voir aujourd’hui comment générer un sommaire avec des liens dans un document PDF.

FPDF propose nativement des méthodes pour générer des liens internes dans un  document :

 

  • addlink() qui créé un lien et retourne son identifiant. Pour le moment, notre lien n’est qu’une ressource, il va maintenant falloir l’associer à un texte et ensuite préciser où ce lien doit pointer. Pour cela, il faut utiliser par exemple, la méthode cell() (qui permet d’écrire du texte) en lui passant en paramètre  l’identifiant du lien.

 

  • SetLink() va enfin nous permettre de préciser la destination du lien. Nous l’utiliserons sur la page où le lien doit pointer

 

Le mode de fonctionnement de FPDF nous impose de créer les page les unes après les autres. Une fois une page créé, il n’est pas possible de revenir dessus. Il devient donc évident que, dans le cadre d’un sommaire, nous allons d’abord devoir créer tous les liens (un par entrée de notre sommaire), puis, page par page, assigner la destination de ces liens.
La première étape va donc consister a créer un conteneur pour stocker tous nos liens. Nous allons donc ajouter un nouvel attribut, en l’occurrence un tableau, à notre classe FPDF :
class myfpdf extends fpdf {
    public $myLinks = array();
}

Au moment de générer notre sommaire, nous allons créer les liens et les ajouter, un par un à notre tableau. Voici un exemple de code à adapter à votre document :

<?php
...
//le numéro de la page
$numPage = 1;

//le titre de la page
$titrePage = 'première page';

//on créé un lien
$fpdi->myLinks[$numPage] = $fpdi->addLink();

// on écrit le nom de la page et on y associe le lien
$fpdi->cell(185,5,$titrePage,0,0,'L',$fpdi->myLinks[$numPage];

//on écrit le numéro de la page
$fpdi->cell(5,5,$numPage,0,2,'R',TRUE);

?>

Cette opération doit être renouvelée pour chaque ligne apparaissant dans notre sommaire, le plus simple est donc de boucler dessus.

Voilà, nous avons écrit notre sommaire, il va maintenant falloir associer les bonnes pages aux liens.
La solution basique serait de le faire manuellement dans notre code à chaque création de page.
Mais comme un bon développeur est un développeur feignant, nous allons plutôt réécrire la méthode addPage() de FPDF afin d’automatiser l’action et que cela se fasse tout seul par la suite dans notre document :

<?php
class myfpdf extends fpdf {
    public $myLinks = array();

    public function addPage() {
        //on génère la page en appelant la méthode 
        //parente addPage()
        parent::addPage();

        // si un lien existe pour ce numéro de page, 
        //on l'associe à la page
        $page = $this->pageNo();
        if (isset($this->myLinks[$page])) {
            $this->setLink($this->myLink[$page]);
        }
    }

}
?>

Voilà, à chaque nouvelle page, si un lien y est associé, il sera automatiquement ajouté.

 

Si vous souhaitez voir le résultat, vous pouvez aller consulter le catalogue de formations d’AlliaForm, en bas à gauche du menu.

 

Le document est entièrement généré en PHP avec FPDI ( la version que vous y verrez est un version statique en cache, je ne le génère qu’une seule fois lorsque des modifications y sont apportées).



numéros de page intelligents avec FPDI / FPDF

    12:21 17 12 2011

Dans la continuité de l’article précédent, voici un petit tutoriel pour intégrer des numéros de page intelligents dans vos documents PDF générés par FPDF ou FPDI en PHP.

Avec FPDF, l’insertion des numéros de pages passe par la réécriture de la méthode footer() (qui est appelée à chaque création de nouvelle page) et l’utilisation de la méthode pageNo() qui renvoie le numéro de la page courante.

Typiquement :

public function Footer() {
    // Positionnement à 1,5 cm du bas
    $this->SetY(-15);
    // Police Arial italique 8
    $this->SetFont('Arial','I',8);
    // Numéro de page
    $page = $this->PageNo();
    $this->Cell(0,10,$page,0,0,$pos);
}

Mais, si cette solution est suffisante pour des documents de base, la construction d’un document chiadé demande souvent des fonctionnalités supplémentaires :

  • possibilité de commencer la numérotation sur la deuxième ou troisième page (pas sur la couverture) et donc de décaller les numéros des pages
  • afficher le numéro de page dans le coin et donc le mettre à droite sur les pages paires et à gauche sur les pages impaires (ou vice-versa selon la page où vous commencez la numérotation)

Voici donc une version un peu plus évolué de la méthode footer() qui intègre ces fonctionnalités :

class myfpdi extends fpdi {
    public $addPageNum = false;
    public $decalage = 2;

    public function Footer() {
        // Positionnement à 1,5 cm du bas
        $this->SetY(-15);
        // Police Arial italique 8
        $this->SetFont('Arial','I',8);
        // Numéro de page
        if ($this->addPageNum ==  true) {
            $page = $this->PageNo() - $this->decalage;
            if ($page % 2)
                $pos = 'R';
            else
                $pos = 'L';
            $this->Cell(0,10,$page,0,0,$pos);
        }
    }
...

Quelques explications

L’attribut $addPageNum est un booléen qui permet de dire si on doit afficher le numéro de page ou non (true ou false). A vous de lui donner la valeur souhaitée avant de faire appel à la méthode addPage();

L’attribut $decalage permet d’introduire un décalage dans la numérotation. Par exemple, si il vaut 2, la page 3 du document aura le numéro 1 d’affiché.

Enfin le test  ($page % 2) ajoute l’alternance d’affichage à gauche et à droite. Inversez $pos = ‘L’; et $pos = ‘R’; si le sens ne vous convient pas.



Template PDF par défaut avec FPDI

    09:56 16 12 2011

Dans le cadre de la création automatique du catalogue de formations PDF de AlliaForm, j’ai utilisé FPDI une classe dérivée de FPDF permettant d’importer des templates (modèles) de PDF.
FPDI est très pratique, on ouvre un fichier PDF existant, on importe une page et on s’en sert comme modele pour générer un nouveau PDF.

Seulement, j’ai rapidement rencontré un problème : si j’assigne un modele à un page, que j’écris un long texte dessus et que ce texte passe sur une page suivante (ce qui se fait automatiquement avec la méthode multicell()), la page suivante n’utilisera pas le modèle, elle sera générée à partir d’une feuille blanche.

J’ai bien sûr sorti la doc de FPDI, googlé pour trouver une solution rapide, mais la seule réponse que j’ai trouvé est « ce n’est pas possible avec FPDI ».

Je vous livre donc la solution (très simple) que j’ai implémentée.

Il suffit de dériver la classe FPDI et plus exactement, la méthode addPage() qui s’occupe d’ajouter une nouvelle page au document PDF pour y ajouter la fonctionnalité.

class myfpdi extends fpdi {

 public $defaultModele;

 public function AddPage() {
  parent::AddPage();
  if ($this->defaultModele != '') {
   $this->setSourceFile($this->defaultModele);
   $tplidx = $this->ImportPage(1);
   $this->useTemplate($tplidx);
  }
 }
}

On commence par appeler la méthode parente afin de ré-implémener le fonctionnement initial de addPAge(), puis on on lui assigne notre modèle par défaut qui se trouve dans le nouvel attribut $defaultModele.

De là je n’ai plus qu’à instancier un objet de type myfpdi() et lui assigner un fichier PDF par défaut dans l’attribut $defaultModele avant de créer de nouvelles pages :

$pdf = new myfpdi();
$pdf->defaultModele = 'fichier.pdf';
$pdf->addPage();
...
$pdf->ouput();

A chaque fois qu’une nouvelle page va être créée, la méthode addPage sera appelée et $defaultModele sera utilisé comme modèle par défaut.

Si à un moment dans mon PDF, je souhaite utiliser un autre modèle, il me suffira de changer la valeur de $defaultModele et si je ne veux plus de modèle, je passe sa valeur à ‘ ‘ (chaîne vide).

Bien sûr, dans un souci de lisibilité, le code présenté ci-dessus va au plus simple, tout cela est perfectible (accesseurs, test d’existence du fichier pdf, etc…)



pré-lancement de waDaWeDo!

    15:36 4 05 2011

Voilà,
après plusieurs mois de travail et d’enfermement chez moi, le grand jour de la mise en ligne de waDaWeDo est enfin arrivé.

203612_187781421257785_3319070_n
http://www.wadawedo.com

waDaWeDo est une application de partage d’agenda et d’événements sur Facebook. waDaWeDo permet de :

- Créer des événements évolués et les partager avec vos amis ou le monde entier
- Gérer votre agenda personnel grâce aux événements privés
- Consulter l’agenda public de vos amis et commenter ou rejoindre leur événements
- Trouver des événements publics proche de chez vous et les rejoindre
- …

waDaWeDo est accessible de 2 façons. Via sa page principale http://www.wadawedo.com mais également sous forme d’application Facebook http://apps.facebook.com/wadawedo/

Bien sûr, l’accès à waDaWeDo est entièrement gratuit.

Au niveau technique, waDaWeDo repose sur trois technologies. Bien sûr, du PHP (sans framework) et du MySQL, avec une architecture adaptée à Facebook.
Mais, grande nouveauté pour moi, tout le ‘front’ repose sur du jQuery ce qui permet de limiter la charge côté serveur à de simples appels de données.

Je vous invite à aller l’essayer et à me faire vos retours.

Ha oui, pour finir, je vais revenir au début de cet article, plus exactement au titre où je parle de ‘pré-lancement’. J’ai décidé de regarder comment la plateforme réagissait avant de considérer que nous étions dans une phase de lancement officiel.
Ceci dit, il ne faut surtout pas que ça vous empêche d’en parler autour de vous, bien au contraire. je compte, dans un premier temps, sur le bouche à oreille pour la faire connaître, alors n’hésitez pas à bloguer, twitter, Facebooker, mailer…