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
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
# 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|
}
# 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
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})
}
}
}
# 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
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('BD')
+ creer_rep('BD/backups')
+ exec("chmod -R g+w BD")
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
- @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
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