-# Utilisation :
-# tools.rb <commande> <args>
-# commandes :
-# \r
-\r
-class MiseEnProd\r
- @@rep_remote = '/var/www/euphorik'\r
- @@host = 'euphorik.ch'\r
- @@opt_rsync = ''\r
- \r
- def initialize \r
- end \r
-\r
- def creer_remote_rep(rep) \r
- begin\r
- `ssh #{@@host} "mkdir #{@@rep_remote}/#{rep}"`\r
- rescue\r
- end\r
- end\r
- \r
- def compiler_partie_serveuse\r
- Dir.chdir(@@rep_remote + '/modules')\r
- puts `make`\r
- if $?.exitstatus != 0\r
- puts "Echec de compilation de la partie serveuse"\r
- exit 1\r
- end\r
- Dir.chdir('..')\r
- end\r
- \r
- def creer_repertoire_bd \r
- # création du repertoire BD\r
- creer_remote_rep('BD')\r
- creer_remote_rep('BD/backup')\r
- `ssh #{@@host} "chmod g+w #{@@rep_remote}/BD"`\r
- end\r
- \r
- # css, images, html, etc..\r
+# TODO :
+# - création de unit tests (voir eunit) et validation avant la mise en prod
+
+# Met à disposition plusieurs outils (classes), tel que :
+# - Vérification du code javascript
+# - Mise à jour du numéro de version à partir du fichier VERSION
+# - Mise en production et en preproduction
+# tools.rb peut s'utiliser à la ligne de commande, exemples :
+# * Mise en production :
+# ./tools.rb --doprod gburri@euphorik.ch:/var/www/euphorik
+# * Mise en préproduction, l'emplacement de production peut être indiqué pour copier la base
+# ./tools.rb --dopreprod gburri@euphorik.ch:/var/www/euphorik_preprod --prod gburri@euphorik.ch:/var/www/euphorik
+
+# voir : http://net-ssh.rubyforge.org/ssh/v2/api/index.html
+# require 'net/ssh'
+
+# Classe permettant la vérification du code JS pas jslint.
+# Passe en revu chaque fichier js de manière récursive à partir d'un dossier de départ.s
+class VerifJS
+
+ def initialize(dossier)
+ @dossier = dossier
+ end
+
+ def verifier
+ verifierRecur(@dossier)
+ end
+
+ def verifierRecur(dossier)
+ Dir.foreach(dossier){|fichier|
+ if fichier != '.' and fichier != '..' and File.directory?(fichier) and fichier != 'dirs'
+ if not verifierRecur(dossier + '/' + fichier)
+ return false
+ end
+ elsif fichier[-3, 3] == '.js'
+ puts "== Vérification de #{dossier}/#{fichier} =="
+ system("java org.mozilla.javascript.tools.shell.Main jslint.js #{dossier}/#{fichier}")
+ # puts $?.exitstatus
+ if $?.exitstatus > 0
+ return false
+ end
+ end
+ }
+ return true
+ end
+end
+
+# Classe de gestion de la version
+class Version
+ # @param dossier la racine du site (par exemple "/var/www/euphorik"
+ def initialize(dossier)
+ @dossier = dossier
+ File.open(@dossier + '/VERSION') {|file|
+ @version = file.readline()
+ }
+ # les fichiers HTML dans lesquels mettre à jour la version
+ @fichiers = ['/pages/about.html']
+ @balise = /(<span.+?class.*?=.*?"version".*?>).*?(<\/span>)/
+ end
+
+ # met à jour la version dans les fichiers @fichiers
+ def maj
+ @fichiers.each{|fichier|
+ fichier = @dossier + fichier
+ lines = IO.readlines(fichier)
+ File.open(fichier, 'w') {|io|
+ lines.each{|l|
+ io.write(l.sub(@balise){|m| $1 + @version + $2})
+ }
+ }
+ }
+ end
+end
+
+# Permet la mise en production et preproduction
+class MiseEnProd
+ # obsolète !
+ @@rep_remote = '/var/www/euphorik'
+ @@host = 'euphorik.ch'
+ @@opt_rsync = ''
+
+ def initialize(prod_uri, preprod_uri)
+ @prod = prod_uri
+ @preprod = preprod_uri
+ end
+
+ # Effectue la mise en production.
+ def miseEnProd
+ end
+
+ # Effectue la mise en préproduction.
+ def miseEnPreProd
+ end
+
+ def creer_remote_rep(rep)
+ begin
+ `ssh #{@@host} "mkdir #{@@rep_remote}/#{rep}"`
+ rescue
+ end
+ end
+
+ def compiler_partie_serveuse
+ Dir.chdir(@@rep_remote + '/modules')
+ puts `make`
+ if $?.exitstatus != 0
+ puts "Echec de compilation de la partie serveuse"
+ exit 1
+ end
+ Dir.chdir('..')
+ end
+
+ def creer_repertoire_bd
+ # création du repertoire BD
+ creer_remote_rep('BD')
+ creer_remote_rep('BD/backup')
+ `ssh #{@@host} "chmod g+w #{@@rep_remote}/BD"`
+ end
+
+ # css, images, html, etc..