Use the new json2 module (from yaws)
[euphorik.git] / tools / tools.rb
old mode 100644 (file)
new mode 100755 (executable)
index 8b14954..323926f
@@ -37,16 +37,16 @@ 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|
          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
@@ -81,9 +81,9 @@ class Version
       @fichiers  = ['/pages/about.html']
       @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)
@@ -91,7 +91,7 @@ class Version
             lines.each{|l|
                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('yaws')
    end
-   
+
    # Effectue la mise en préproduction.
    def miseEnPreProd
       copierFichiers()
       lancerYaws()
       maj('yaws_dev')
    end
-   
+
    def copierFichiers
       compiler_partie_serveuse()
       creer_repertoire_bd()
@@ -135,14 +135,14 @@ class MiseEnProd
       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
@@ -153,7 +153,7 @@ class MiseEnProd
       rescue
       end
    end
-   
+
    def compiler_partie_serveuse
       log "compilation des modules serveur"
       Dir.chdir('modules')
@@ -164,18 +164,18 @@ class MiseEnProd
       end
       Dir.chdir('..')
    end
-   
-   def creer_repertoire_bd     
-      log "création du répertoire de la base de données"      
+
+   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"      
+      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,22 +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" 
+      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 = []
@@ -211,35 +212,35 @@ class MiseEnProd
                fichiers <<  fichier
             end
          end
-      }      
+      }
       return fichiers
    end
-   
-   def copie_modules_serveurs      
-      log "copie des modules du serveur" 
+
+   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" 
+      log "attribution des droits sur les fichiers"
       # attribution des droits
       exec("chmod -R g+rx .")
    end
-   
+
    # 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" 
+      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 #{noeud}; rm /tmp/mise_en_prod.erl\"")
    end
-      
+
    def log(message)
       puts "----- #{message} -----"
    end
@@ -248,19 +249,19 @@ 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()
@@ -276,7 +277,7 @@ class Commande
             @version.maj()
          end
    end
-   
+
    def afficherUsage
       puts "Usage : tools.rb (prod | pre | js | version)\n" +
          "   prod : Mise en production\n" +