2012-08-16 21:49:52 -07:00
|
|
|
# Script meant to be installed on eehouse.org.
|
2012-08-13 21:10:22 -07:00
|
|
|
|
2012-08-15 18:55:54 -07:00
|
|
|
import logging, shelve, hashlib, sys, json
|
2012-08-16 21:49:52 -07:00
|
|
|
from mod_python import apache
|
2012-08-13 21:10:22 -07:00
|
|
|
|
2012-08-14 18:29:48 -07:00
|
|
|
k_suffix = '.xwd'
|
2012-08-15 06:51:48 -07:00
|
|
|
k_filebase = "/var/www/"
|
|
|
|
k_shelfFile = k_filebase + "xw4/info_shelf"
|
|
|
|
k_urlbase = "http://eehouse.org/"
|
|
|
|
k_versions = { 'org.eehouse.android.xw4': {
|
|
|
|
'version' : 42,
|
|
|
|
'url' : 'xw4/android/XWords4-release_android_beta_49.apk'
|
|
|
|
}
|
|
|
|
,'org.eehouse.android.xw4sms' : {
|
|
|
|
'version' : 41,
|
|
|
|
'url' : 'xw4/android/sms/XWords4-release_android_beta_49-3-g8b6af3f.apk'
|
|
|
|
}
|
|
|
|
}
|
2012-08-14 18:29:48 -07:00
|
|
|
|
|
|
|
s_shelf = None
|
2012-08-15 06:51:48 -07:00
|
|
|
|
2012-08-13 21:10:22 -07:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG
|
|
|
|
,format='%(asctime)s [[%(levelname)s]] %(message)s'
|
|
|
|
,datefmt='%d %b %y %H:%M'
|
2012-08-14 07:13:03 -07:00
|
|
|
,filename='/tmp/info_py.log')
|
|
|
|
# ,filemode='w')
|
|
|
|
|
|
|
|
# This seems to be required to prime the pump somehow.
|
2012-08-14 18:29:48 -07:00
|
|
|
# logging.debug( "loaded...." )
|
|
|
|
|
|
|
|
def md5Checksum(sums, filePath):
|
|
|
|
if not filePath.endswith(k_suffix): filePath += k_suffix
|
|
|
|
if not filePath in sums:
|
2012-08-15 06:51:48 -07:00
|
|
|
file = open( k_filebase + "and_wordlists/" + filePath, 'rb' )
|
2012-08-14 18:29:48 -07:00
|
|
|
md5 = hashlib.md5()
|
|
|
|
while True:
|
|
|
|
buffer = file.read(128)
|
|
|
|
if not buffer: break
|
|
|
|
md5.update( buffer )
|
|
|
|
sums[filePath] = md5.hexdigest()
|
2012-08-16 21:49:52 -07:00
|
|
|
logging.debug( "figured sum for %s" % filePath )
|
2012-08-14 18:29:48 -07:00
|
|
|
return sums[filePath]
|
|
|
|
|
|
|
|
def getDictSums():
|
|
|
|
global s_shelf
|
|
|
|
s_shelf = shelve.open(k_shelfFile)
|
|
|
|
if not 'sums' in s_shelf: s_shelf['sums'] = {}
|
|
|
|
if not 'count' in s_shelf: s_shelf['count'] = 0
|
|
|
|
s_shelf['count'] += 1
|
|
|
|
logging.debug( "Count now %d" % s_shelf['count'] )
|
|
|
|
return s_shelf['sums']
|
2012-08-13 21:10:22 -07:00
|
|
|
|
2012-08-14 07:13:03 -07:00
|
|
|
# public
|
2012-08-16 21:49:52 -07:00
|
|
|
def curVersion( req, name, avers, gvers, installer ):
|
2012-08-15 06:51:48 -07:00
|
|
|
global k_versions
|
2012-08-16 21:49:52 -07:00
|
|
|
result = { 'success' : True }
|
|
|
|
logging.debug('IP address of requester is %s' % req.get_remote_host(apache.REMOTE_NAME))
|
|
|
|
logging.debug( "name: %s; avers: %s; installer: %s; gvers: %s"
|
|
|
|
% (name, avers, installer, gvers) )
|
2012-08-15 06:51:48 -07:00
|
|
|
if name in k_versions:
|
2012-08-16 21:49:52 -07:00
|
|
|
if k_versions[name]['version'] > int(avers):
|
2012-08-14 07:13:03 -07:00
|
|
|
logging.debug( name + " is old" )
|
2012-08-15 18:55:54 -07:00
|
|
|
result['url'] = k_urlbase + k_versions[name]['url']
|
2012-08-15 06:51:48 -07:00
|
|
|
else:
|
|
|
|
logging.debug(name + " is up-to-date")
|
2012-08-13 21:10:22 -07:00
|
|
|
else:
|
|
|
|
logging.debug( 'Error: bad name ' + name )
|
2012-08-15 18:55:54 -07:00
|
|
|
return json.dumps( result )
|
2012-08-14 07:13:03 -07:00
|
|
|
|
|
|
|
# public
|
|
|
|
def dictVersion( req, name, lang, md5sum ):
|
2012-08-16 21:49:52 -07:00
|
|
|
result = { 'success' : True }
|
2012-08-14 18:29:48 -07:00
|
|
|
if not name.endswith(k_suffix): name += k_suffix
|
|
|
|
dictSums = getDictSums()
|
2012-08-15 07:22:10 -07:00
|
|
|
path = lang + "/" + name
|
2012-08-14 18:29:48 -07:00
|
|
|
if not path in dictSums:
|
|
|
|
sum = md5Checksum( dictSums, path )
|
|
|
|
if sum:
|
|
|
|
dictSums[path] = sum
|
|
|
|
s_shelf['sums'] = dictSums
|
2012-08-15 07:22:10 -07:00
|
|
|
if path in dictSums:
|
|
|
|
if dictSums[path] != md5sum:
|
2012-08-15 18:55:54 -07:00
|
|
|
result['url'] = k_urlbase + "and_wordlists/" + path
|
2012-08-14 07:13:03 -07:00
|
|
|
else:
|
|
|
|
logging.debug( path + " not known" )
|
2012-08-14 18:29:48 -07:00
|
|
|
s_shelf.close()
|
2012-08-15 18:55:54 -07:00
|
|
|
return json.dumps( result )
|
2012-08-14 18:29:48 -07:00
|
|
|
|
|
|
|
def clearShelf():
|
|
|
|
shelf = shelve.open(k_shelfFile)
|
|
|
|
shelf['sums'] = {}
|
|
|
|
shelf.close()
|
|
|
|
|
|
|
|
def usage():
|
|
|
|
print "usage:", sys.argv[0], '--get-sums [lang/dict]* | --clear-shelf'
|
|
|
|
|
|
|
|
def main():
|
|
|
|
arg = sys.argv[1]
|
|
|
|
if arg == '--clear-shelf':
|
|
|
|
clearShelf()
|
|
|
|
elif arg == '--get-sums':
|
|
|
|
dictSums = getDictSums()
|
|
|
|
for arg in sys.argv[2:]:
|
|
|
|
print arg, md5Checksum(dictSums, arg)
|
|
|
|
s_shelf['sums'] = dictSums
|
|
|
|
s_shelf.close()
|
|
|
|
else:
|
|
|
|
usage()
|
|
|
|
|
|
|
|
##############################################################################
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|