Use the new json2 module (from yaws)
[euphorik.git] / tools / tools.rb
old mode 100644 (file)
new mode 100755 (executable)
index 9bf9b86..323926f
@@ -37,27 +37,28 @@ along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.
 
 # 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|
-         if fichier != '.' and fichier != '..' and File.directory?(fichier) and fichier != 'dirs'
-            if not verifierRecur(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} =="
-            # TODO : mettre un if pour la version windows si dessous 
-            #system("java org.mozilla.javascript.tools.shell.Main jslint.js #{dossier}/#{fichier}")
-            system("rhino ./tools/jslint.js #{dossier}/#{fichier}")
+            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
@@ -69,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
@@ -78,19 +79,19 @@ class Version
       }
       # les fichiers HTML dans lesquels mettre à jour la version
       @fichiers  = ['/pages/about.html']
-      @balise = /(<span.+?class.*?=.*?"version".*?>).*?(<\/span>)/
+      @balise = /(<a.+?href=".*?\/tags\/).*?(".+?class.*?=.*?"version".*?>).*?(<\/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
@@ -100,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)
@@ -112,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()
@@ -134,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
@@ -155,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
@@ -165,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}")
@@ -182,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 = []
@@ -209,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()
@@ -261,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" +