Grâce à Fahed j’ai pu découvrir Lovely Charts . Il faut s’inscrire, mais c’est gratuit.
Il permet de créer des diagrammes en ligne. Comme le permet Visio sur votre PC.
Mais là s’arrête le point commun entre ces 2 outils car Lovely Charts est d’une simplicité d’utilisation déconcertante quand on n’a connu que visio.
A présent il n’est donc plus nécessaire de perdre des heures sur visio pour :
dessiner des schémas pour un réseau informatique
réaliser des diagrammes de toutes sortes
dessiner des formulaires web (tous les types sont déjà pret, checkbox et select par exemple)
J’ai même pu faire un schéma pour une base de données en un temps record.
Les schemas que j’ai réalisé sont confidentiels… il va falloir aller tester vous même, c’est si bien fait qu’on a même pas besoin de période d’apprentissage : http://my.lovelycharts.com/
voici l’interface :
Lorsque l’on veut lier des objets, finalement il suffit juste de changer de mode en cliquant sur le 2e boutons ci-dessous, puis on repasse dans le mode normal en cliquant sur le premier bouton :
Il y fait allusion rapidement à MAMP, mais ce logiciel ne nous avait pas convaincu car il oblige à laisser tourner un logiciel et nous n’avions pas pu ajouter les modules que nous souhaitions. MacPorts fonctionnera plutôt comme un daemon.
MAMP conviendra à quelqu’un qui code “tous les 36 du mois” certainement.
Voici un copier/coller pour le cas où la page ne serait plus joignable :
J’en ai déjà parlé, la version de PHP fournie avec Mac OS X Leopard est assez… épurée : pas de GD ou de PEAR par exemple et la compilation d’extensions ne marchent pas (cf. mon billet sur Runkit). Pour une utilisation (très?) basique de PHP cela suffira mais si vous voulez, par exemple, manipuler des images il faudra utiliser une autre solution…
Parmi les autres solutions possibles, j’ai choisi d’utiliser MacPorts et de compiler “moi-même” PHP. Certains auraient peut-être choisi MAMP qui est une solution plus simple et plus “rapide” mais peut-on compiler des extensions avec ? A priori oui mais je n’en suis pas sûr. L’objectif est aussi de pouvoir installer d’autres packages que le trio Apache-MySQL-PHP et de mettre à jour ces packages très simplement (une ligne de commande).
Pour ceux que cela intéresse, voici la procédure pour installer et configurer Apache-MySQL-PHP avec MacPorts sur Leopard. A noter que je suppose que vous avez déjà installé les “Developper Tools” d’Apple.
Installation de MacPorts
Téléchargez MacPorts sur le site officiel : http://www.macports.org/
Ouvrez l’image disque (.dmg)
Lancez le .pkg et suivez les instructions.
Une fois l’installation terminée, allez dans le terminal et lancez la commande :
sudo port selfupdate
Installation d’Apache 2.2
Installez Apache 2.2 en exécutant la commande qui suit dans le terminal :
sudo port install apache2
Une fois l’installation terminée, lancez Apache :
sudo /opt/local/apache2/bin/apachectl start
Si vous allez à l’adresse http://localhost vous devriez voir “It works!” à l’écran.
Si vous souhaitez qu’Apache soit lancé au démarrage de votre ordinateur, lancez la commande ci-dessous :
Vous pouvez maintenant créer dans votre dossier Sites (/Users/votrePseudo/Sites/) un fichier phpinfo.php
Voilà, votre environnement de développement AMP est installé et prêt à acceuillir vos scripts et applications ! Pour aller un peu plus loin, vous pouvez installer phpmyadmin et xdebug, avec MacPorts bien sûr.
Concernant MacPorts, je l’utilise depuis maintenant plusieurs mois et j’en suis très content. J’ai pu installer tous les packages dont j’avais besoin très simplement et sans problème. Je regrette juste de ne pas l’avoir découvert plus tôt…
Si vous ne pouvez plus insérer d’enregistrement dans une base sous MySQL qui vous dit :
#1114 – The table ‘*****’ is full
Et que vous êtes en innoDB et que vous n’avez pas de problème d’espace disque après vérification, c’est sans doute qu’une limitation explicite dans le fichier de configuration de mySQM : /etc/mysql/my.cnf
Il faut donc ajouter plus de place à la base de donnée (parametre en rouge dans l’exemple suivant) :
# you may wish to change this size to be more suitable for your system
# the max is there to avoid run-away growth on your machine
innodb_data_file_path = ibdata1:10M:autoextend:max:256M
Là on a mis 256MO (117MO réels) au lieu de 128MO
C’est vraiment évident non ?
Toutes nos imprimantes ont la possibilité d’être surveillées en SNMP. Il devient intéressant d’avoir une vue d’ensemble sur une page web.
Au départ j’ai utilisé le PHP pour récupérer les numéros MIB utiles à la configuration de Nagios pour ajouter les imprimantes à notre monitoring. Puis il s’est avéré plus utile de garder la page PHP lorsque Canon nous appelait pour savoir si telle ou telle imprimante fonctionnait bien (ils sont capables de recevoir des messages pour le début de pannes, mais pas pour leur fin… vive le 21e siècle chez Canon).
Donc j’utilise la commande suivante sous linux
snmpwalk -Oa -v1 -c public x.x.x.x mib-2.43.18.1.1.8
x.x.x.x étant l’adresse IP ou le nom DNS de l’imprimante.
Cela m’a donné un code PHP ressemblant à ceci (bien sûr c’est un code écrit rapidement que j’améliorerais à l’usage) :
//-Oa permet d’éviter d’avoir des messages en Hexa
//mib-2.43.18.1.1.8 semble dans notre cas rassembler tous les messages d’erreurs
$cmd = “snmpwalk -Oa -v1 -c public $printer mib-2.43.18.1.1.8″;
//$output n’est pas correctement vidé à chaque usage de exec
unset($output);
exec($cmd,$output,$retourne);
//si la commande Shell a retourné une erreur on l’affiche (parfois juste une erreur dans l’adresse)
if($retourne != 0)
$printers_tab[$printer][0] = “erreur({$retourne})<br/>\n”;
//sinon, s’il n’y a aucun message on place un message indiquant que tout est “OK”
else{
$nbmsg = count($output);
if($nbmsg == 0) $printers_tab[$printer][0] = “OK”;
//et sinon on récupère tous les messages
else
for($i=0; $i < $nbmsg; $i++)
$printers_tab[$printer][$i] = $output[$i];
}
}
/****************************************************************************
* $printers_tab["nom_imprimante"][0-n] contient tous les messages à afficher par imprimante
***************************************************************************/
//affichage dans une liste
$html.= ”
<!– liste des imprimantes –>
<div id=’imprimantes’>
<ul id=’liste_imprimantes’>
“;
//pour chaque imprimante
foreach($printers_tab as $name=>$messages){
//pour chaque message correspondant à l’imprimante $name
foreach($messages as $message){
$message = trim($message);
//les 30 premieres caractère correpondent à SNMPv2-SMI::mib-2.43.18.1.1.8.
//je garde les derniers numéros pour tenter d’en comprendre la logique
$afficher = substr($message, 30);
//moins de 30 caractères correspond à un message non attendu qu’on affichera
if(empty($afficher))
$afficher = $message;
Orange met à disposition une API pour accéder à notre messagerie vocale.
Cela signifie que l’on peut créer des applications (donc des sites web) qui permettent d’accéder à notre messagerie vocale.
Cela permet par exemple :
d’avoir un répondeur où les auditeurs laissent des messages et de laisser tout le monde les écouter sur le net
de supprimer les messages une fois récupéré en mp3, changer l’annonce.
On peut enfin archiver définitivement tous ses messages sans limite.
récupérer ses messages par email (pratique à l’étranger !)
etc etc etc
Une annonce personnalisée enfin paramétrable par heure. On peut enfin informer tous les mardi soir que si on est injoignable c’est parce qu’on a piscine ! et. Il doit y avoir des applications plus pratiques comme empêcher de laisser des messages le week-end et la nuit.
Lorsqu’on envoi un email via nos applications “maison”, il arrive incroyablement souvent que l’encodage du sujet soit laissé de coté. CodeIgniter n’échappe pas à la règle.
Des antispam comme spamassassin pénalisent fortement ce genre de courrier.
La RFC 2047 indique comment doit être encodé un sujet d’email. C’est assez simple, ça utilise le même encodage que les url - en php la fonction urlencode() peut donc être utilisée - à l’exception des caractères = qui remplacent les caractères % habituels et des espaces qui n’ont pas à être remplacés par des +
Spamassassin pénalise également les emails qui contiennent plusieurs fois l’indication de l’encodage, bien que la rfc l’autorise. Nous allons donc indiquer une bonne fois pour toute en début et ne plus le mentionner. Donc le sujet doit commencer par =?UTF-8?Q?
Et voila, nos emails seront beaucoup mieux notés par les messageries qui utilisent Spamassassin comme antispam et nous aurons la satisfaction de respecter les normes internet.
Il nous arrive parfois de demander conseils pour des portions de code via internet.
http://pastie.org/ est très pratique dans ce cas, il permet d’y faire un copier-coller de la portion de code en indiquant son langage (C++, PHP, Ruby, CSS, HTML, Javascript…) et cela nous retourne une URL que l’on peut diffuser. Voici un exemple : http://pastie.org/225942
Ayant besoin d’une excuse pour avancer le rodage de ma moto (l’autoroute à 80km/h ça va un temps ! vivement que les 1000km soient faits), je me suis rendu à Beaubourg (centre Pompidou) pour un festival sur le Flash. Les jeux présentés en flash étaient un pur plaisir la conférence à laquelle j’ai assisté concernait plus les graphistes alors j’ai moyennement apprécié.
Celui qui m’a le plus marqué restera sans contestation possible Crayon Physics Deluxe. Le but est assez simple : attraper le drapeau avec la balle rouge. Pour bouger la balle, vous pouvez dessiner des objets qui vont interagir avec le décor suivant les lois de la physique. Vous pouvez aussi relier des objets entre eux à l’aide des chevilles.
A chaque fois que je modifie un fichier php sur mon ordinateur (Mac OS X, donc avec rsync intégré), je lance un upload en sftp vers le serveur de dev pour voir le résultat (avec Filezilla). La manip est faite si souvent qu’il devient très rentable – et surtout beaucoup plus sûr – d’en faire un script.
La chance c’est que rsync fonctionne avec ssh, et j’ai toujours utilisé des systèmes de clé pour me connecter. Tout est donc déjà en place pour que la synchro fonctionne d’un simple click :