Ejemplo n.º 1
0
def parseZip( fn ):
	date_time = ''
	members = dict()
	removemembers = False
	zipfile = ZipFile( fn )
	cache.invalidate(recordlist.output, 'list_output', )
	files_of_interest = ['infolog.txt','ext.txt','platform.txt','script.txt','settings.txt','unitsync.log','client.txt','information.txt','demo.sdf']
	
	for info in zipfile.infolist():
		if info.filename in files_of_interest and info.file_size < 5 * 1024 * 1024:
			members[info.filename] = zipfile.read( info.filename )
			if info.filename == 'infolog.txt':
				date_time = info.date_time
		else:
			removemembers = True
	
	if removemembers:
		newzipfile = ZipFile (fn + '.new', 'w')
		tmpfilename = '/tmp/' + os.path.basename (fn) + '.tmp'
		for file in members.keys ():
			tmpfile = open (tmpfilename, 'w')
			tmpfile.write (zipfile.read (file))
			tmpfile.close ()
			newzipfile.write (tmpfilename, file)
			os.remove (tmpfilename)
		newzipfile.close ()
		zipfile.close ()
		os.rename (fn, fn + '.orig')
		os.rename (fn + '.new', fn)
	else:
		zipfile.close ()
	
	return db.parseZipMembers( fn, members, date_time )
Ejemplo n.º 2
0
def parseZip( fn ):
	members = dict()
	zipfile = ZipFile( fn )
	cache.invalidate(recordlist.output, 'list_output', )
	files_of_interest = ['infolog.txt','ext.txt','platform.txt','script.txt','settings.txt','unitsync.log']
	for info in zipfile.infolist():
		if info.filename in files_of_interest and info.file_size < 20e5:
			members[info.filename] = zipfile.read( info.filename )
	return db.parseZipMembers( fn, members )
Ejemplo n.º 3
0
def parseZip(fn):
    date_time = ''
    members = dict()
    removemembers = False
    zipfile = ZipFile(fn)
    cache.invalidate(
        recordlist.output,
        'list_output',
    )
    files_of_interest = [
        'infolog.txt', 'ext.txt', 'platform.txt', 'script.txt', 'settings.txt',
        'unitsync.log', 'client.txt', 'information.txt', 'demo.sdf'
    ]

    for info in zipfile.infolist():
        if info.filename in files_of_interest and info.file_size < 5 * 1024 * 1024:
            members[info.filename] = zipfile.read(info.filename)
            if info.filename == 'infolog.txt':
                date_time = info.date_time
        else:
            removemembers = True

    if removemembers:
        newzipfile = ZipFile(fn + '.new', 'w')
        tmpfilename = '/tmp/' + os.path.basename(fn) + '.tmp'
        for file in members.keys():
            tmpfile = open(tmpfilename, 'w')
            tmpfile.write(zipfile.read(file))
            tmpfile.close()
            newzipfile.write(tmpfilename, file)
            os.remove(tmpfilename)
        newzipfile.close()
        zipfile.close()
        os.rename(fn, fn + '.orig')
        os.rename(fn + '.new', fn)
    else:
        zipfile.close()

    return db.parseZipMembers(fn, members, date_time)
Ejemplo n.º 4
0
def output_post():
    try:
        data = request.POST["file"].value
        upload_dir = config.get("site", "uploads")
        fn = "%s/%s/%s.zip" % (os.getcwd(), upload_dir, hashlib.sha224(data).hexdigest())
        fd = open(fn, "wb")
        fd.write(data)
        fd.close()
        members = dict()
        zipfile = ZipFile(fn)

        files_of_interest = ["infolog.txt", "ext.txt", "platform.txt", "script.txt", "settings.txt", "unitsync.log"]
        for info in zipfile.infolist():
            if info.filename in files_of_interest and info.file_size < 20e5:
                members[info.filename] = zipfile.read(info.filename)
        new_id = db.parseZipMembers(fn, members)
        base_url = config.get("site", "baseurl")
        chan = config.get("tasbot", "report_channel")
        tasbot.tasclient.say(chan, "new crash report uploaded: http://%s/details?id=%d" % (base_url, new_id))
        return "success"

    except Exception, m:
        print m
        return env.get_template("error.html").render(err_msg=str(m))