Catégorie : Code en Php

Code en Php

  • Utiliser l’API des climatiseurs DAIKIN

    Utiliser l’API des climatiseurs DAIKIN

    Aujourd’hui, je vous partage ma dernière création. Une libraire destinée à contrôler les climatiseurs Daikin.

    Voici les unités compatibles (2021)

    BRP069A41

    • dispositif de commande inclus avec l’unité

    Vous pouvez l’installer avec composer https://packagist.org/packages/daikin/api

    Enjoy 🙂

  • Soumettre un sitemap.xml à Google, et Bing

    Bonjour,

    Ce petit code va vous permettre de soumettre votre sitemap.xml aux 2 principaux moteurs de recherche, soit Google search et Bing.

    <?php
    
    class searchEngineSubmitter{
        
        private $urls;
        
        public function getUrls(){
            return  $this->urls ;
        }
        /**
         * @param array $urlsForSubmitting
         */
        public function __construct(array $urlsForSubmitting){
            $this->urls = $urlsForSubmitting;
        }
        
        /**
             * 
             * @param string $url
             * @return type
             */
        private function myCurl($url) {
            $ch       = curl_init($url);
            curl_setopt($ch, CURLOPT_HEADER, 0);
            curl_exec($ch);
            $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
            curl_close($ch);
            return $httpCode;
        }
        
        /*
             * @abstract Sitemap Submitter Use this script to submit your site maps automatically to Google, Bing.MSN and Ask Trigger this script on a schedule of your choosing or after your site map gets updated.
         * @param string
        */
        public function submitSitemap($sitemapUrl) {
    
            foreach ( $this->getUrls() as $url) {
                $code = $this->myCurl($url . $sitemapUrl);
                if ($code == '200') {
                      return 'success: ' . parse_url($url, PHP_URL_HOST) . ' has been pinged (return code: ' . $code . ' )';
                } else {
                      return 'warning' . parse_url($url, PHP_URL_HOST) . ' return error (return code: ' . $code . ' )';
                }
            }
        }
        
    }

    Pour l’utiliser on fait comme ceci :

    <?php
    
    $submit = (new searchEngineSubmitter(
        ["http://www.google.com/webmasters/sitemaps/ping?sitemap=",
        "http://www.bing.com/webmaster/ping.aspx?siteMap="]))
        ->submitSitemap('http://www.mywebsite.com');

    Et voilà 🙂

    @ bientôt

  • Valider les champs d’un formulaire avec Silex et « Validator Constraints »

    Valider les champs d’un formulaire avec Silex et « Validator Constraints »

    Je me suis associé à Baptiste Pesquet l’auteur du cours sur Openclassrooms « Évoluez vers une architecture PHP professionnelle ». La validation des champs est désormais compatible avec la version 2.1 de silex c’est l’itération 14.

    Bonjour,

    Aujourd’hui nous allons voir comment ajouter la validation des valeurs de retour d’un formulaire dans le framework Silex.

    Après avoir suivi le cours sur Openclassrooms « Évoluez vers une architecture PHP professionnelle », il vous manquera cette partie avant de mettre votre site en ligne.

    Pourquoi valider les champs ?

    Pour s’assurer que les utilisateurs du site ne cherche pas à enter n’importe quelle donnée n’importe où. Par exemple un numéro de téléphone dans le champ email, tenter de faire passer des valeurs inapproprié et exploiter une faille xss…

    Voici comment nous allons procéder :

    Dans un premier temps nous allons ajouter un namespace qui sera utilisé par votre buildForm:: ce namespace c’est :

    use Symfony\Component\Validator\Constraints as Assert;

    Voici ce que j’ai fait pour l’enregistrement d’un email :

    <?php
    
    namespace MicroCMS\Form\Type;
    
    use Symfony\Component\Form\AbstractType;
    use Symfony\Component\Form\FormBuilderInterface;
    
    class NewsletterType extends AbstractType
    {
    
        public function buildForm(FormBuilderInterface $builder, array $options) {
            $builder->add('email', 'email', [
                'label'      => '',
                'required'   => true,
            ]);
        }
    
        public function getName() {
            return 'newsletter';
        }
    
    }

    On vois que j’ai mis plusieurs contraintes. En premier lieu j’ai décidé que le champ est de type « email »et qu’il est « requis » (required), c’est à dire que sur le html généré, on verra ceci :

    <input id="newsletter_email" name="newsletter[email]" required="required" placeholder="Votre email pour vous inscrire à la Newsletter" type="email">

    Si l’utilisateur a un navigateur récent, et qu’il soumet le formulaire directement, un message lui dira que ce n’est pas possible car le champ est vide. Si il remplit ce champ avec autre chose qu’un email le navigateur va là aussi l’informer que cette donnée n’est pas valide. C’est une première étape car si l’utilisateur est un petit malin, il peut modifier le type de champ dans le input, supprimer le required et le email. à ce moment là, il pourra soumettre le formulaire sans message d’erreur.

    Il faut donc procéder à une deuxième vérification sur les données au niveau du framework et pas seulement dans le navigateur.

    Pour cela on va rajouter cette ligne dans notre méthode buildForm, ‘constraints’ => new Assert\Email(),

    <?php 
    namespace MicroCMS\Form\Type;
    
    use Symfony\Component\Form\AbstractType;
    use Symfony\Component\Form\FormBuilderInterface;
    use Symfony\Component\Validator\Constraints as Assert;
    
    class NewsletterType extends AbstractType
    {
    
        public function buildForm(FormBuilderInterface $builder, array $options) {
            $builder->add('email', 'email', [
                'label'      => '',
                'required'   => true,
                'constraints' => new Assert\Email(),
            ]);
        }
    
        public function getName() {
            return 'newsletter';
        }
    
    }

    Là, on est certain que la valeur attendu sera un email et pas autre chose. Si l’utilisateur fait le malin au niveau de son navigateur, voici ce qui va s’afficher :

    • This value is not a valid email address.

    Grand maître L

  • Grosse mise à jour de ma librairie PHP Json-heitz

    Le logiciel Heitz System expose toujours une API avec laquelle on peux discuter via JSON. Je vous avais déjà présenté la première version de cette class ici.

    Elle rencontre un petit succès 162 téléchargements aux dernières nouvelles sur Packagist.

    Pour l’invoquer, voici comment faire :

    <?php
    require_once 'vendor/autoload.php';
    
        use JsonHeitz\JsonHeitz;
        use JsonHeitzCredential\Credential;
        use JsonHeitz\JsonHeitzException\JsonHeitzException;
    
    try {
            $connect = (new Credential())
                    ->setPort(80)
                    ->setUserLogin('test1@heitzsystem.com')
                    ->setUserPass('1')
                    ->setHost('http://heitz.no-ip.com')
                    ->setHostPassword('AuthentificationBaseTest')
                    ->urlWebServeurHeitz()
            ;
        } catch (JsonHeitzException $exc) {
            echo $exc->getMessage();
        }
    
        try {
    
            $call = (new Query($connect))->setConnectHeitzAPI()
                //    ->setDebug(true) //optional
            ;
    
            $resultat = $call->callWSHeitz();
    
            $call->setIdSession($resultat->idSession)
                    ->setIdClient($resultat->idClient);
    
    
            var_dump($call->getOneClient());
            var_dump($call->getTaskList());
            var_dump($call->getTest());
            var_dump($call->getFormTraining());
            var_dump($call->getActiveReservation());
            var_dump($call->getConfigServeur());
            var_dump($call->getBilan());
            var_dump($call->getTest());
            var_dump($call->getClientMessage(10));
            var_dump($call->getListOfActiveAccess());
            var_dump($call->getListOfPassages());
            var_dump($call->getArrowPoints());
            var_dump($call->getTaskGroup());
            var_dump($call->getPlaceForTheTask());
            var_dump($call->getListOfFinancialDeadlines());
            var_dump($call->getListOfLevies());
            var_dump($call->getListOfBills());
            var_dump($call->getListOfFinancial());
            var_dump($call->getListOfFinancialDeadlines());
            var_dump($call->getListOfLevies());
            var_dump($call->getListOfPoints());
            var_dump($call->getListOfCures());
            var_dump($call->getListOfActiveAccess());
            var_dump($call->getAllArticles());
            var_dump($call->getAllCity());
            var_dump($call->getAllCivility());
            var_dump($call->getAllJobs());
            var_dump($call->getAllWhereTheCustomerHasPracticed());
            var_dump($call->getAllMotivation());
            var_dump($call->getAllVAT());
            var_dump($call->getAllPayment());
            var_dump($call->getAllWayToKnowTheInstitution());
            var_dump($call->getAllTypeOfProspects());
            var_dump($call->getAllDiscountLevel());
            var_dump($call->getAllCustomerGroup());
            var_dump($call->getAllEmployee());
            var_dump($call->getAllFamilySituation());
            var_dump($call->getArrowPoints());
            var_dump($call->getDetailOfCures());
            var_dump($call->getCriterion1());
            var_dump($call->getCriterion2());
            var_dump($call->getCriterion3());
            var_dump($call->getCriterion4());
            var_dump($call->getCriterion5());
            var_dump($call->getDashboard('01-03-2012', '01-03-2013'));
            var_dump($call->getDashbordFinancial('01-03-2012'));
            var_dump($call->getFinancial());
            var_dump($call->getFormTraining());
            var_dump($call->getScheduleSEPA());
    
            $sale = array(
                'vente'     => '{"ventes":[{"idArticle":300024225, "idTva":0, "quantite":3, "prixUnitaire":12.34},
                                                       {"idArticle":300185150, "idTva":0, "quantite":2, "prixUnitaire":987.654}]}',
                'reglement' => '{"reglements":[{"idMode":1, "montant":12.34},
                                            {"idMode":3, "montant":987.654},{"idMode":2, "montant":122.3}]}'
            );
            var_dump($call->addSale($sale));
    
            $search = array(
                "idClientRecherche" => '',
                "nom"               => 'sa%',
                "prenom"            => '',
                "secondPrenom"      => '',
                "email"             => '',
                "idCivilite"        => '',
                "naissance"         => '',
                "telephone"         => '',
                "portable"          => '',
                "idVille"           => '',
                "idSituation"       => '',
                "idProfession"      => '',
                "dateCreation"      => '',
                "contactSMS"        => '',
                "contactEmail"      => '',
                "contactCourrier"   => '',
                "contactTelephone"  => ''
            );
    
            var_dump($call->searchClient($search, 1));
            var_dump($call->getClientIdByEmail('toto@toto.fr'));
            var_dump($call->clientWithAnActiveSpecificAccess(1018874, 16485527));
            var_dump($call->accessListForAClient(19435255));
        } catch ( JsonHeitzException $exc) {
            echo $exc->getMessage();
        }

    Et voila, @Bientôt Grand Maître L

  • SgAutoRepondeur avec composer

    J’ai développé une petite classe en PHP pour utiliser facilement l’API de SGAutoRépondeur.

    Elle est bien-sûr disponible pour tous sur mon Bitbucket. Elle respecte les conventions PSR-4 pour l’auto-chargement des classes et ça c’est important !!!

    Pour information, voici comment l’utiliser :

    <?php
    require_once 'vendor/autoload.php';
    
    try {
        $monTest = (new \SgAutoRepondeur\SgAutoRepondeur())
                ->setCodeActivationClient('1010201000162121718617151918911')
                ->setMembreID('32')
                ->setInscriptionNormale('non')
                ->setEmailSG('sebastienXXX_@hotmail.com')
                ->setListeID('779')
    
        ;
    } catch (SgAutoRepondeur\SgException\SgException $exc) {
        echo $exc->getMessage();
    }
    
    try {
        $userSG = (new \SgAutoRepondeur\User\User())
                ->setEmail('tutu@tutu.fr')
                ->setNom('Dupont')
                ->setPrenom('Jean')
                ->setAdresse('125 rue de nulle part')
                ->setPays('France')
                ->setAnneeNaissance('1979')
                ->setMoisNaissance('01')
                ->setJourNaissance('10')
                ->setVille('lyon')
                ->setIp('192.168.1.236');
    
        $monTest->setFields($monTest, $userSG);
    
      //  var_dump($monTest->getFields());
    } catch (SgAutoRepondeur\SgException\SgException $exc) {
        echo $exc->getMessage();
    }
    
    try {
        var_dump( $result = (new SgAutoRepondeur\ResponseDictionary\ResponseDictionary())
            ->value( $monTest->callWebService($monTest->getFields()) ));
    } catch (SgAutoRepondeur\SgException\SgException $exc) {
        echo $exc->getMessage();
    }
    

    Pour avoir plus d’informations sur l’autorépondeur et à quoi cela sert, je vous invite à vous rendre sur leur site internet

    http://sg-autorepondeur.com/index.php

    @ plus Grand Maitre L

  • Codeigniter 3.0 is out !

    C’est parti Codeigniter 3.0 est maintenant disponible en version finale, la lise des changements étant longue comme mon bras, je vous invite à vous plonger dans le changelog officiel sur cette page.

    A partir de maintenant c’est un nouveau départ pour le framework qui j’espère sera amené à évoluer plus souvent. Je lui souhaite le meilleur mais je fait aussi quelques recommandations.

    Une nouvelle version à minima

    La version minimale est php 5.2.x, c’est une version qui n’est plus supportée par PHP depuis 4 ans (la doc dit qu’ils recommandent PHP 5.4.x). Là je suis un peux plus content mais aucun des apports de la version ne sont utilisé (TRAITS, namespaces…). Une refonte du cœur doit être entreprise pour tirer le meilleur parti de ces nouveaux ajouts.

    Et maintenant je fais quoi ?

    Et bien je vais tenter de migrer au moins un projet vers codeigniter 3.0 pour voir les limitations et les opportunités de la nouvelle version. Si tous se passe correctement, je migre mes autres projets.

     

    La nouvelle version est disponible ici

    See you soon !

  • Migrer son framework CodeIgniter de la version 2.1.4 vers la version 3.0.0

    Migrer son framework CodeIgniter de la version 2.1.4 vers la version 3.0.0

    Dans cet article je vais m’efforcer de vous traduire les consignes pour migrer son projet Codeigniter 2.1.4 vers la version 3.0.0 :

    le texte original est disponible ici :

    Ces notes de mise à niveau sont valables pour une version qui n’est pas encore publié.

    Avant d’effectuer la mise à jour, vous devriez mettre votre site en ligne en remplaçant le fichier index.php avec une version >statique pour prévenir vos utilisateurs d’une migration en cours.

    Étape 1 : Mettre à jour les fichier de Codeigniter

    Remplacer tous les dossiers présents dans « system » ainsi que index.php. Si des modifications ont été apportées à votre index.php, elles devront être refaites à nouveau .

    Si vous avez des fichiers de votre crus présents dans « system », pensez à en réaliser une copie d’abord !

    Étape 2 : Mettre à jour les noms de fichiers de classes

    À partir de CodeIgniter 3.0, tous les noms de fichiers de classe (bibliothèques, les pilotes, les contrôleurs et modèles) doivent être nommés de manière « ucfirst », en d’autres termes – ils doivent commencer par une lettre majuscule.

    Par exemple, si vous avez le fichier suivant dans « libraries » :

    application/libraries/mylibrary.php

    …vous devez le renommer en :

    application/libraries/Mylibrary.php

    La même chose vaut pour les bibliothèques de pilotes et extensions et / ou celles qui on été remplacé par vos propres bibliothèques et les classes.

    application/libraries/MY_email.php application/core/MY_log.php

    Les fichiers ci-dessus doivent être renommés respectivement de cette manière :

    application/libraries/MY_Email.php application/core/MY_Log.php

    Controllers:

    application/controllers/welcome.php -> application/controllers/Welcome.php

    Models:

    application/models/misc_model.php -> application/models/Misc_model.php

    Veuillez noter que cela n’affecte pas les répertoires , seulement les fichiers de configuration , des vues, des aides, des crochets et rien d’autre – ce n’est appliqué qu’ aux classes.

    Vous devez maintenant suivre une règle simple – le noms de classes en « ucfirst » et tout le reste en minuscules.

    Étape 3 : Replacer le fichier config/mimes.php

    Ce fichier de configuration a été mis à jour pour contenir plus de mime-types, copiez-le dans « Application/config/mimes.php« .

    Étape 4 : Supprimer $autoload[‘core’] de votre fichier config/autoload.php

    L’usage de $autoload['core'] est déprécié depuis CodeIgniter 1.4.1, il est maintenant supprimé. Déplacez toute les entrées que vous avez ajouté dans $autoload['libraries'] à la place.

    Étape 5 : déplacez votre classe de log et extensions

    La classe log est considéré comme une extension du « core » elle est maintenant situé dans le dossier system/core/. Par conséquent, pour que votre classe Log remplace ou étende , vous devez les déplacer dans application/core/:

    application/libraries/Log.php -> application/core/Log.php
    application/libraries/MY_Log.php -> application/core/MY_Log.php
    

    Étape 6 : Convertir votre utilisation de « session » à partir de la bibliothèque « driver »

    Lorsque vous chargez (ou autochargez) la Session library, vous devez maintenant le charger en tant que pilote au lieu d’une bibliothèque. Cela signifie qu’il faut appeler $this->Load->driver('session') au lieu de $this->Load->library('session') et/ou de la liste ‘session’ dans $autoload['drivers'] au lieu de $autoload['library'].

    Avec le changement de la libairie session de la nouvelle session utilisant « driver », deux nouveaux éléments de configuration ont été ajoutés :

    • $config['sess_driver'] sélectionner les drivers que vous voulez utiliser. Les option sont :

      • ‘cookie’ (par défault) pour des sessions basées sur les cookies
      • ‘native’ pour utiliser les sessions native de PHP
      • le nom de votre driver personnalisé
    • $config['sess_valid_drivers'] offre toute une gamme de drivers personnalisés supplémentaires pour rendu disponible au chargement

    La nouvelle bibliothèque session driver charge le pilote de Cookie par défaut mais « cookie » et « native » disponible comme avant, aucune configuration n’est nécessaires. Cependant, il est recommandé que vous les ajoutiez à pour la clarté et la facilité de configuration future.

    Si vous avez écrit une extension à session, vous devez la déplacer dans un sous-répertoire «session» de «libraries», conformément à la norme pour les drivers. Méfiez-vous également à ce que certaines fonctions qui ne font pas partie de l’API Session externe ne soit installés dans les pilotes, si votre poste peut être décomposé en extensions de library de la classe de driver séparément.

    Étape 7 : Mettre à jour config/database.php

    en raison du chenagement de nom de Active Record pour Query Builder, à l’intérieur de votre config/ database.php, vous devez renommer la variable $active_record en $query_builder

    $active_group = 'default';
    
    // $active_record = TRUE;
    
    $query_builder = TRUE;

    Étape 8 : Remplacez votre template d’affichage des erreurs

    Dans CodeIgniter 3.0, le template error est maintenant considéré comme une vue et à été déplacé dans le dossier _application/views/errors.

    En outre, nous avons ajouté un support pour des modèles d’erreur en CLI (ligne de commande) un format texte qui, contrairement au HTML, est plus addapté la ligne de commande. Bien sûr, cela nécessite un autre niveau de séparation.

    Il est plus sûr de déplacer vos modèles préexistants de _Application/erreurs vers _Application/views/errors/html, n’oubliez pas de copier le nouveau _application/views/errors/cli dans le répertoire de CodeIgniter.
    Nous vous conseillons de déplacer vos anciens templates du dossier _application/errors vers _application/views/errors/html, vous aurez à copier le nouveau _application/views/errors/cli répertoire de l’archive de CodeIgniter.

    Étape 9 : Mettre à jour les config/routes.php de type (:any)

    Historiquement, CodeIgniter a toujours fourni la route :any générique, avec l’intention de fournir un moyen de faire correspondre tout les caractères dans un segment de type URI.
    Cependant, la :any générique est en fait juste un alias pour une expression régulière, il est utilisé pour être exécuté de cette manière + .. Ceci est considéré comme un bug, car elle correspond également au caractère (slash) /, qui est le segment séparateur URI dont cela n’a jamais été l’intention… Dans CodeIgniter 3, le générique :any est représenté par [^/]+,de sorte qu’il ne peux pas correspondre à un slash.

    Il y a certainement beaucoup de développeurs qui ont utilisé ce bug comme une caractéristique réelle. Si vous êtes l’un d’entre eux et que vous voulez faire correspondre un slash, utiliser une expression régulière .+ :

    (.+)    // matches ANYTHING
    (:any)  // matches any character, except for '/'
    

    Étape 10 : Toutes les fonctions qui retournent NULL à la place de FALSE

    De nombreuses méthodes et fonctions renvoient désormais NULL, au lieu de FALSE lorsque les éléments nécessaires n’existent pas :

    • `Config Class ../libraries/config`
      • config->item()
      • config->slash_item()
    • :doc:`Input Class ../libraries/input`
      • input->get()
      • input->post()
      • input->get_post()
      • input->cookie()
      • input->server()
      • input->input_stream()
      • input->get_request_header()
    • :doc:`Session Class ../libraries/sessions `
      • session->userdata()
      • session->flashdata()
    • :doc:`URI Class <../libraries/uri `
      • uri->segment()
      • uri->rsegment()
    • :doc:`Array Helper ../helpers/array_helper `
      • element()
      • elements()

    Étape 11 : Application du filtre XSS

    De nombreuses méthodes de CodeIgniter vous permettent d’utiliser la fonction de filtrage XSS à la demande en passant un paramètre de type booléen. La valeur par défaut de ce paramètre utilisé est FALSE, il est maintenant remplacé par la valeur NULL et il sera déterminée dynamiquement par votre $config ['global_xss_filtering'] value.

    Si vous avez utilisé pour passer manuellement une valeur booléenne pour le filtre $xss ou si vous avez toujours eu $config ['global_xss_filtering'] défini à FALSE, alors ce changement ne vous concerne pas. Sinon vérifier l’utilisation des fonctions suivantes :

    • input->get()
    • input->post()
    • input->get_post()
    • input->cookie()
    • input->server()
    • input->input_stream()

    Important, les superglobals $_GET, $_POST, $_COOKIE et $_SERVER ne sont plus automatiquement écrasé lorsque le filtrage global XSS est activé.

    Étape 12 : Mettre à jour l’utilisation de la méthode de la classe get_post()

    Précédemment, la méthode get_post()recherchait les données en POST en premier, puis en GET. La méthode à été modifiée pour chercher en premier en GET puis en POST, comme son nom le suggère.

    Une méthode à été ajouté, post_get(), qui recherche en POST puis en GET, comme get_post() le faisait avant.

    Étape 13 : Mise à jour des dossier Helpers en directory_map()

    Dans le tableau résultant, les répertoires finissent maintenant avec un séparateur de répertoire(c’est à dire un /, généralement).

    Étape 14 : Mise à jour de l’utilisation de la base de données et de la méthode Forge de DROP_TABLE

    Jusqu’à présent il y avait une clause IF EXISTS DROP_TABLE() par défaut qui ne fonctionne pas du tout avec certains pilotes. Avec CodeIgniter 3.0, l’IF EXISTS ​​n’est plus ajoutée par défaut, il y a un second paramètre optionnel qui le permet. Il est mis à FALSE par défaut.

    Si votre application utilise IF EXISTS, vous devez controler son utilisation.

    // Now produces just DROP TABLE `table_name`
    $this->dbforge->drop_table('table_name');
    
    // Produces DROP TABLE IF EXISTS `table_name`
    $this->dbforge->drop_table('table_name', TRUE);
    

    Le présent exemple concerne la syntax MySQL, mais elle devrait fonctionner pour tous les pilotes à l’exception de ODBC.

    Étape 15 : Changer l’utilisation de la bibliothèque e-mails pour l’envoi de plusieurs e-mails

    Effacement automatiquement des paramètres réglés après l’envoi des e-mails avec succès. Pour remplacer ce comportement, passer FALSE comme premier paramètre dans le send () :

    if ($this->email->send(FALSE))
    {
            // Parameters won't be cleared
    }
    

    Étape 16: Mettez à jour vos traduction avec la méthode Form_validation()

    Deux améliorations ont été apportées à la validation de formulaire bibliothèques / form_validation..> 'Slt; / bibliothèques / langue&gt; fichiers et le format des messages d’erreur..:

    • touches de ligne doivent désormais être précédés de form_validation_ afin d’éviter les collisions :
      // Ancien
      $lang['rule'] = ...
      
      // Nouveau
      $lang['form_validation_rule'] = ...
      
    • Le format des messages d’erreur a été modifié pour utiliser des paramètres nommés, afin de permettre plus de souplesse que ce que propose sprintf() :
      // Ancien
      'The %s field does not match the %s field.'
      
      // Nouveau
      'The {field} field does not match the {param} field.'
      

    Le vieux formatage fonctionne toujours, mais les touches de ligne non-préfixés sont obsolètes et programmé pour être supprimé dans CodeIgniter 3.1 +. Par conséquent, vous êtes encouragés à mettre à jour son utilisation au plutôt tôt.

    Étape 17 : Retirer l’utilisation des fonctionnalités obsolètes

    En plus de $autoload['core'] de paramètre de configuration, il y a un certain nombre d’autres fonctionnalités qui ont été supprimés dans CodeIgniter 3.0.0:

    La librairie SHA1

    La bibliothèque de SHA1 du framework a été supprimé, modifier votre code pour utiliser le SHA1 natif de PHP pour générer un hash SHA1.

    SHA1() a été supprimé le la libraire encrypt.

    La constante EXT

    L’utilisation de la constante EXT a été dépréciée depuis l’abandon du support de PHP 4. Il n’y a pas plus besoin de maintenir des extensions de nom de fichier et dans cette nouvelle version CodeIgniter, EXT constante a donc été retirée. Utilisez seulement ‘.Php’ à la place.

    Le helper js_insert_smiley()

    La function js_insert_smiley() est dépréciée depuis CodeIgniter 1.7.2, elle est maintenant supprimée. Vous devez passer à smiley_js() à la place.

    La libraire Encrypt

    Après de nombreux rapports de vulnérabilité, la Bibliothèque Encrypt a été déprécié et une nouvelle, Bibliothèque Encryption est ajouté pour prendre sa place.

    La nouvelle bibliothèque nécessite soit l’extension MCrypt ou PHP 5.3.3 et l’extension OpenSSL. Même si cela peut être assez gênant, c’est une exigence qui nous permet d’avoir des fonctions cryptographiques correctement mises en œuvre.

    Remarque

    La bibliothèque Crypter est toujours disponible dans le but de maintenir la compatibilité ascendante.

    Important : Vous êtes fortement encouragés à passer à la nouvelle bibliothèque Encryption dès que possible!

    Le pilotes de base de données ‘mysql’ , ‘sqlite’, ‘MSSQL’, ‘AOP / dblib’

    Le pilote mysql utilise l’ancienne extension ‘mysql’ de PHP, connue pour sa base de code vieillissante et de nombreux problèmes de bas niveau. L’extension est obsolète depuis PHP 5.5 et CodeIgniter le déprécie dans la version 3.0, la valeur par défaut du pilote MySQL est configuré pour mysqli .

    S’il vous plaît utiliser le pilote ‘mysqli’ ou le pilote ‘PDO / mysql’ pour MySQL. L’ancien pilote ‘mysql’ sera retiré dans l’avenir.

    Les pilotes sqlite , MSSQL et AOP / dblib (aussi connu comme AOP / MSSQL ou AOP / sybase) dépendent tous des extensions de PHP qui pour différents raisons n’existent plus depuis PHP 5.3.

    Par conséquent, nous sommes en train de déprécier ces pilotes que nous aurons à retirer dans les prochaines versions de CodeIgniter. Vous devez utiliser les pilotes les plus avancés, soit sqlite3 ,sqlsrv ou AOP / sqlsrv .

    Remarque : Ces pilotes sont encore disponibles, mais vous êtes fortement encouragés migrer au plus tôt.

    La sécurité du helper do_hash()

    La function do_hash() est maintenant juste un alias pour la fonction de hachage de PHP. Il est obsolète et est programmé pour être supprimé dans CodeIgniter 3.1 +.

    Note :
    Cette fonction est toujours disponible, mais vous êtes fortement encouragé à retirer arrêter son utilisation au plus tôt.

    Le helper read_file()

    La fonction read_file() est maintenant un simple alias de la fonction PHP native file_get_contents(). Cette fonction est dépréciée, elle sera supprimé dans CodeIgniter 3.1+.

    Note :
    Cette fonction est toujours disponible, mais vous êtes fortement encouragé à retirer son utilisation au plus tôt.

    String helper repeater()

    La fonction est maintenant un simple alias de la fonction PHP native str_repeat(). Cette fonction est dépréciée, elle sera supprimé dans CodeIgniter 3.1+.

    Note :
    Cette fonction est toujours disponible, mais vous êtes fortement encouragé à retirer son utilisation au plus tôt.

    Le helper trim_slashes()

    Cette est maintenant un simple alias de la fonction PHP native trim() (avec un slash passé en second argument). Cette fonction est dépréciée, elle sera supprimé dans CodeIgniter 3.1+.

    Note :
    Cette fonction est toujours disponible, mais vous êtes fortement encouragé à retirer son utilisation au plus tôt.

    le helper Email

    Le Helper Email a seulement 2 fonctionnalités

    • :func:`valid_email()`
    • :func:`send_email()`

    Deux d’entre eux sont maintenant des alias pour la fonction native filter_var () de PHP et le mail() . Par conséquent, le:doc:Email Helper < .. / Helpers / email_helper> tout est obsolète et est prévue pour le déménagement à CodeIgniter 3.1 +.

    Note
    Cette fonction est toujours disponible, mais vous êtes fortement encouragé à retirer son utilisation au plus tôt.

    Date helper standard_date()

    La function standard_date() is being deprecated due to the availability of native PHP constants, which when combined with date() provide the same functionality. Furthermore, they have the exact same names as the ones supported by standard_date(). Here are examples of how to replace its usage:

    // Old way
    standard_date(); // defaults to standard_date('DATE_RFC822', now());
    
    // Replacement
    date(DATE_RFC822, now());
    
    // Old way
    standard_date('DATE_ATOM', $time);
    
    // Replacement
    date(DATE_ATOM, $time);
    

    Note

    This function is still available, but you’re strongly encouraged to remove its usage sooner rather than later as it is scheduled for removal in CodeIgniter 3.1+.

    HTML helpers nbs(), br()

    :doc:HTML Helper &lt;../helpers/html_helper&gt; functions nbs() and br() are just aliases for the native str_repeat() function used with &nbsp; and <br > respectively.

    Because there’s no point in just aliasing native PHP functions, they are now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    These functions are still available, but you’re strongly encouraged to remove their usage sooner rather than later.

    Pagination library ‘anchor_class’ setting

    The :doc:Pagination Library &lt;../libraries/pagination&gt; now supports adding pretty much any HTML attribute to your anchors via the ‘attributes’ configuration setting. This includes passing the ‘class’ attribute and using the separate ‘anchor_class’ setting no longer makes sense. As a result of that, the ‘anchor_class’ setting is now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    This setting is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    String helper random_string() types ‘unique’ and ‘encrypt’

    When using the :doc:String Helper &lt;../helpers/string_helper&gt; function :func:random_string(), you should no longer pass the unique and encrypt randomization types. They are only aliases for md5 and sha1 respectively and are now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    These options are still available, but you’re strongly encouraged to remove their usage sooner rather than later.

    URL helper url_title() separators ‘dash’ and ‘underscore’

    When using the function, you should no longer pass dash or underscore as the word separator. This function will now accept any character and you should just pass the chosen character directly, so you should write ‘-‘ instead of ‘dash’ and ‘_’ instead of ‘underscore’.

    dash and underscore now act as aliases and are deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    These options are still available, but you’re strongly encouraged to remove their usage sooner rather than later.

    Session Library method all_userdata()

    As seen in the :doc:Change Log &lt;../changelog&gt;, :doc:Session Library &lt;../libraries/sessions&gt; method userdata() now allows you to fetch all userdata by simply omitting its parameter:

    $this->session->userdata();
    

    This makes the all_userdata() method redudant and therefore it is now just an alias for userdata() with the above shown usage and is being deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    This method is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    Database Forge method add_column() with an AFTER clause

    If you have used the third parameter for :doc:Database Forge &lt;../database/forge&gt; method add_column() to add a field for an AFTER clause, then you should change its usage.

    That third parameter has been deprecated and scheduled for removal in CodeIgniter 3.1+.

    You should now put AFTER clause field names in the field definition array instead:

    // Old usage:
    $field = array(
            'new_field' => array('type' => 'TEXT')
    );
    
    $this->dbforge->add_column('table_name', $field, 'another_field');
    
    // New usage:
    $field = array(
            'new_field' => array('type' => 'TEXT', 'after' => 'another_field')
    );
    
    $this->dbforge->add_column('table_name', $field);
    

    Note

    The parameter is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    Note

    This is for MySQL and CUBRID databases only! Other drivers don’t support this clause and will silently ignore it.

    URI Routing methods fetch_directory(), fetch_class(), fetch_method()

    With properties CI_Router::$directory, CI_Router::$class and CI_Router::$method being public and their respective fetch_*() no longer doing anything else to just return the properties – it doesn’t make sense to keep them.

    Those are all internal, undocumented methods, but we’ve opted to deprecate them for now in order to maintain backwards-compatibility just in case. If some of you have utilized them, then you can now just access the properties instead:

    $this->router->directory;
    $this->router->class;
    $this->router->method;
    

    Note

    Those methods are still available, but you’re strongly encouraged to remove their usage sooner rather than later.

    Input library method is_cli_request()

    Calls to the CI_Input::is_cli_request() method are necessary at many places in the CodeIgniter internals and this is often before the :doc:Input Library &lt;../libraries/input&gt; is loaded. Because of that, it is being replaced by a common function named :func:is_cli() and this method is now just an alias.

    The new function is both available at all times for you to use and shorter to type.

    // Old
    $this->input->is_cli_request();
    
    // New
    is_cli();
    

    CI_Input::is_cli_request() is now now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    This method is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    Config library method system_url()

    Usage of CI_Config::system_url() encourages insecure coding practices. Namely, your CodeIgniter system/ directory shouldn’t be publicly accessible from a security point of view.

    Because of this, this method is now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    This method is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    The Javascript library

    The :doc:Javascript Library &lt;../libraries/javascript&gt; has always had an ‘experimental’ status and was never really useful, nor a proper solution.

    It is now deprecated and scheduled for removal in CodeIgniter 3.1+.

    Note

    This library is still available, but you’re strongly encouraged to remove its usage sooner rather than later.

    Step 18: Check your usage of Text helper highlight_phrase()

    The default HTML tag used by :doc:Text Helper &lt;../helpers/text_helper&gt; function :func:highlight_phrase() has been changed from <strong> to the new HTML5 tag <mark>.

    Unless you’ve used your own highlighting tags, this might cause trouble for your visitors who use older web browsers such as Internet Explorer 8. We therefore suggest that you add the following code to your CSS files in order to avoid backwards compatibility with old browsers:

    mark {
            background: #ff0;
            color: #000;
    };
    
  • Développement d’une class PHP pour Heitz SYSTEM

    Développement d’une class PHP pour Heitz SYSTEM

    La classe a beaucoup évolué, elle est maintenant disponible avec composer :

    require " json-heitz/json-heitz": "dev-master"

    et hop !

    Heitz System est un ERP ou PGI pour les francophones, spécialisé dans la gestion des salles de remise en forme proposé par Heitz international. Ils existent depuis de nombreuses années sur ce marché.

    Depuis-peu, il est possible de s’interfacer avec celui-ci via un web service qu’ils ont mis en place. Les échanges sont réalisés grâce à Javascript Object Notation autrement dit JSON. Depuis le temps que je leur casse les pieds les incites fortement pour qu’ils réalisent une interface…

    L’éditeur propose donc un exemple de code basé sur la bibliothèque jQuery dont voici le code :

    var IdentificationJson = 
    {
       "status":0,
       "idErreur":0,
       "idSite": "AuthentificationBaseTest",
       "type":1,
       "email":"test1@heitzsystem.com",
       "code":"1",
       "idSession":0,
       "idClient":0
    };
    
    function SendIdentification(){
      $.ajax({
              type: "POST",
            dataType: "json",
            url: 'http://heitz.no-ip.com/json',
           data: IdentificationJson,
           dataType: "json",
           success:function(data){
           console.log(data);
       }
    });
    }

    Le fait d’afficher les informations de connexion dans le code source du projet ne me conviens pas, c’est pour quoi j’ai décidé de proposer une class en PHP afin de masquer ces infos au tout venant et ainsi faciliter le traitement de ces informations dans d’autres projets tel que Magento, Drupal ou autres…

    Je me suis appuyé sur la programmation orienté objet pour faciliter sa modularité et les éventuelles évolutions dans le temps car l’éditeur sort de nouvelle mises à jour régulièrement. Comme je suis super sympas (si,si..) je propose à tous le monde la source de mon code sur Bitbucket à la condition express que si ils l’améliorent, ils le propose à la communauté via un push request. La procédure est très simple, profitons en !

    J’attend beaucoup de vos retours pour l’améliorer, n’hésiter pas à m’en faire.

    @ bientôt grand Maitre L

  • Partage d’un code source pour le tracking COLISSIMO

    Super Edit :

    j’ai des infos de la poste, ils sont en train de mettre en place une API Officielle.
    Pour cela il faut avoir un compte Inet-Expeditor et le service sera proposé en janvier 2014.
    Il répondra au jolis nom de « colis view ». Je vous conseille de vous rapprocher de votre commercial car l’ancienne API sera supprimée.

    « EDIT » Ce code rencontre de petits problèmes actuellement, je vous conseille de vous tourner vers la vieille version en procédurale qui fonctionne .

    Les années avançant et les statistiques Google Analytics sont là pour le prouver , la page la plus lue sur le blog est celle concernant un petit code mis en ligne pour faire du tracking de paquet Colissimo.

    Je ne pouvais pas le mettre en ligne tel quel, un dépoussiérage me semblais nécessaire, c’est pourquoi j’ai décidé de m’appuyer sur la programmation orientée objet pour refondre ce code.

    En faisant une petite recherche sur internet je me suis rendu compte qu’un lyonnais avais déjà effectué cette démarche et quelle était beaucoup plus avancé que ce que j’étais susceptible de vous proposer. Son code est disponible sur GITHUB.

    Pour les autres le voici :

    /*
     * @author Julien 'delphiki' Villetorte <gdelphiki@gmail.com>
     * http://www.delphiki.com/
     * http://twitter.com/delphiki
     *
     */
    class ColissimoAPI{
        private $host = 'http://www.laposte.fr';
        private $page = '/outilsuivi/web/suiviInterMetiers.php';
        private $user_agent = 'Dalvik/1.4.0 (Linux; U; Android 2.3.5; HTC Desire HD Build/GRJ90)';
        private $key ;
        private $method;
        private $code;
        private $image_dir;
        private $param_string;
        private $response;
        private $invalidResponse;
        private $parsedResponse = array();
    
        /**
         * @access Public
         * @param string $_key
         */
        public function __construct($_key = 'd112dc5c716d443af02b13bf708f73985e7ee943'){
            $this->setKey($_key);
            $this->setImageDir('images/');
        }
    
        /**
         * @access public
         * @name setImageDir()
         * @param Path of image Directory
         * @throws Exception
         */
        public function setImageDir($_image_dir){
            $this->image_dir = $_image_dir;
            if(substr($this->image_dir, -1) !== '/'){
                $this->image_dir .= '/';
            }
            if(!is_writable($this->image_dir)){
                throw new Exception('Image directory not writable.');
            }
        }
    
        /**
         * @access public
         * @param string $_key
         * @throws Exception
         */
        public function setKey($_key ){
            if(preg_match('#^[a-zA-Z0-9]{40}$#', $_key) || empty($_key) || ($_key === 'null')){
                $this->key = $_key;
            } else {
                throw new Exception('Invalid key or empty.');
            }
        }
    
        /**
         * @access public$
         * @name   setUserAgent()
         * @param  string $_user_agent
         */
        public function setUserAgent($_user_agent){
            $this->user_agent = $_user_agent;
        }
    
        /**
         * @access public
         * @name setReferer()
         * @param string $_referer
         * @throws Exception
         */
        public function setReferer($_referer){
            if(filter_var($_referer, FILTER_VALIDATE_URL)) {
                $this->referer = $_referer;
            } else {
                throw new Exception('Invalid URL');
            }
        }
    
        /**
         * @access public
         * @name getStatus()
         * @param string $_code
         * @param string $_method
         * @param bool $_plain
         * @return Xml
         * @throws Exception
         */
        public function getStatus($_code, $_method = 'xml', $_plain = false){
            if(!preg_match('#^[0-9]{1}[a-zA-Z]{1}[0-9]{11}#', $_code)) {
                throw new Exception('Invalid code.');
            }
            $this->code = $_code;
    
            $allowed_methods = array('xml', 'json', 'img');
    
            if(!in_array($_method, $allowed_methods)){
                throw new Exception('Invalid method.');
            }
            $this->method = $_method;
    
            $this->param_string = '?key='.urlencode($this->key).'&code='.urlencode($this->code);
    
            return $this->getResponse(!$_plain);
        }
    
        /**
         * @access private
         * @name getResponse()  
         * @param bool $_parse
         * @return type
         */
        private function getResponse($_parse = true){
            $ch = curl_init();
    
            $url = $this->host.$this->page.$this->param_string;
    
            if($this->method != 'img'){
                $url .= '&method='.$this->method;
            }
            curl_setopt($ch, CURLOPT_URL, $url);
            curl_setopt($ch, CURLOPT_USERAGENT, $this->user_agent);
            curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
            curl_setopt($ch, CURLOPT_FAILONERROR, true);
            curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 3);
            curl_setopt($ch, CURLOPT_TIMEOUT, 3);
            $data = curl_exec($ch);
            curl_close($ch);
    
            $this->response = $data;
    
            return ($_parse || $this->method == 'img') ? $this->parseResponse() : $this->response;
        }
    
       /**
        * @access private
        * @name parseResponse()
        * @return img, xml, json
        * @throws Exception
        */
        private function parseResponse(){
            switch($this->method){
                default:
                    throw new Exception('Invalid method.');
                    break;
                case 'img':
                    $newImg = imagecreatefromstring($this->response);
                    imagepng($newImg, $this->image_dir.$this->code.'.png');
    
                    $this->parsedResponse = array(
                        'code' => $this->code,
                        'image' => $this->image_dir.$this->code.'.png'
                    );
                    break;
                case 'xml':
                    $dom = new DOMDocument('1.0', 'utf-8');
                    if(!$dom->loadXML($this->response)){
                        $this->invalidResponse = $this->response;
                        $this->response = null;
    
                        if($this->invalidResponse != NULL ) {
                            return $this->invalidResponse;
                        } else {
                            throw new Exception("Invalid XML.\n\n" . $this->invalidResponse);
                        }
                    }
    
                    $this->parsedResponse['status']     = $dom->getElementsByTagName('status')->item(0)->nodeValue;
                    $this->parsedResponse['code']       = $dom->getElementsByTagName('code')->item(0)->nodeValue;
                    $this->parsedResponse['client']     = $dom->getElementsByTagName('client')->item(0)->nodeValue;
                    $this->parsedResponse['date']       = $dom->getElementsByTagName('date')->item(0)->nodeValue;
                    $this->parsedResponse['message']    = $dom->getElementsByTagName('message')->item(0)->nodeValue;
                    $this->parsedResponse['gamme']      = $dom->getElementsByTagName('gamme')->item(0)->nodeValue;
                    $this->parsedResponse['base_label'] = $dom->getElementsByTagName('base_label')->item(0)->nodeValue;
                    $this->parsedResponse['link']       = $dom->getElementsByTagName('link')->item(0)->nodeValue;
                    $this->parsedResponse['error']      = $dom->getElementsByTagName('error')->item(0)->nodeValue;
    
                    $this->parsedResponse = array_map('utf8_decode', $this->parsedResponse);
    
                    break;
                case 'json':
                    if($this->response === null){
                        $this->invalidResponse = $this->response;
                        $this->response = null;
    
                        if( $this->invalidResponse != NULL ){
                            return $this->invalidResponse;
                        } else {
                            throw new Exception("Invalid JSON.\n\n".$this->invalidResponse);
                        }
                    }
    
                    $this->parsedResponse = json_decode($this->response, true);
                    $this->parsedResponse = array_map('utf8_decode', $this->parsedResponse);
    
                    break;
            }
            return $this->parsedResponse;
        }
    }

     

    Pour l’utiliser rien de plus simple :

    try{     $colis = new ColissimoAPI();     $colis->setImageDir('tmp/'); // optionnal, default: images/
    
        $res = $colis->getStatus('XXXXXXXXXXXXX');
    }
    catch(Exception $e){
        echo $e->getMessage();
    }

    N’oubliez pas le « try catch » pour gérer proprement les erreurs.

    Bien à vous

    Grand maître L

  • CodeIgniter et la gestion des bases de données

    CodeIgniter est capable au travers de « drivers » de gérer plusieurs types de base de données tel-que :

    • Cubrid
    • msSql
    • mysql
    • mysqli
    • oci8
    • odbc
    • postgre
    • sqlite
    • sqlsrv

    Un grand choix donc. J’ai pu rajouter FirebridSQL car un pilote à été créé mais là je me suis rendu compte des limites du système.

    Je vous réexplique : j’ai 2 BDD sous FirebridSQL et une sous mySQL, mon objectif est de toutes les faire discuter.

    Dans la configuration on ne me propose de n’utiliser qu’un seul type de BDD avec n bases mais pas plusieurs BDD simultanément ou alors je n’ai pas trouvé comment.

    Tout l’intérêt de passer par le pilote du FrameWork c’est d’avoir Active Record pour interroger la base de donnée. Ce design pattern simplifie grandement le travail, il est fortement inspiré de ROR (ruby on rails).

    pour information voici ce qu’on peut faire avec une requête de sélection :

    $query = $this->db->get('mytable');

    Et c’est tout ! Extraordinaire non ? Bon allé c’est à peine plus long, voici un code complet qui va se retrouver dans un fichier de mon modele :

     <?php
     
     public function getSouplMuscById($configuration_exercice_id_fk, $bilan_id_fk, ){
            
                $this->db->select('valeur_1, valeur_2, masse');
                $this->db->from('exercice');
                $this->db->where('configuration_exercice_id_fk', $configuration_exercice_id_fk);
                $this->db->where('bilan_id_fk', $bilan_id_fk);
    
                $query = $this->db->get();
    
                if ($query->num_rows() > 0)
                {
                    foreach ($query->result() as $row ) {
                        array_push($this->_arraySouplMusc,
                                                     array(
                                                            $row->valeur_1,
                                                            $row->valeur_2,
                                                            $row->masse)
                                );
                        }
                    return (array) $this->_arraySouplMusc;
                } else {
                    return (bool) false;
                }
            }

     

  • Mes débuts avec Codeigniter

    Mes débuts avec Codeigniter

    Bonjour,

    Depuis quelque temps je me suis mis à travailler avec le framework MVC PHP  » CodeIgniter « .

     

    Ce cadre de développement à été choisis car après de nombreux test j’ai réussi à le faire fonctionner sur mon intranet qui présente une particularité au niveau du serveur web (IIS 6.0, php 5.3.x, mySql). j’ai aussi testé le zend FrameWork et à l’arrivée de la version 2.0 j’ai jugé qu’il était urgent d’attendre.

    Je vous propose une suite de petits billets sur son utilisation au quotidien.

    Sans plus attendre son installation :
    À ce stade rien de bien sorcier, il suffit de se rendre sur le site et de télécharger la dernière version en date (la 2.1.3 à l’heure où j’écris ces lignes).
    On dézippe le tout sur son serveur.
    Pour ma part, l’environnement de dev et de prod sont identiques, réduisant le risque d’incompatibilité.

    Mon projet à une spécificité, je doit me connecter à 3 bdd différentes.

    • une mysql
    • deux firebirdSQL

    Nativement codeIgniter est capable de se connecter à toutes ces bdd mais pas simultanément à plusieurs types de bdd :), si vous n’avez pas compris les commentaires sont là pour ça.

    le principe du MVC est le suivant :

    • m = Modèle => relation avec la bdd,
    • v = Vue => ce que vois l’utilisateur final (le html)
    • c = Contrôleur => c’est une sorte de gare de triage entre ce qui viens de la vue et ce qui viens du modèle pour tout organiser.

    Suite au prochain épisode…

  • PHP 5.4 est disponible en Rc2

    C’est toujours Agréable de voir que le langage PHP poursuit son bonhomme de chemin sans prendre de retard.

    En effet le 24 Novembre la devteam à mis à disposition la Rc2 dans un timing prévu il y a maintenant plus de 6 mois (du jamais vu !!!). Au passage, on apprend que nous aurons droit à une Rc3 car de nombreux bugs ont été corrigés.

    Pas de grandes nouveauté comme l’indique Mageekblog à l’exception d’une fonctionnalité ajouté à SOAP.

    @plus Grand Maître L

  • Gerer les dates en php avec la class transDater

    Avec cette petite class je gère les dates plus facilement. Bien sûr on peut toujours l’améliorer pour lui rajouter la prise en charge de timestamp par exemple, je reste ouvert à vos suggestions.

    
    /**
     * transDater
     *
     * @package
     * @author luc
     * @copyright Copyright (c) 2012
     * @version $Id$
     * @access public
     */
    /* la date en entrée doit être valide mais pas de type timestamp */
    class TransDater {
    
        /**
         * TransDater::dateTransform()
         *
         * @param string $dateString
         * @param mixed $newDateFormat
         * @return
         */
        static function dateTransform($dateString = '01-01-1979', $newDateFormat) {
            if ($dateString && ($format = $newDateFormat)) {
                $date = new DateTime($dateString);
                return $date->format($format);
            }
            return (bool) false;
        }
    
        /**
         * *Si on récupère le numéro du mois de l'année on peut le transformer en nom en toutes lettres
         */
        static function monthTransformFr($date) {
            static $mois = array(
                '01' => 'janvier',
                '02' => 'fevrier',
                '03' => 'mars',
                '04' => 'avril',
                '05' => 'mai',
                '06' => 'juin',
                '07' => 'juillet',
                '08' => 'aout',
                '09' => 'septembre',
                '10' => 'octobre',
                '11' => 'novembre',
                '12' => 'decembre'
            );
            $m           = self::dateTransform($date, 'm');
    
            if (!empty($mois[$m])) {
                return (string) $mois[$m];
            }
        }
    
        /**
         * TransDater::dayWord()
         * @abstract Si on récupère le numéro du jour de l'année on peut le transformer en nom en toutes lettres (0->français,1->Anglais,2->Allemand)
         * @param mixed $date
         * @param mixed $int
         * @return
         */
        static function dayWord($date, $int) {
            $french  = array('dimanche', 'lundi', 'mardi', 'mercredi', 'jeudi', 'vendredi', 'samedi');
            $english = array('Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Monday');
            $german  = array('Dienstag', 'Mittwoch', 'Donnerstag', 'Freitag', 'Samstag', 'Sonntag', 'Montag');
            switch ($int) {
                case 0 : $day = $french;
                    break;
                case 1: $day = $english;
                    break;
                case 2: $day = $german;
                    break;
                default:
                    false;
            } // switch
            $d = self::dateTransform($date, 'w');
            if (!empty($day[$d])) {
                return (string) $day[$d];
            }
            return (bool) false;
        }
    
        /* fonction : bissextile */
    
        static function leapYear($date) {
            $date = self::dateTransform($date, 'y-m-d');
    
            if ((is_int($date / 4) && !is_int($date / 100)) || is_int($date / 400)) {
                return (bool) true;
            } else {
                return (bool) false;
            }
        }
    
        /**
         * TransDater::datePlusUnMois()
         *
         * @abstract fonction rajoutant un mois a une date
         * @param mixed $date
         * @return string date plus 1 mois
         */
        static function datePlusUnMois($date) {
            $newDate = new DateTime($date);
            $newDate->modify('+1 month');
    
            return (string) $newDate->format('Y-m-d');
        }
    
        /**
         * TransDater::dateMoinsUnJour(()
         *
         * @abstract fonction enlevant 1 jour à une date
         * @param mixed $date
         * @return string date moins 1 jour
         */
        static function dateMoinsUnJour($date) {
            $newDate = new DateTime($date);
    
            return $newDate->modify('-1 day');
        }
    
        /**
         * TransDater::age()
         *
         * @abstract Fonction pour calculer l'age
         * @param string  date de naissance type 'd/m/Y'
         * @param string  date à laquelle on veux calculer l'age
         * @return age /integer
         */
        static function age($date_naissance, $currentDate = NULL) {
            if ($date_naissance != NULL) {
                if ($currentDate == NULL) {
                    $currentDate = date('d/m/Y');
                }
            }
            $arr1 = explode('/', $date_naissance);
            $arr2 = explode('/', $currentDate);
            if (($arr1[1] < $arr2[1]) || (($arr1[1] == $arr2[1]) && ($arr1[0] <= $arr2[0]))) {
                return $arr2[2] - $arr1[2];
            }
            return (int) $arr2[2] - $arr1[2] - 1;
        }
    
        /**
         * returns the difference, in days, between two dates.  avoids the daylight's savings issue by using GMT
         */
        static function dateDiff($date1, $date2) {
            $date1 = date_parse($date1);
            $date2 = date_parse($date2);
            return ((gmmktime(0, 0, 0, $date1['month'], $date1['day'], $date1['year']) - gmmktime(0, 0, 0, $date2['month'], $date2['day'], $date2['year'])) / 3600 / 24);
        }
    
        /**
         * @name dateExcelToHuman()
         * @param string $date
         * @return string date
         */
        static function dateExcelToHuman($date) {
            $date = ($date - 25569) * 86400;
            return (string) date('Y-m-d H:i:s', $date);
        }
    
        /**
         * @abstract Returns elapsed time with human format in french
         *
         * @param     int The timestamp of the date
         * @return    string
         */
        public function elapsed_time($date) {
    
            $old_time = $date;
    
            // Current time
            $time = time();
    
            // Little check
            if ($time < $old_time) {
    
                return FALSE;
            }
    
            // Get seconds elapsed
            $seconds = round($time - $old_time);
    
            // Convert into minutes
            $minutes = round($seconds / 60);
    
            // Convert into hours
            $hours = round($minutes / 60);
    
            // Returns
            if ($hours >= 72) {
                return 'Le ' . date('d/m/Y', $old_time);
            } elseif ($hours >= 48 && $hours < 72) {
                return 'Avant Hier';
            } elseif ($hours >= 24 && $hours < 48) {
                return 'Hier';
            } elseif ($hours >= 1) {
                return 'Il y a ' . $hours . ' h';
            } elseif ($minutes >= 1) {
                return 'Il y a ' . $minutes . ' mn';
            } elseif ($seconds == 0) {
                return 'A l\'instant';
            } else {
                return 'Il y a ' . $seconds . ' s';
            }
        }
    
        static public function addSeconde(\DateTime $date, $seconde) {
            return self::addInterval($date, 'PT' . (int) $seconde . 'S');
        }
    
        static public function addMonth(\DateTime $date, $month) {
            return self::addInterval($date, 'P' . (int) $month . 'M');
        }
    
        static public function addDay(\DateTime $date, $day) {
            return self::addInterval($date, 'P' . (int) $day . 'D');
        }
    
        static public function addYear(\DateTime $date, $year) {
            return self::addInterval($date, 'P' . (int) $year . 'Y');
        }
    
        static public function addInterval(\DateTime $date, $value) {
            try {
                $interval = new \DateInterval($value);
                $date->add($interval);
            } catch (Exception $exc) {
                throw new \Exception(__METHOD__ . 'The format of $value is not valid (String) exemple : P55S (add 55 second) ');
            }
            return $date;
        }
    
    }
    
    

    à bientôt Grand maître L

  • Php 5.4 Alpha 1, quand php renait de ces cendres…

    Php 5.4 Alpha 1, quand php renait de ces cendres…

    Une nouvelle mouture de notre langage de prédilection présente le bout de son nez. Malgré les apparences, il s’agit d’une version en réalité majeure. En effet, la mort de PHP6 il y a plus d’un an pour cause de problème d’intégrations de l’Unicode a chamboulé le planning.

    C’est pour cela qu’une version alpha vient d’être mise à disposition sur le SVN de PHP.net.

    Les contributeurs ne se sont pas endormis, car plus de 6 000 points ont été modifiés. De nombreuses idées de PHP6 ont été implémentées. Malheureusement, la bonne idée de l’Unicode a été repoussée sans date.

    Comment fonctionne PHP ?

    PHP est un langage de programmation impérative de type CGI, qui peut être utilisé en procédural ou orienté objet (POO). C’est un langage de haut niveau qui doit être exécuté par une machine spéciale pour fonctionner, généralement un serveur (cette exécution ne peut pas être accomplie par un navigateur, il en est incapable).

    Pour que le PHP soit interprété, il faut qu’on lui dise comment ; c’est le rôle du moteur de PHP, appelé Zend Engine.

    Ce moteur est écrit en C. C’est le cœur du langage ; c’est en fait lui qui évolue à chaque nouvelle version.

    Les nouveautés

    Principaux changement apportés

    safe_mode, register_globals et register_long_array sont définitivement supprimés de PHP. De quoi ravir les développeurs, qui n’aurons plus à réaliser toute une série de vérifications concernant ces directives de configuration.

    Pour le register_globals, on peut dire que c’est une vraie avancée en termes de sécurité, même si depuis de nombreuses versions cette fonction était désactivée par défaut dans le php.ini.

    Avec le register_globlals à « ON », on ne faisait pas de différence entre une variable superglobale et une variable « interne » : un vrai problème de sécurité, car on ne savait pas si une variable venait du site — et donc était fiable — ou de l’extérieur, et par conséquent potentiellement dangereuse.

    Concernant le safe_mode et register_long_array, la documentation de PHP indique en effet :

    Citation : Documentation PHP

    Cette fonctionnalité est OBSOLÈTE depuis PHP 5.3.0. Nous vous encourageons vivement à ne plus l’utiliser.

    Les ajouts apportés à cette version

    Il est maintenant plus explicite de passer des arguments en références.

    Pour rappel, voici comment on passe un argument en référence avec PHP :

    Code : PHP – Soumission d’argument sous forme de référence

     <?php 
    function foo( & $var){
     $var++; 
    } 
    
    function & bar(){ 
    $a=5; return $a; 
    } 
    
    foo ( bar ()); 
    ?>

    Un passage par référence va modifier la variable inscrite en mémoire par une nouvelle version de cette variable, c’est le & devant $var qui le permet.

    Il est aussi possible de faire ceci, actuellement :

     <?php 
    myFunction(& $toto); 
    ?>

    Un simple avertissement est généré sous PHP 5.3. Désormais, avec PHP 5.4, le code plante et renvoie une erreur.

    Les traits

    Une nouvelle fonctionnalité (un conteneur) apparaît également : les traits. C’est un regroupement de méthodes qui peuvent être partagées entre différentes classes (ce qui est différent de l’héritage et des interfaces).

    Image utilisateur Plus d’informations sur les traits.

    Ajout du support d’Autoconf

    GNU Autoconf, livré avec PHP 5.4 dans sa version 6.59, est un outil permettant de générer des scripts shell qui configurent automatiquement les sources d’un logiciel dans l’optique de l’adapter aux systèmes UNIX (Linux, Mac OS X, etc.).

    Notez que Autoconf ne fait que configurer : il n’est pas nécessaire aux personnes exécutant le script d’avoir Autoconf installé sur leurs machines.

    Image utilisateur Plus d’information sur Autoconf.

    Image utilisateur Image utilisateur Description officielle d’Autoconf.

    La feuille de route

    • Le 28 juin 2011, la version alpha 1 sera publiée.
    • Le 26 juillet, ce sera au tour de l’alpha 2.
    • La version bêta sera livrée le 23 août.
    • Enfin, la version Relase Candidate n° 1 (RC 1) sera publiée le 20 septembre 2011.
    • Après cela, une version RC sera publiée toutes les deux semaines, jusqu’à la version stable.

    Les dates présentées ci-dessus sont cependant susceptible d’être modifiées.

    La communauté de PHP

    Tout comme la communauté de l’anneau, la communauté de PHP était lancée pour fait de grandes choses car elle était unie. Cependant, des divisions apparaissent régulièrement sur la gouvernance et la prise de décisions.

    On peut en gros la diviser en deux groupes : les contributeurs historiques et les nouveaux contributeurs.

    Les contributeurs historiques considèrent que l’évolution doit aller vers une stabilisation du langage, une éradication des bugs et une simplification, alors que les autres aimeraient que les nouveautés soient implémentées plus rapidement pour ne pas se retrouver à attendre trop longtemps des fonctionnalités qu’ils jugent essentielles pour programmer avec des méthodes modernes.

    La dissolution des développeurs de PHP n’est heureusement pas à l’ordre du jour, mais il manque pourtant un leader.

    Rasmus Lerdorf, le créateur de PHP, serait capable de dire où il faut aller, néanmoins, il se contente de prendre le rôle de médiateur. Cette situation a conduit à un drame (la mort de PHP6), de nombreuses leçons doivent donc en être tirées…

    Image utilisateur Vous pouvez trouver la liste complète des nouveautés de cette version en vous rendant ici.

    Sources

    <pre class= »brush:[php] »>
  • Une fonction pratique pour vérifier la conformité d’un numero de téléphone en PHP

    En se moment je travail sur de petites fonctions bien pratiques que je pourrais réutiliser un peut partout dans mes projets.

    J’ai créé cette fonction pour répondre à un besoin simple et elle me satisfait

    Cette fonction renvoie true en cas de succès si non false.

    //fonction pour vérifier la conformité d'un numéro de tel Français
    function VerifTelFr($chaine){
    	$regex = "#^0[1-68]([-. ]?[0-9]{2}){4}$#";
    		if (preg_match($regex,$chaine)){
    					return true; 
    			} else {
    					return false;
    		}
    }
    

    @ bientôt Grand Maître L