summaryrefslogtreecommitdiff
authorClipperz <info@clipperz.com>2013-01-18 17:17:26 (UTC)
committer Clipperz <info@clipperz.com>2013-01-18 17:17:26 (UTC)
commit1e19202f478ca4ab25c6566bf1c17dc7f3698824 (patch) (side-by-side diff)
tree9b2792add41f98cc8aea44077a40a5064c793610
parent969b9f94a25931a765a4cd4765177979f66c1585 (diff)
downloadclipperz-1e19202f478ca4ab25c6566bf1c17dc7f3698824.zip
clipperz-1e19202f478ca4ab25c6566bf1c17dc7f3698824.tar.gz
clipperz-1e19202f478ca4ab25c6566bf1c17dc7f3698824.tar.bz2
Improved the reporting of the MAC while building
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--scripts/builder/backendBuilder.py15
1 files changed, 12 insertions, 3 deletions
diff --git a/scripts/builder/backendBuilder.py b/scripts/builder/backendBuilder.py
index 36b28ca..20b4bd0 100644
--- a/scripts/builder/backendBuilder.py
+++ b/scripts/builder/backendBuilder.py
@@ -1,126 +1,135 @@
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
import sys, os, json
import shutil
import hashlib
+from functools import reduce
+from operator import add
+from itertools import izip
+
import main
#===================================================================
class BackendBuilder(object):
def __init__ (self, projectTargetDir, frontends, versions, settings):
self.projectTargetDir = projectTargetDir
self.frontends = frontends
self.versions = versions
self.settings = settings
# --------------------------------------------------------------------------
def name (self):
raise NotImplementedError()
def relativePath (self):
raise NotImplementedError()
def compileCode (self):
raise NotImplementedError()
def createPackage (self):
raise NotImplementedError()
# --------------------------------------------------------------------------
def sourceFolder (self):
return os.path.join(main.projectBaseDir() , 'backend', self.relativePath(), 'src')
def tempFolder (self):
return os.path.join(self.projectTargetDir, '.tmp', self.relativePath())
def frontEndTempFolder (self):
return self.tempFolder()
def developmentTargetFolder (self):
return os.path.join(self.projectTargetDir, 'development')
def targetFolder (self):
return os.path.join(self.projectTargetDir, self.relativePath())
# --------------------------------------------------------------------------
def writeToFolder (self, folder, filename, content):
file = open(os.path.join(folder, filename), 'w')
file.write(content.encode('utf-8'))
file.close()
def configureIndexContent (self, indexContent, requestPathPrefix = ".."):
result = indexContent
result = result.replace( '@request.path@', requestPathPrefix + '/' + self.settings['request.path'] )
result = result.replace( '@should.pay.toll@', self.settings['should.pay.toll'] )
return result
+ def formatMAC (self, value):
+ x = iter(value)
+ return ' '.join([reduce(add, tup) for tup in izip(x, x, x, x)])
+
+
def logChecksums (self, content, message):
- md5Digest = hashlib.md5(content.encode('utf-8')).hexdigest()
- shaDigest = hashlib.sha1(content.encode('utf-8')).hexdigest()
- sha256Digest = hashlib.sha256(content.encode('utf-8')).hexdigest()
+ md5Digest = self.formatMAC(hashlib.md5(content.encode('utf-8')).hexdigest())
+ shaDigest = self.formatMAC(hashlib.sha1(content.encode('utf-8')).hexdigest())
+ sha256Digest = self.formatMAC(hashlib.sha256(content.encode('utf-8')).hexdigest())
print message + ": " + md5Digest + " (md5)"
print message + ": " + shaDigest + " (sha1)"
print message + ": " + sha256Digest + " (sha256)"
def shouldCompileCode (self):
return ('debug' in self.versions) or ('install' in self.versions)
def run (self):
print self.name() + " - RUN"
if self.shouldCompileCode():
self.compileCode()
for frontend in self.frontends:
if (frontend.module == frontend.submodule):
submoduleExtension = ''
else:
submoduleExtension = '.' + frontend.submodule
main.createFolder(os.path.join(self.frontEndTempFolder(), frontend.module))
if 'debug' in self.versions:
frontend.copyResourcesToFolder(self.frontEndTempFolder())
index = self.configureIndexContent(frontend.assemble(assemblyMode='DEBUG', versionType='DEBUG'))
self.writeToFolder(self.frontEndTempFolder(), os.path.join(frontend.module, 'index_debug' + submoduleExtension + '.html'), index)
if 'install' in self.versions:
index = self.configureIndexContent(frontend.assemble())
self.writeToFolder(self.frontEndTempFolder(), os.path.join(frontend.module, 'index' + submoduleExtension + '.html'), index)
self.logChecksums(index, "[" + self.name() + " - " + frontend.module + "] index" + submoduleExtension + ".html checksum")
self.createPackage()
# if 'development' in self.versions:
# for frontend in self.frontends:
# if (frontend.module == frontend.submodule):
# submoduleExtension = ''
# else:
# submoduleExtension = '.' + frontend.submodule
#
# print "FRONTEND module: " + frontend.module
# print "FRONTEND submodule: " + frontend.submodule
#
## main.createFolder(os.path.join(self.developmentTargetFolder(), frontend.module))