Warning: Parameter 1 to behaviorsPagesStatiques::addTplPath() expected to be a reference, value given in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php on line 304

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/libs/clearbricks/common/lib.http.php on line 248

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/libs/clearbricks/common/lib.http.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/libs/clearbricks/common/lib.http.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/libs/clearbricks/common/lib.http.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/public/lib.urlhandlers.php on line 85

Warning: Cannot modify header information - headers already sent by (output started at /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/core/class.dc.core.php:304) in /home/flyounet/dev.flyou.net/dotclear-2.2.3/inc/libs/clearbricks/common/lib.http.php on line 273
Tag - Script - Flyou.net [Dev] : Développements

Aller au contenu | Aller au menu | Aller à la recherche

Flyou.net [Dev] : Développements

jeudi 27 mai 2010

Quel est le meilleur moyen pour savoir le nom d'un fichier pointé par un lien ?

Vaste question qui ne me semble reposer que sur 3 réponses :

  • L'utilisation de stat,
  • L'utilisation de file,
  • L'utilisation de readlink.
Utilisons stat :
fly@Capote:~/tmp$ stat /tmp/totoz
  File: `/tmp/totoz' -> `/tmp/pipo'
  Size: 40        	Blocks: 0          IO Block: 4096   lien symbolique
Device: 808h/2056d	Inode: 3744        Links: 1
Access: (0777/lrwxrwxrwx)  Uid: ( 1000/     fly)   Gid: ( 1000/     fly)
Access: 2010-05-27 23:42:00.590730266 +0200
Modify: 2010-05-26 23:34:46.978029853 +0200
Change: 2010-05-26 23:34:46.978029853 +0200

On constate que le nom du fichier pointé est indiqué en première ligne. Donc, la ligne suivante devrait suffire :

fly@Capote:~/tmp$ a="$(stat /tmp/totoz | head -1 | awk '{print $NF}')" ; echo ${a}
`/tmp/pipo'

C'est bien mais pas top avec les quotes, d'où l'astuce suivante :

fly@Capote:~/tmp$ i=${#a}; echo ${a:1:(($i-2))}
/tmp/pipo
Utilisons file :
fly@mst:~/tmp$ file /tmp/totoz
/tmp/totoz: symbolic link to `/tmp/pipo'

On constate maintenant qu'une seule ligne est retournée, mais il y a toujours ce problème de quotes. Donc, on résout de la même manière :

