MOD cleanage
[euphorik.git] / tools / tools.rb
1 #!/usr/bin/ruby
2 # coding: utf-8
3 =begin
4 Copyright 2008 Grégory Burri
5
6 This file is part of Euphorik.
7
8 Euphorik is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
12
13 Euphorik is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17 +
18 You should have received a copy of the GNU General Public License
19 along with Euphorik. If not, see <http://www.gnu.org/licenses/>.
20 =end
21
22 # TODO :
23 # - création de unit tests (voir eunit) et validation avant la mise en prod
24
25 # Met à disposition plusieurs outils (classes), tel que :
26 # - Vérification du code javascript
27 # - Mise à jour du numéro de version à partir du fichier VERSION
28 # - Mise en production et en preproduction
29 # tools.rb peut s'utiliser à la ligne de commande, exemples :
30 # * Mise en production :
31 # ./tools.rb --doprod gburri@euphorik.ch:/var/www/euphorik
32 # * Mise en préproduction, l'emplacement de production peut être indiqué pour copier la base
33 # ./tools.rb --dopreprod gburri@euphorik.ch:/var/www/euphorik_preprod --prod gburri@euphorik.ch:/var/www/euphorik
34
35 # voir : http://net-ssh.rubyforge.org/ssh/v2/api/index.html
36 # require 'net/ssh'
37
38 # Classe permettant la vérification du code JS pas jslint.
39 # Passe en revu chaque fichier js de manière récursive à partir d'un dossier de départ.s
40 class VerifJS
41
42 def initialize(dossier)
43 @dossier = dossier
44 end
45
46 def verifier
47 verifierRecur(@dossier)
48 end
49
50 def verifierRecur(dossier)
51 Dir.foreach(dossier){|fichier|
52 if fichier != '.' and fichier != '..' and File.directory?(fichier) and fichier != 'dirs'
53 if not verifierRecur(dossier + '/' + fichier)
54 return false
55 end
56 elsif fichier[-3, 3] == '.js'
57 puts "== Vérification de #{dossier}/#{fichier} =="
58 system("java org.mozilla.javascript.tools.shell.Main jslint.js #{dossier}/#{fichier}")
59 # puts $?.exitstatus
60 if $?.exitstatus > 0
61 return false
62 end
63 end
64 }
65 return true
66 end
67 end
68
69 # Classe de gestion de la version
70 class Version
71 # @param dossier la racine du site (par exemple "/var/www/euphorik"
72 def initialize(dossier)
73 @dossier = dossier
74 File.open(@dossier + '/VERSION') {|file|
75 @version = file.readline()
76 }
77 # les fichiers HTML dans lesquels mettre à jour la version
78 @fichiers = ['/pages/about.html']
79 @balise = /(<span.+?class.*?=.*?"version".*?>).*?(<\/span>)/
80 end
81
82 # met à jour la version dans les fichiers @fichiers
83 def maj
84 @fichiers.each{|fichier|
85 fichier = @dossier + fichier
86 lines = IO.readlines(fichier)
87 File.open(fichier, 'w') {|io|
88 lines.each{|l|
89 io.write(l.sub(@balise){|m| $1 + @version + $2})
90 }
91 }
92 }
93 end
94 end
95
96 # Permet la mise en production et preproduction
97 class MiseEnProd
98 # obsolète !
99 @@rep_remote = '/var/www/euphorik'
100 @@host = 'euphorik.ch'
101 @@opt_rsync = ''
102
103 def initialize(prod_uri, preprod_uri)
104 @prod = prod_uri
105 @preprod = preprod_uri
106 end
107
108 # Effectue la mise en production.
109 def miseEnProd
110 end
111
112 # Effectue la mise en préproduction.
113 def miseEnPreProd
114 end
115
116 def creer_remote_rep(rep)
117 begin
118 `ssh #{@@host} "mkdir #{@@rep_remote}/#{rep}"`
119 rescue
120 end
121 end
122
123 def compiler_partie_serveuse
124 Dir.chdir(@@rep_remote + '/modules')
125 puts `make`
126 if $?.exitstatus != 0
127 puts "Echec de compilation de la partie serveuse"
128 exit 1
129 end
130 Dir.chdir('..')
131 end
132
133 def creer_repertoire_bd
134 # création du repertoire BD
135 creer_remote_rep('BD')
136 creer_remote_rep('BD/backup')
137 `ssh #{@@host} "chmod g+w #{@@rep_remote}/BD"`
138 end
139
140 # css, images, html, etc..
141 def copier_partie_statique
142 print `rsync #{$opt_rsync} index.yaws #{$host}:#{$rep_remote}`
143 print `rsync #{$opt_rsync} favicon.ico #{$host}:#{$rep_remote}`
144 print `rsync #{$opt_rsync} -r css #{$host}:#{$rep_remote}`
145 print `rsync #{$opt_rsync} -r pages #{$host}:#{$rep_remote}`
146 print `rsync #{$opt_rsync} -r --exclude 'autres' img #{$host}:#{$rep_remote}`
147 end
148
149 # minification et package des fichiers js dans euphorik.js
150 def pack_js
151 # copie des js avec minification
152 rep_js = 'js'
153 creer_remote_rep(rep_js)
154 Dir.entries(rep_js).each{|fichier|
155 if fichier[0..0] != '.' and fichier != 'debug.js'
156 puts "Minimisation et copie de #{fichier}"
157 print `tools/jsmin.rb < #{rep_js}/#{fichier} | ssh #{@@host} "cat > #{@@rep_remote}/#{rep_js}/#{fichier}"`
158 end
159 }
160 end
161
162 def copie_modules_serveurs
163 # copie des modules erlang
164 creer_remote_rep('modules')
165 `rsync #{@@opt_rsync} -r --exclude 'euphorik_test.beam' modules/ebin #{@@host}:#{@@rep_remote}/modules`
166 `rsync #{@@opt_rsync} -r modules/include #{@@host}:#{@@rep_remote}/modules`
167 end
168
169 def set_droits_fichiers
170 # attribution des droits
171 `ssh #{$host} "chmod -R g+rx #{$rep_remote}"`
172 end
173
174 def maj
175 # execution du script de mise à jour
176 print `cat tools/mise_en_prod.erl | ssh #{$host} "cat > /tmp/mise_en_prod.erl"`
177 print `ssh #{$host} "chmod u+x /tmp/mise_en_prod.erl; /tmp/mise_en_prod.erl; rm /tmp/mise_en_prod.erl"`
178 end
179 end
180
181
182 # Traite la ligne de commande lorsque tools.rb est utilisé comme tel
183 class Commande
184 def traiter
185 #ARGV
186 =begin
187 Net::SSH.start('euphorik.ch', 'gburri') {|ssh|
188 output = ssh.exec!("hostname")
189 stdout = ""
190 ssh.exec!("ls -l /tmp"){|channel, stream, data|
191 stdout << data if stream == :stdout
192 }
193 puts stdout
194 }
195 =end
196
197
198 #miseEnProd = MiseEnProd.new("gburri@euphorik.ch:/var/www/euphorik", "gburri@euphorik.ch:/var/www/euphorik_preprod")
199 #miseEnProd.miseEnPreProd()
200
201 verifJS = VerifJS.new("../js")
202 verifJS.verifier()
203
204 #version = Version.new("..")
205 #version.maj()
206 end
207 end
208
209 cl = Commande.new
210 cl.traiter()