X-Git-Url: http://git.euphorik.ch/?a=blobdiff_plain;f=tools%2Ftools.rb;h=323926fffac32d9d0f4dff5d64898a9d1122abfc;hb=79f0cfc91b7220d98e4caf50fbb3857807fc6bc4;hp=e2ed15341b134ff8cdd74bb974192fe5449cfe30;hpb=f25f1c7fcec2a610cd5fbd82ae5501e1e9710098;p=euphorik.git diff --git a/tools/tools.rb b/tools/tools.rb old mode 100644 new mode 100755 index e2ed153..323926f --- a/tools/tools.rb +++ b/tools/tools.rb @@ -37,16 +37,16 @@ along with Euphorik. If not, see . # 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 - +class VerifJS + def initialize(dossier) @dossier = dossier end - + def verifier verifierRecur(@dossier) end - + def verifierRecur(dossier) Dir.foreach(dossier){|fichier| cheminComplet = "#{dossier}/#{fichier}" @@ -56,7 +56,7 @@ class VerifJS end elsif fichier[-3, 3] == '.js' puts "== Vérification de #{cheminComplet} ==" - # TODO : mettre un if pour la version windows si dessous + # 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 @@ -70,7 +70,7 @@ class VerifJS end # Classe de gestion de la version -class Version +class Version # @param dossier la racine du site (par exemple "/var/www/euphorik") def initialize(dossier) @dossier = dossier @@ -79,19 +79,19 @@ 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 - def maj + 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}) + io.write(l.sub(@balise){|m| $1 + @version + $2 + @version + $3}) } - } + } } end end @@ -101,11 +101,11 @@ class MiseEnProd # obsolète ! @@rep_remote = '/var/www/euphorik' @@host = 'euphorik.ch' - + def initialize(racine) Dir.chdir(racine) - end - + end + # L'emplacement ou sont copié les fichiers # A définir avant la mise en prod def uri=(uri) @@ -113,20 +113,20 @@ class MiseEnProd @uri = plop[0] @rep = plop[1] end - + # Effectue la mise en production. def miseEnProd copierFichiers() - maj() + maj('yaws') end - + # Effectue la mise en préproduction. def miseEnPreProd copierFichiers() - copierBD() lancerYaws() + maj('yaws_dev') end - + def copierFichiers compiler_partie_serveuse() creer_repertoire_bd() @@ -135,17 +135,14 @@ class MiseEnProd copie_modules_serveurs() set_droits_fichiers() end - - # TODO - def copierBD - 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 @@ -156,8 +153,9 @@ class MiseEnProd rescue end end - + def compiler_partie_serveuse + log "compilation des modules serveur" Dir.chdir('modules') system("make") if $?.exitstatus != 0 @@ -166,16 +164,18 @@ class MiseEnProd end 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_rep('BD') creer_rep('BD/backups') exec("chmod -R g+w BD") end - + # css, images, html, etc.. 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}") @@ -183,21 +183,23 @@ class MiseEnProd 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 + log "minification, assemblage et copie du javascript" rep_js = 'js' 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 " + 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\"") + # tools/jsmin.rb | + system("#{commande_cat} | ssh #{@uri} \"cd #{@rep} && cat > #{rep_js}/euphorik.js\"") end - + #renvoie une liste des fichiers js def get_fichiers_js(rep) fichiers = [] @@ -210,45 +212,56 @@ class MiseEnProd fichiers << fichier end end - } + } return fichiers end - - def copie_modules_serveurs + + def copie_modules_serveurs + log "copie des modules du serveur" # copie des modules erlang 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 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 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; rm /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 + def initialize Dir.chdir("..") @miseEnProd = MiseEnProd.new(".") @verifJS = VerifJS.new("js") @version = Version.new(".") end - + def traiter if ARGV.size == 0 afficherUsage return end - + case ARGV[0] when 'prod' @version.maj() @@ -262,20 +275,9 @@ class Commande @verifJS.verifier() when 'version' @version.maj() - end - -=begin - 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 - } -=end + end end - + def afficherUsage puts "Usage : tools.rb (prod | pre | js | version)\n" + " prod : Mise en production\n" +