fly@mst:~/tmp$ a="$(stat /tmp/totoz | awk '{print $NF}')" ; echo ${a}
`/tmp/pipo'
fly@mst:~/tmp$ i=${#a}; echo ${a:1:(($i-2))}
/tmp/pipo
Utilisons readlink :
fly@Capote:~/tmp$ readlink /tmp/totoz
/tmp/pipo

Bon, ben voilà; finalement je le préfère ce petit readlink (et de loin)...

jeudi 20 mai 2010

dueTasks.php v0.01 for TaskFreak !

TaskFreak ! is a PHP tools to manage your Todo list. Written by Stan Ozier the v0.62/v0.63 lacks a tool to send email for due tasks. Here is my little contribution.

Please note, it has only be tested with the multi version (not the single).

Lire la suite...

lundi 3 mai 2010

F01common.lib v0.28

Because I need it, I implement the statusBar function. Test statusBar 01 Test statusBar 02 I tested with KSH and Bash and it seems to work with both.

Changelog :

+ statusBar : generate the informations to have a status bar.
   eg. 0%....5%....10%.... and so on until 100%

Lire la suite...

jeudi 29 avril 2010

bashColors.sh v0.03

Purpose :

As I am writting more Shell code every day. I often need to use color to show to my users the huge mistake they're trying to put with my Shell script[1]
As my wife calls me Red Fish[2], I rarely figure what is the reference for Shell colors. That's why I made this little Script.

Changelog :

v0.01 [30/03/2010] Flyounet  [@Home] :
      > Initiale Release
      > Prerequisites : F01 common.lib (at least v0.24)
v0.02 [21/04/2010] Flyounet  [@Home] :
      > Now Under DSSL & GPLv3
      > set ts=4 ; set noai
      + Add information how to quit
      * When run with Ksh, it show errors about declare... Erased them &
        use typeset instead.
v0.03 [27/04/2010] Flyounet  [@Home] :
      + Added the work 'effect' in the rainbowTable function
      > Now use the F01common.lib v0.27

Notes

[1] It remembers me a newbie that wants to put his saves in /dev/null, because he read on Internet, this folder compress incredibly everything. Don't laught ! I'm pretty sure everyone already met one of this people...

[2] I now know it's for my memory.

Lire la suite...

mardi 27 avril 2010

F01common.lib v0.27

Due to lots of bugs in the previous version, I'm happy to show you this one with I hope no bug inside.

Nearly all tests have been done with Ksh, and unfortunately I forget to test under Bash, and that's the result... Sorry.

Changelog :

 > Problem with the Bash version. If old Bash is use BASH_SOURCE
   doesn't exist...
   Now looks for the files instead of trying to load it directly to
   avoid, error messages. Search in above and under directory.
 * F01Version return the path of the Bash extension.
 * trim : Huge bug ! Instead of unsetting __ltrim & __trim, i unsetted
   functions ltrim & rtrim...
 > ltrim & rtrim don't work under Bash ! ARGGGGGGGGGGGGG !!!!!
 * iniParseFile : In case of a line only containing a left var with
   incorrect character (like a dash -), the awk version sent an error
   to the output (and under Ksh stops).
   Function has been rewritted purely in Shell...
 * sprintf : Problem under Bash. Bash doesn't support only one _ as a
   variable name : Corrected.
 * iniGetValue : Not use grep anymore. Only Shell !
 * fileCheck : Problem under Bash. Bash doesn't support only one _ as
   a variable name : Corrected.
 * logMe : Problem under Bash. Bash doesn't support only one _ as a
   variable name : Corrected.
 > Now only logRotate use non-shell programs !
 + myError : If none args then empty __lastError

Lire la suite...

jeudi 22 avril 2010

F01common.lib v0.26

J'ai oublié de publier les précédentes versions, aussi je vous présente cette nouvelle version.

Après pas mal de boulot, il ne reste plus que la fonction iniParseFile qui continue d'utiliser awk, sinon tout le reste n'utilise plus que le Shell avec lequel il a été exécuté.
Et j'en ai profité pour passer le code sous GPLv3 et DSSL (disponible ).

L'incontournable Changelog :

 v0.23 [30/01/2010] Flyounet  [@Home] :
       * fileCreate: In case of error during touch an ugly message is now
         sent to /dev/null (for chmod too)
 v0.24 [03/03/2010] Flyounet  [@Home] :
       > First svn version
 v0.25 [01/04/2010] Flyounet  [@Home] :
       + textFill: equivalent to perl "string" x number
       + textBox: put a caracter all around a text
       * textBox: not working with KSH
       + _str2lower & _str2upper have been added, cause to KSH that doesn't
         support Case modification of Bash.
       * textBox: now use _str2*er and work with KSH
       * iniGetValue: Remove the call to awk (Yeah ! Love shell !)
 v0.26 [22/04/2010] Flyounet  [@Home] :
       + parseHeadersForHelp: Print the headers of each function in a file.
         Headers are based on a first line containing a #F??.
       > textBox: Only works with KSH... Fuck !
       * textBox: A subfile is needed to make it works with bash.

J'ai tenté de la rendre la plus indépendante possible de sed et awk qui sont assez incontournable[1]. Elle fonctionne sous bash ou ksh.

Ci-dessous un aperçu des variables et fonctions : common.lib.png

En annexes sont fournis les fichiers indépendants, ainsi qu'une archive regroupant le tout.
Les fichiers sont :

  • common.lib_v0.26.tar.bz2 : L'archive qui contient tous les fichiers,
  • common.lib.README : Une micro documentation,
  • common.lib : La librairie Shell,
  • _common4bash.lib : L'extension pour Bash de la fonction textBox(),
  • doc/common.lib.mm : La liste de fonctions et variables sous forme de fichier Free(Mind|Plane),
  • doc/common.lib.png : La liste de fonctions et variables sous forme de fichier image,
  • test/libHelp.sh : Un script de test qui retourne de l'aide sur les fonctions,
  • test/test_common-lib.conf : Un fichier de configuration pour exécuter le script de test,
  • test/test_common-lib.sh : Un script de test, qui exécute quasiment toutes les fonctions de la librairie.

Les md5 des fichiers :

26ecc237a2dcc4f74f3a21ed3db809d6  _common4bash.lib
2c540c2a2516829a7f0796ebdc789979  common.lib
07d486cdcf8c5623a2a17b7183c0b7be  common.lib.README
dde7d1862448a90eaadfd8e2ee5ec811  doc/common.lib.png
606b099e82e48e846c71555b2827237a  doc/common.lib.mm
d04d3958e604ffdd69d5387d6c95110f  test/libHelp.sh
51504fd29f5fd1aa73137d73657536ae  test/test_common-lib.conf
21793fdcd0cc20cf16743e223d157a63  test/test_common-lib.sh
4cef5fce3dc9d224333540b91bd53f61  F01common.lib_v0.26.tar.bz2

Les sha1 des fichiers :

123dfbdbce15d27c0d5ca8a927d5d2fe0a575b41  _common4bash.lib
72e7de48dd30ef059bc16bbd809536505de62cdf  common.lib
fa9dead34dbc604a49ddf15b81805d288a9a0157  common.lib.README
0acab9ac384dfb9ce9e30baa4195cd2088fc069b  doc/common.lib.png
d32b6a8c2ad02816031b1e2f39dde6d7f41818af  doc/common.lib.mm
f8f1bf4afb8e54ec122f5f6e67a8a0bba72e98c8  test/libHelp.sh
34a05abbd28321b353c34b4003b7e001afd8a1b0  test/test_common-lib.conf
db07298d8710c78ca681dc4496408ee4901aa000  test/test_common-lib.sh
b849101928c71eec69f7623b233f369bf0dcfd3c  F01common.lib_v0.26.tar.bz2

Ci-dessous la liste des fonctions :

#F01.01.03
#Function : ps2, Print to screen string passed in argument
#F01.02.02
#Function : p2st, Print to screen string passed in argument, with Time before
#F01.03.01
#Function : oops, Print to screen string passed in argument, and exit 1
#F01.04.01
#Function : oopst, Print to screen string passed in argument, with time before, and exit 1
#F01.05.06
#Function : myDebug, Print to screen string passed in argument if debug level is reach
#F01.06.02
#Function : myError, Store error in variables
#F01.07.02
#Function : fileCheck, Check file for presence and permission
#F01.08.02
#Function : fileCreate, Create file with permissions if asked
#F01.09.01
#Function : fileDelete, Delete the specified file
#F01.10.04
#Function : iniGetValue, Get the value from a specified INI file
#F01.11.04
#Function : iniParseFile, Set all values from a specified INI file
#F01.12.03
#Function : trim, Remove all blank from begining and end
#F01.13.03
#Function : logRotate, Transfer the begining of a file to the rotationned version.
#F01.14.01
#Function : logMe, Send the log to the log files
#F01.15.01
#Function : logMeV, Send the log to the verbose log files
#F01.16.03
#Function : isFunction, Verify that the function exists
#F01.17.07
#Function : sprintf, return a formatted string
#F01.18.02
#Function : ltrim, Remove all blank from begining
#F01.19.02
#Function : rtrim, Remove all blank from end
#F01.20.01
#Function : _str2lower, lower all characters
#F01.21.01
#Function : _str2upper, upper all characters
#F01.22.01
#Function : textFill, Create a text filled by the caracter
#F01.23.03
#Function : textBox, Create a box around the text
#F01.24.05
#Function : parseHeadersForHelp, Print headers of function for a given file
#F01.99.02
#Function : F01Version, Return/Print version information
#F01.23-1.02
#Function : _textBox4Bash, Create a box around the text

Notes

[1] Mes fonctions préférées sont sans aucun doute : sprintf et les *trim.

lundi 25 janvier 2010

F01common.lib v0.22

Après plusieurs mois à codouiller[1] des petits bouts de script Shell, j'ai décidé d'en faire librairie : F01common.lib.

J'ai tenté de la rendre la plus indépendante possible de sed et awk qui sont assez incontournable[2]. Elle fonctionne sous bash ou ksh.

Ci-dessous un aperçu des variables et fonctions : common.lib_v0.22.png

En annexes sont fournis les fichiers indépendants, ainsi qu'une archive regroupant le tout.
Les fichiers sont :

  • common.lib.README : Une micro documentation,
  • common.lib_v0.22 : La librairie Shell,
  • common.lib_v0.22.mm : La liste de fonctions et variables sous forme de fichier Free(Mind|Plane),
  • common.lib_v0.22.png : La liste de fonctions et variables sous forme de fichier image,
  • common.lib_v0.22.tar.bz2 : L'archive qui contient tous les fichiers,
  • test_common-lib.conf : Un fichier de configuration pour exécuter le script de test,
  • test_common-lib.sh : Un script de test, qui exécute quasiment toutes les fonctions de la librairie.

Les md5 des fichiers :

16fc140f5a69acdcbe5e1a21be185772  common.lib.README
3f5c5a78a3bc2da85e86395d65b88188  common.lib_v0.22
31bd6704a048d38ba1479ec42a0e97b2  common.lib_v0.22.mm
d273f4afd7a95aa8aa899e53f5dca904  common.lib_v0.22.png
1d0c7dd2ce3d264a14bfd442dadf0d24  common.lib_v0.22.tar.bz2
4c550b4593b12cd849af697313139e33  test_common-lib.conf
5520dd6882f166f4688ffef981187b41  test_common-lib.sh

Les sha1 des fichiers :

076770bedcfef3cc2568b0d00185c47a5c84ab89  common.lib.README
b9f251ee69112e2357f716fac604f3bb3d73b627  common.lib_v0.22
b7cf30403aec92271678e14f79af9a4fd1f82df8  common.lib_v0.22.mm
30790cd148091e996415a5f620e5128feb40d986  common.lib_v0.22.png
832f5c6938657396f1361f80ebcb327f31956bd1  common.lib_v0.22.tar.bz2
7113349a4f5d1ddd74e790f4c2fa782ace0af949  test_common-lib.conf
7be004717f6ca2f9281955888c011ac6209b03e7  test_common-lib.sh

Notes

[1] Voir définition ici.

[2] Mes fonctions préférées sont sans aucun doute : sprintf et les *trim.

mardi 19 janvier 2010

Mon petit environnement IRC

Mais c'est quoi donc ?

Depuis pas mal de temps, je codouille[1] en Perlouille[2] pour le plus beau, le trop méga génial hyper LOL ; j'ai bien sûr nommé IRSSI.
Comme je n'ai pas forcément Internet partout où je vais, il faut bien que je puisse continuer à Perlouiller, du coup ci-dessous une petite explication pour se faire un environnement IRC quickly.

De quoi a-ton besoin ?

  • D'un Client IRC, logiquement IRSSI,
  • D'un Serveur IRC, soit du lourd, du velu comme UnrealIrcd, soit du romantique extravagant avec une once de sophistication et surtout du Poil partout : inspIRCd (celui que j'ai choisi pour aujourd'hui),
  • D'un Bot faisant du XDCC, donc pour l'occasion : Iroffer.
  • D'un Linux, et pour ma part du répertoire /usr/local/src/IRC_dev/.

Comment builder le serveur ?

Le Build en lui même :

./configure --prefix=/usr/local/src/IRC_dev/inspIRCd
make clean && make && make install

Pour résumer, on indique où vont se trouver les binaires après installation, on compile et on installe. Comptez 19 bonnes minutes sur mon Athlon mobile 2000+, mes 512 MiB de RAM et dont la RunQueue est en moyenne de 2 en permanence, ou alors 7 minutes sur un Sempron 3000+ qui fait semblant de router des paquets IP.

La configuration :

Si c'est pour du test, il n'y a pas grand chose à modifier ; vous copiez le fichier inspircd.conf.example en inspircd.conf dans le sous-répertoire conf/ et vous modifiez les quelques lignes suivantes :

name="localhost.localdomain"
description="Mon Test IRC"
name="Me"
nick="myUglyNick"
address="127.0.0.1"

Pour la partie secret :

allow="192.168.36.15"

Pour la partie main :

allow="127.0.0.1"

Et n'oubliez pas de commenter les lignes qui commencent par <die value="....

Le test :

Comme je suis pas un relou, d'une part je ne laisse pas ce genre de programme tourner en root, mon user me suffit, et d'autre part je le fais tourner en debug dans un screen[3].

$ ./inspircd help
Usage: ./inspircd (start|version|restart|checkconf|status|cron|help|rehash|stop)
Developer arguments: (screendebug|valdebug|debug|valdebug-unattended|screenvaldebug)

Exemple :

$ ./inspircd debug
[...]
InspIRCd is now running as 'localhost.localdomain'[559] with 1024 max open sockets
Mon Jan 18 23:51:47 2010: Keeping pseudo-tty open as we are running in the foreground.
Mon Jan 18 23:51:47 2010: Startup complete as 'localhost.localdomain'[559], 1024 max open sockets

Comment builder le Bot ?

Le Build en lui même :

D'abord je modifie le Makefile.config pour avoir mon installation où je veux. Je change INSDIR = /usr/local/src/IRC_dev/iroffer.

mkdir /usr/local/src/IRC_dev/iroffer
./Configure
make clean && make && sudo make install
sudo chown monuser:mongroup /usr/local/src/IRC_dev/iroffer/iroffer

Faites fi de tout ces Warning qui font chier, et vous aurez un beau binaire.

La configuration :

Si c'est pour du test, il n'y a pas grand chose à modifier ; vous copiez le fichier sample.conf en tupeuxpastest.conf dans le répertoire du binaire et vous modifiez les quelques lignes suivantes :

connectionmethod direct
server 127.0.0.1
channel #myTest -plist 2 -plistoffset 3 -pformat full
user_nick mybotDCC
user_realname My Bot
# Pour la valeur suivante, c'est à voir pour vos tests
downloadhost *!*@*
# C'est du local
overallmaxspeed 600
#adminpass montest (généré avec iroffer -c)
adminpass Hffrt/W5SUFZk
adminhost *!~me@*.domain.com
adminhost *!me@192.168.10.#
timestampconsole

Le test :

Comme je suis pas un relou, d'une part je ne laisse pas ce genre de programme tourner en root, mon user me suffit, et d'autre part je le fais tourner en debug dans un screen[4].

$ ./iroffer
./iroffer: no configuration file specifed
 
iroffer v1.3.b11 [20051213023024] by PMG, see http://iroffer.org/
 
Usage: ./iroffer [-vc] [-bdkns] [-u user] [-t dir] configfile [ configfile ... ]
        -v        Print version and exit.
        -c        Generate encrypted password and exit.
        -d        Increase debug level
        -b        Go to background mode
        -k        Attempt to adjust ulimit to allow core files
        -n        No colors in foreground mode
        -s        No screen manipulation in foreground mode
        -u user   Run as user (you have to start as root).
        -t dir    Chroot to dir (you have to start as root).

Exemple :

$ ./iroffer -d tupeuxpastest.config
[...]
** 2010-01-19-00:24:04: Attempting Connection to 127.0.01 (direct)
** 2010-01-19-00:24:04: Connecting to 127.0.0.1:6667
** 2010-01-19-00:24:04: ircserver socket = 5
** 2010-01-19-00:24:04: Server Connection Established, Logging In
** 2010-01-19-00:24:04: ourip = 127.0.0.1
** 2010-01-19-00:24:04: <SND<: NICK mybotDCC
[...]
** 2010-01-19-00:24:54: <SND<: PING localhost.localdomain
** 2010-01-19-00:24:54: >IRC>: :localhost.localdomain PONG localhost.localdomain :localhost.localdomain

[ Stat: 0/20 Sls, 0/10 Q, 0.0K/s Rcd, 0 SrQ (Bdw: 0K, 0.0K/s, 0.0K/s Rcd)                       ]
[ iroffer (mybotDCC) >

Comment builder le client ?

M'en fous ! Un sudo apt-get install irssi m'a suffi.

Notes

[1] Concaténation du verbe coder et du verbe merdouiller.

[2] Concaténation de Perl (langage de programmation) et de couilles (diminutif de boulettes, et dans de nombreux cas aussi appelées "Brave merde").

[3] Une des meilleures commande au monde...

[4] Une des meilleures commande au monde... Sans déconner, j'ai grave l'impression d'un déjà vu, non ?!

jeudi 10 avril 2008

AnalDup.sh v0.21 (anciennement allcompare.sh)

Script shell pour trouver vos fichiers dupliqués.

Cette mise à jour (et ce changement de nom depuis la version 0.20) est un début de la mise en place de la limitation du nombre de traitements concurrents.

Lire la suite...

mardi 8 avril 2008

allcompare.sh v0.15 (Blennorragie)

Permettre à tous vos petits fichiers en double[1] d'être trouvés (même s'ils n'ont pas le même nom).

Je me doute qu'il doit bien exister une tétra chier de programme du même genre, mais ceux que j'ai pu trouver étaient soit graphiques, soit il me manquait quelque chose. Comme j'en ai principalement eu besoin au boulot pour mes serveurs, je suis sûr qu'il tourne sous Linux (et normalement il fonctionne encore sur AIX).

Notes

[1] Triple, quadruple, quintuple, sextuple, et j'en passe...

Lire la suite...

mardi 25 octobre 2005

MyPurgeLogs v0.05

Script Shell : Permet la rotation et la purge de Logs.

Un grand nombre de scripts en Perl existent sur Internet (ex : FreshMeat.net). Le problème est que l'on a souvent un script pour la rotation des logs et un autre pour la purge (quand un find ne se ballade pas tout seul dans une crontable, une vague odeur de déjà vue ?!).

Ce petit script a pour but de reconcillier les deux mondes en fournissant un seul script à lancer et un seul fichier de configuration pour tout gérer.

Notes

Ce script n'a pour l'instant été testé que sur AIX avec KSH. Si vous l'avez testé sur d'autres plateformes, n'hésitez pas à me faire un retour.

Lire la suite...