REPORT de la branche 1.1 (433->435)
[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 prod 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 pre gburri@euphorik.ch:/var/www/euphorik_preprod 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 # TODO : mettre un if pour la version windows si dessous
59 #system("java org.mozilla.javascript.tools.shell.Main jslint.js #{dossier}/#{fichier}")
60 system("rhino ./tools/jslint.js #{dossier}/#{fichier}")
61 # puts $?.exitstatus
62 if $?.exitstatus > 0
63 return false
64 end
65 end
66 }
67 return true
68 end
69 end
70
71 # Classe de gestion de la version
72 class Version
73 # @param dossier la racine du site (par exemple "/var/www/euphorik")
74 def initialize(dossier)
75 @dossier = dossier
76 File.open(@dossier + '/VERSION') {|file|
77 @version = file.readline()
78 }
79 # les fichiers HTML dans lesquels mettre à jour la version
80 @fichiers = ['/pages/about.html']
81 @balise = /(<span.+?class.*?=.*?"version".*?>).*?(<\/span>)/
82 end
83
84 # met à jour la version dans les fichiers @fichiers
85 def maj
86 @fichiers.each{|fichier|
87 fichier = @dossier + fichier
88 lines = IO.readlines(fichier)
89 File.open(fichier, 'w') {|io|
90 lines.each{|l|
91 io.write(l.sub(@balise){|m| $1 + @version + $2})
92 }
93 }
94 }
95 end
96 end
97
98 # Permet la mise en production et preproduction
99 class MiseEnProd
100 # obsolète !
101 @@rep_remote = '/var/www/euphorik'
102 @@host = 'euphorik.ch'
103
104 def initialize(racine)
105 Dir.chdir(racine)
106 end
107
108 # L'emplacement ou sont copié les fichiers
109 # A définir avant la mise en prod
110 def uri=(uri)
111 plop = uri.split(':')
112 @uri = plop[0]
113 @rep = plop[1]
114 end
115
116 # Effectue la mise en production.
117 def miseEnProd
118 copierFichiers()
119 maj()
120 end
121
122 # Effectue la mise en préproduction.
123 def miseEnPreProd
124 copierFichiers()
125 copierBD()
126 lancerYaws()
127 end
128
129 def copierFichiers
130 compiler_partie_serveuse()
131 creer_repertoire_bd()
132 copier_partie_statique()
133 pack_js()
134 copie_modules_serveurs()
135 set_droits_fichiers()
136 end
137
138 def copierBD
139 #TODO
140 end
141
142 def lancerYaws
143 creer_rep("tools")
144 system("rsync tools/yaws.conf #{@uri}:#{@rep}/tools")
145 system("rsync tools/start_yaws.sh #{@uri}:#{@rep}/tools")
146 # TODO
147 end
148
149 def exec(commande)
150 system("ssh #{@uri} \"cd #{@rep} && #{commande}\"")
151 end
152
153 def creer_rep(rep)
154 begin
155 exec("test -d #{rep} || mkdir #{rep}")
156 rescue
157 end
158 end
159
160 def compiler_partie_serveuse
161 Dir.chdir('modules')
162 system("make")
163 if $?.exitstatus != 0
164 puts "Echec de compilation de la partie serveuse"
165 exit 1
166 end
167 Dir.chdir('..')
168 end
169
170 def creer_repertoire_bd
171 # création du repertoire BD
172 creer_rep('BD')
173 creer_rep('BD/backups')
174 exec("chmod -R g+w BD")
175 end
176
177 # css, images, html, etc..
178 def copier_partie_statique
179 uri = "#{@uri}:#{@rep}"
180 system("awk '$0 !~ /prod=\"delete\"/' index.yaws | ssh #{@uri} \" cat > #{@rep}/index.yaws\"")
181 system("rsync favicon.ico #{uri}")
182 system("rsync --delete -r styles #{uri}")
183 system("rsync --delete -r pages #{uri}")
184 system("rsync --delete -r --exclude 'autres' img #{uri}")
185 end
186
187 # minification et package des fichiers js dans euphorik.js
188 def pack_js
189 rep_js = 'js'
190 creer_rep(rep_js)
191 # jquery.js et euphorik.js doivent se trouve en premier
192 fichiers = ['js/libs/jquery.js', 'js/euphorik.js'].concat(get_fichiers_js(rep_js))
193 commande_cat = "cat "
194 fichiers.each{|f|
195 commande_cat += f + " "
196 }
197 #copie des js concaténés avec minification
198 system("#{commande_cat} | tools/jsmin.rb | ssh #{@uri} \"cd #{@rep} && cat > #{rep_js}/euphorik.js\"")
199 end
200
201 #renvoie une liste des fichiers js
202 def get_fichiers_js(rep)
203 fichiers = []
204 Dir.entries(rep).each{|fichier|
205 if fichier[0..0] != '.' and fichier != 'euphorik.js' and fichier != 'jquery.js'
206 fichier = rep + "/" + fichier
207 if File.directory?(fichier)
208 fichiers.concat(get_fichiers_js(fichier))
209 else
210 fichiers << fichier
211 end
212 end
213 }
214 return fichiers
215 end
216
217 def copie_modules_serveurs
218 # copie des modules erlang
219 creer_rep('modules')
220 system("rsync -r --exclude 'euphorik_test.beam' modules/ebin #{@uri}:#{@rep}/modules")
221 system("rsync -r modules/include #{@uri}:#{@rep}/modules")
222 end
223
224 def set_droits_fichiers
225 # attribution des droits
226 exec("chmod -R g+rx .")
227 end
228
229 def maj
230 # execution du script de mise à jour
231 system("cat tools/mise_en_prod.erl | ssh #{@uri} \"cat > /tmp/mise_en_prod.erl\"")
232 system("ssh #{@uri} \"chmod u+x /tmp/mise_en_prod.erl; /tmp/mise_en_prod.erl; rm /tmp/mise_en_prod.erl\"")
233 end
234 end
235
236
237 # Traite la ligne de commande lorsque tools.rb est utilisé comme tel
238 class Commande
239 def initialize
240 Dir.chdir("..")
241 @miseEnProd = MiseEnProd.new(".")
242 @verifJS = VerifJS.new("js")
243 @version = Version.new(".")
244 end
245
246 def traiter
247 if ARGV.size == 0
248 afficherUsage
249 return
250 end
251
252 case ARGV[0]
253 when 'prod'
254 @version.maj()
255 @miseEnProd.uri = "gburri@euphorik.ch:/var/www/euphorik"
256 @miseEnProd.miseEnProd()
257 when 'pre'
258 @version.maj()
259 @miseEnProd.uri = "gburri@euphorik.ch:/var/www/euphorik_preprod"
260 @miseEnProd.miseEnPreProd()
261 when 'js'
262 @verifJS.verifier()
263 when 'version'
264 @version.maj()
265 end
266
267 =begin
268 Net::SSH.start('euphorik.ch', 'gburri') {|ssh|
269 output = ssh.exec!("hostname")
270 stdout = ""
271 ssh.exec!("ls -l /tmp"){|channel, stream, data|
272 stdout << data if stream == :stdout
273 }
274 puts stdout
275 }
276 =end
277 end
278
279 def afficherUsage
280 puts "Usage : tools.rb (prod | pre | js | version)\n" +
281 " prod : Mise en production\n" +
282 " preprod : Mise en préproduction, copie les données en production\n" +
283 " js : vérification des fichiers JavaScript\n" +
284 " version : met à jour la version à partir du fichier VERSION"
285 end
286 end
287
288 cl = Commande.new
289 cl.traiter()