MOD set the user nick later
[euphorik.git] / tools / tools.rb
index 127e3f3..5d9f40b 100644 (file)
@@ -14,7 +14,7 @@ Euphorik is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY; without even the implied warranty of
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 GNU General Public License for more details.
-+
+
 You should have received a copy of the GNU General Public License
 along with Euphorik.  If not, see <http://www.gnu.org/licenses/>.
 =end
@@ -49,15 +49,16 @@ class VerifJS
    
    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} =="
+            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 #{dossier}/#{fichier}")
-            system("rhino jslint.js #{dossier}/#{fichier}")
+            #system("java org.mozilla.javascript.tools.shell.Main jslint.js #{cheminComplet}")
+            system("rhino ./tools/jslint.js #{cheminComplet}")
             # puts $?.exitstatus
             if $?.exitstatus > 0
                return false
@@ -70,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|
@@ -78,7 +79,7 @@ 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
@@ -88,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})
             }
          }   
       }
@@ -100,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
@@ -132,51 +165,84 @@ 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
 
@@ -184,12 +250,10 @@ end
 # Traite la ligne de commande lorsque tools.rb est utilisé comme tel
 class Commande
    def initialize   
-      @miseEnProd = MiseEnProd.new(
-         "gburri@euphorik.ch:/var/www/euphorik",
-         "gburri@euphorik.ch:/var/www/euphorik_preprod"
-      )
-      @verifJS = VerifJS.new("../js")
-      @version = Version.new("..")
+      Dir.chdir("..")
+      @miseEnProd = MiseEnProd.new(".")
+      @verifJS = VerifJS.new("js")
+      @version = Version.new(".")
    end
    
    def traiter
@@ -201,32 +265,23 @@ class Commande
       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
-      
-=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" +
-         "   preprod : Mise en préproduction, copie les données 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