X-Git-Url: http://git.euphorik.ch/?p=euphorik.git;a=blobdiff_plain;f=tools%2Ftools.rb;h=5d9f40b31e24c23af39b6de647ab7f84e8c5b181;hp=5472a3c209d94f2065efa478e24f641ff644a643;hb=4696f876c2a6e33619bf688138262fe9d85540f0;hpb=4aa85a2e80963b73773e748fd4402fab2ad852ce diff --git a/tools/tools.rb b/tools/tools.rb index 5472a3c..5d9f40b 100644 --- a/tools/tools.rb +++ b/tools/tools.rb @@ -28,12 +28,12 @@ along with Euphorik. If not, see . # - 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 +# ./tools.rb prod 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 +# ./tools.rb pre gburri@euphorik.ch:/var/www/euphorik_preprod gburri@euphorik.ch:/var/www/euphorik # voir : http://net-ssh.rubyforge.org/ssh/v2/api/index.html -require 'net/ssh' +# 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 @@ -44,19 +44,22 @@ class VerifJS end def verifier - verifierRecu(@dossier) + verifierRecur(@dossier) end - def verifierRecu(dossier) + def verifierRecur(dossier) Dir.foreach(dossier){|fichier| - if fichier != '.' and fichier != '..' and File.directory?(fichier) and fichier != 'dirs' - if not verifierRecu(dossier + '/' + fichier) + cheminComplet = "#{dossier}/#{fichier}" + if fichier[0,1] != '.' and File.directory?(cheminComplet) and fichier != 'libs' + if not verifierRecur(cheminComplet) 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 + puts "== Vérification de #{cheminComplet} ==" + # TODO : mettre un if pour la version windows si dessous + #system("java org.mozilla.javascript.tools.shell.Main jslint.js #{cheminComplet}") + system("rhino ./tools/jslint.js #{cheminComplet}") + # puts $?.exitstatus if $?.exitstatus > 0 return false end @@ -68,7 +71,7 @@ end # Classe de gestion de la version class Version - # @param dossier la racine du site (par exemple "/var/www/euphorik" + # @param dossier la racine du site (par exemple "/var/www/euphorik") def initialize(dossier) @dossier = dossier File.open(@dossier + '/VERSION') {|file| @@ -76,7 +79,7 @@ class Version } # les fichiers HTML dans lesquels mettre à jour la version @fichiers = ['/pages/about.html'] - @balise = /().*?(<\/span>)/ + @balise = /().*?(<\/a>)/ end # met à jour la version dans les fichiers @fichiers @@ -86,7 +89,7 @@ class Version lines = IO.readlines(fichier) File.open(fichier, 'w') {|io| lines.each{|l| - io.write(l.sub(@balise){|m| $1 + @version + $2}) + io.write(l.sub(@balise){|m| $1 + @version + $2 + @version + $3}) } } } @@ -98,31 +101,63 @@ 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 + def initialize(racine) + Dir.chdir(racine) end + # L'emplacement ou sont copié les fichiers + # A définir avant la mise en prod + def uri=(uri) + plop = uri.split(':') + @uri = plop[0] + @rep = plop[1] + end + # Effectue la mise en production. def miseEnProd + copierFichiers() + maj('yaws') end # Effectue la mise en préproduction. def miseEnPreProd + copierFichiers() + lancerYaws() + maj('yaws_dev') + end + + def copierFichiers + compiler_partie_serveuse() + creer_repertoire_bd() + copier_partie_statique() + pack_js() + copie_modules_serveurs() + set_droits_fichiers() + end + + def lancerYaws + creer_rep("tools") + system("rsync tools/yaws.conf #{@uri}:#{@rep}/tools") + system("rsync tools/start_yaws.sh #{@uri}:#{@rep}/tools") + system("ssh #{@uri} \"cd #{@rep}/tools; screen -d -m -S yaws_dev ./start_yaws.sh\"") + end + + def exec(commande) + system("ssh #{@uri} \"cd #{@rep} && #{commande}\"") end - def creer_remote_rep(rep) + def creer_rep(rep) begin - `ssh #{@@host} "mkdir #{@@rep_remote}/#{rep}"` + exec("test -d #{rep} || mkdir #{rep}") rescue end end def compiler_partie_serveuse - Dir.chdir(@@rep_remote + '/modules') - puts `make` + log "compilation des modules serveur" + Dir.chdir('modules') + system("make") if $?.exitstatus != 0 puts "Echec de compilation de la partie serveuse" exit 1 @@ -130,78 +165,125 @@ class MiseEnProd Dir.chdir('..') end - def creer_repertoire_bd + def creer_repertoire_bd + log "création du répertoire de la base de données" # création du repertoire BD - creer_remote_rep('BD') - creer_remote_rep('BD/backup') - `ssh #{@@host} "chmod g+w #{@@rep_remote}/BD"` + creer_rep('var') + creer_rep('var/images') + creer_rep('var/BD/backups') + exec("chmod -R g+w var") end # css, images, html, etc.. - def copier_partie_statique - print `rsync #{$opt_rsync} index.yaws #{$host}:#{$rep_remote}` - print `rsync #{$opt_rsync} favicon.ico #{$host}:#{$rep_remote}` - print `rsync #{$opt_rsync} -r css #{$host}:#{$rep_remote}` - print `rsync #{$opt_rsync} -r pages #{$host}:#{$rep_remote}` - print `rsync #{$opt_rsync} -r --exclude 'autres' img #{$host}:#{$rep_remote}` + def copier_partie_statique + log "copie de la partie statique" + uri = "#{@uri}:#{@rep}" + system("awk '$0 !~ /prod=\"delete\"/' index.yaws | ssh #{@uri} \" cat > #{@rep}/index.yaws\"") + system("rsync favicon.ico #{uri}") + system("rsync --delete -r styles #{uri}") + system("rsync --delete -r pages #{uri}") + system("rsync --delete -r --exclude 'autres' img #{uri}") end # minification et package des fichiers js dans euphorik.js def pack_js - # copie des js avec minification + log "minification, assemblage et copie du javascript" rep_js = 'js' - creer_remote_rep(rep_js) - Dir.entries(rep_js).each{|fichier| - if fichier[0..0] != '.' and fichier != 'debug.js' - puts "Minimisation et copie de #{fichier}" - print `tools/jsmin.rb < #{rep_js}/#{fichier} | ssh #{@@host} "cat > #{@@rep_remote}/#{rep_js}/#{fichier}"` + creer_rep(rep_js) + # jquery.js et euphorik.js doivent se trouve en premier + fichiers = ['js/libs/jquery.js', 'js/euphorik.js'].concat(get_fichiers_js(rep_js)) + commande_cat = "cat " + fichiers.each{|f| + commande_cat += f + " " + } + #copie des js concaténés avec minification + system("#{commande_cat} | tools/jsmin.rb | ssh #{@uri} \"cd #{@rep} && cat > #{rep_js}/euphorik.js\"") + end + + #renvoie une liste des fichiers js + def get_fichiers_js(rep) + fichiers = [] + Dir.entries(rep).each{|fichier| + if fichier[0..0] != '.' and fichier != 'euphorik.js' and fichier != 'jquery.js' + fichier = rep + "/" + fichier + if File.directory?(fichier) + fichiers.concat(get_fichiers_js(fichier)) + else + fichiers << fichier + end end } + return fichiers end def copie_modules_serveurs + log "copie des modules du serveur" # copie des modules erlang - creer_remote_rep('modules') - `rsync #{@@opt_rsync} -r --exclude 'euphorik_test.beam' modules/ebin #{@@host}:#{@@rep_remote}/modules` - `rsync #{@@opt_rsync} -r modules/include #{@@host}:#{@@rep_remote}/modules` + creer_rep('modules') + system("rsync -r --exclude 'euphorik_test.beam' modules/ebin #{@uri}:#{@rep}/modules") + system("rsync -r modules/include #{@uri}:#{@rep}/modules") end def set_droits_fichiers + log "attribution des droits sur les fichiers" # attribution des droits - `ssh #{$host} "chmod -R g+rx #{$rep_remote}"` + exec("chmod -R g+rx .") end - def maj + # noeud : le nom du noeud sur lequel le script de mise en prod est exécuté + # Execute le script 'mise_en_prod.erl' sur le serveur afin de : + # - Recharger les modules + # - Mettre à jour la base de données + def maj(noeud) + log "rechargement des modules serveur et mise à jour de la base de données" # execution du script de mise à jour - print `cat tools/mise_en_prod.erl | ssh #{$host} "cat > /tmp/mise_en_prod.erl"` - print `ssh #{$host} "chmod u+x /tmp/mise_en_prod.erl; /tmp/mise_en_prod.erl; rm /tmp/mise_en_prod.erl"` + system("cat tools/mise_en_prod.erl | ssh #{@uri} \"cat > /tmp/mise_en_prod.erl\"") + system("ssh #{@uri} \"chmod u+x /tmp/mise_en_prod.erl; /tmp/mise_en_prod.erl #{noeud}; rm /tmp/mise_en_prod.erl\"") + end + + def log(message) + puts "----- #{message} -----" end end # Traite la ligne de commande lorsque tools.rb est utilisé comme tel class Commande + def initialize + Dir.chdir("..") + @miseEnProd = MiseEnProd.new(".") + @verifJS = VerifJS.new("js") + @version = Version.new(".") + end + def traiter - #ARGV - - Net::SSH.start('euphorik.ch', 'gburri') {|ssh| - output = ssh.exec!("hostname") - stdout = "" - ssh.exec!("ls -l /tmp"){|channel, stream, data| - stdout << data if stream == :stdout - } - puts stdout - } - + if ARGV.size == 0 + afficherUsage + return + end - #miseEnProd = MiseEnProd.new("gburri@euphorik.ch:/var/www/euphorik", "gburri@euphorik.ch:/var/www/euphorik_preprod") - #miseEnProd.miseEnPreProd() - - #verifJS = VerifJS.new("../js") - #verifJS.verifier() - - #version = Version.new("..") - #version.maj() + case ARGV[0] + when 'prod' + @version.maj() + @miseEnProd.uri = "gburri@euphorik.ch:/var/www/euphorik" + @miseEnProd.miseEnProd() + when 'pre' + @version.maj() + @miseEnProd.uri = "gburri@euphorik.ch:/var/www/euphorik_preprod" + @miseEnProd.miseEnPreProd() + when 'js' + @verifJS.verifier() + when 'version' + @version.maj() + end + end + + def afficherUsage + puts "Usage : tools.rb (prod | pre | js | version)\n" + + " prod : Mise en production\n" + + " pre : Mise en préproduction, copie les données en production\n" + + " js : vérification des fichiers JavaScript\n" + + " version : met à jour la version à partir du fichier VERSION" end end