Ejemplo n.º 1
0
    def validateMDB(self):

        self.db.dbfile.seek(0)

        i = 0
        while self.db.dbfile.tell() < self.db.dbfilesize:
            buf = self.db.dbfile.read(self.db.dbpagesize)

            type = ord(buf[0])

            if type in MDBValidatorMarkers.DBPAGEINDEX:
                self.updatecount(type)

                if type == MDBValidatorMarkers.DBDATAPAGE:
                    self.mdbDP = MDBDataPageValidator(self.db.dbversion)
                    self.mdbDP.handleMDBDataPage(buf)

                    if self.mdbDP.versionset == True:
                        self.versionno = self.mdbDP.versionno
                        self.buildno = self.mdbDP.buildno

                elif type == MDBValidatorMarkers.DBTABLEDEFINITION:

                    if i == MDBValidatorMarkers.MSYSOBJECTSPAGE:  # want MSysObjects #from design view
                        self.mdbTDEF = MDBTableDefinitionValidator(
                        )  # definitions table 2nd page of DB
                        self.mdbTDEF.handleMDBTableDefinition(buf)

                #TODO:
                #if type == MDBValidatorMarkers.DBDEFINITION:
                #elif type == MDBValidatorMarkers.DBINTERINDEXPAGE:
                #elif type == MDBValidatorMarkers.DBLEAFINDEXPAGE:
                #elif type == MDBValidatorMarkers.DBPAGEUSAGEBMP:
                #elif type == MDBValidatorMarkers.DBPAGENOID:

            else:
                self.updatecount(-1)

            i += 1

        # Write to stdout...
        #self.db.outputObjectData()
        self.outputObjectData()
Ejemplo n.º 2
0
	def validateMDB(self):
				
		self.db.dbfile.seek(0)
		
		i = 0
		while self.db.dbfile.tell() < self.db.dbfilesize:
			buf = self.db.dbfile.read(self.db.dbpagesize)
			
			type = ord(buf[0])
			
			if type in MDBValidatorMarkers.DBPAGEINDEX:
				self.updatecount(type)
				
				if type == MDBValidatorMarkers.DBDATAPAGE:
					self.mdbDP = MDBDataPageValidator(self.db.dbversion)
					self.mdbDP.handleMDBDataPage(buf)	
					
					if self.mdbDP.versionset == True:
						self.versionno = self.mdbDP.versionno
						self.buildno = self.mdbDP.buildno
					
				elif type == MDBValidatorMarkers.DBTABLEDEFINITION:
				
					if i == MDBValidatorMarkers.MSYSOBJECTSPAGE:		# want MSysObjects #from design view
						self.mdbTDEF = MDBTableDefinitionValidator()		# definitions table 2nd page of DB
						self.mdbTDEF.handleMDBTableDefinition(buf)
					
				#TODO:
				#if type == MDBValidatorMarkers.DBDEFINITION:
				#elif type == MDBValidatorMarkers.DBINTERINDEXPAGE:
				#elif type == MDBValidatorMarkers.DBLEAFINDEXPAGE:
				#elif type == MDBValidatorMarkers.DBPAGEUSAGEBMP:
				#elif type == MDBValidatorMarkers.DBPAGENOID: 

			else:
				self.updatecount(-1)

			i+=1
		
		# Write to stdout...
		#self.db.outputObjectData()
		self.outputObjectData()
Ejemplo n.º 3
0
class MDBValidatorClass:

    expectedpages = ''
    validsize = ''
    db = ''

    versionno = 'null'
    buildno = 'null'

    def __init__(self, mdb):
        self.mdb = mdb
        self.db = MDBDefinitionValidator(self.mdb)
        if self.db.processDBDefinition() is True:
            if (self.db.dbfilesize % self.db.dbpagesize) is 0:
                self.validsize = "True"
            else:
                self.validsize = "False"
        else:
            return 1

    def validateMDB(self):

        self.db.dbfile.seek(0)

        i = 0
        while self.db.dbfile.tell() < self.db.dbfilesize:
            buf = self.db.dbfile.read(self.db.dbpagesize)

            type = ord(buf[0])

            if type in MDBValidatorMarkers.DBPAGEINDEX:
                self.updatecount(type)

                if type == MDBValidatorMarkers.DBDATAPAGE:
                    self.mdbDP = MDBDataPageValidator(self.db.dbversion)
                    self.mdbDP.handleMDBDataPage(buf)

                    if self.mdbDP.versionset == True:
                        self.versionno = self.mdbDP.versionno
                        self.buildno = self.mdbDP.buildno

                elif type == MDBValidatorMarkers.DBTABLEDEFINITION:

                    if i == MDBValidatorMarkers.MSYSOBJECTSPAGE:  # want MSysObjects #from design view
                        self.mdbTDEF = MDBTableDefinitionValidator(
                        )  # definitions table 2nd page of DB
                        self.mdbTDEF.handleMDBTableDefinition(buf)

                #TODO:
                #if type == MDBValidatorMarkers.DBDEFINITION:
                #elif type == MDBValidatorMarkers.DBINTERINDEXPAGE:
                #elif type == MDBValidatorMarkers.DBLEAFINDEXPAGE:
                #elif type == MDBValidatorMarkers.DBPAGEUSAGEBMP:
                #elif type == MDBValidatorMarkers.DBPAGENOID:

            else:
                self.updatecount(-1)

            i += 1

        # Write to stdout...
        #self.db.outputObjectData()
        self.outputObjectData()

    def updatecount(self, type):
        c = MDBValidatorMarkers.DBPAGECOUNT[type]
        c += 1
        MDBValidatorMarkers.DBPAGECOUNT[type] = c

    def __writeAll2File__():
        doSomething = 0

        #for each object... (put all page objects into an array?)
        # object.__write2file__()
        # object.__write2file__()
        # object.__write2file__()
        # object.__write2file__()

    # Output code

    def incrementVersion(self, versionno):
        if versionno[0:2] == '06':
            return "7.0"
        elif versionno[0:2] == '07':
            return "8.0"
        elif versionno[0:2] == '08':
            return "9.0"
        elif versionno[0:2] == '09':
            return "10.0"
        else:
            return "0"

    def outputObjectData(self):
        mdbutil = MDBUtilityClass()

        # File system metadata
        stats = os.stat(self.mdb)

        mdbutil.__stdout__("")
        mdbutil.__fmttime__("Created : ", stats.st_ctime)  #created
        mdbutil.__fmttime__("Modified: ", self.db.mtime)  #modified
        mdbutil.__fmttime__("Accessed: ", self.db.atime)  #accessed
        mdbutil.__stdout__("")
        mdbutil.__stdout__("Filesize: " + str(self.db.dbfilesize) + " bytes")
        mdbutil.__stdout__("")

        mdbutil.__stdout__("Magic:     " + self.db.magic)
        mdbutil.__stdout__("")
        mdbutil.__stdout__("Format ID: " + self.db.formatid)

        if self.db.versiontext == MDBDefinitionMarkers.JETVER[
                MDBDefinitionMarkers.JET3]:
            puid = 'x-fmt/238 x-fmt/239'
        elif self.db.versiontext == MDBDefinitionMarkers.JETVER[
                MDBDefinitionMarkers.JET4]:
            puid = 'x-fmt/240, x-fmt/241'

        mdbutil.__stdout__("Version:   " + self.db.versiontext)

        mdbutil.__stdout__("Access Version / Build Number: " + self.versionno +
                           "." + self.buildno + " (" +
                           self.incrementVersion(self.versionno) + "." +
                           self.buildno + ")")
        mdbutil.__stdout__("")
        mdbutil.__stdout__("PUID: " + puid)

        #TODO: Version Number Switch, plus all by one -ish

        mdbutil.__stdout__("")
        mdbutil.__stdout__("Password: "******"Code page    : " + self.db.t_codepage)
        mdbutil.__stdout__("DB key       : " + self.db.t_dbkey)
        mdbutil.__stdout__("Creation Date: " + self.db.t_creationdate)

        x = MDBValidatorMarkers.DBPAGEINDEX.itervalues()
        mdbutil.__stdout__("")
        mdbutil.__stdout__("Page count")
        mdbutil.__stdout__("---")

        count = 0
        for v in x:
            c = MDBValidatorMarkers.DBPAGECOUNT.get(v)
            count = count + c
            mdbutil.__stdout__(
                MDBValidatorMarkers.DBPAGETYPE.get(v) + ": " + str(c))

        expectedpages = self.db.dbfilesize / self.db.dbpagesize

        mdbutil.__stdout__("---")
        mdbutil.__stdout__("Total (count/expected): " + str(count) + " / " +
                           str(expectedpages))
Ejemplo n.º 4
0
class MDBValidatorClass:

	expectedpages = ''
	validsize = ''
	db = ''
	
	versionno = 'null'
	buildno = 'null'

	def __init__(self, mdb):
		self.mdb = mdb
		self.db = MDBDefinitionValidator(self.mdb)
		if self.db.processDBDefinition() is True:
			if (self.db.dbfilesize % self.db.dbpagesize) is 0:
				self.validsize = "True"
			else:
				self.validsize = "False"
		else:
			return 1
			
	def validateMDB(self):
				
		self.db.dbfile.seek(0)
		
		i = 0
		while self.db.dbfile.tell() < self.db.dbfilesize:
			buf = self.db.dbfile.read(self.db.dbpagesize)
			
			type = ord(buf[0])
			
			if type in MDBValidatorMarkers.DBPAGEINDEX:
				self.updatecount(type)
				
				if type == MDBValidatorMarkers.DBDATAPAGE:
					self.mdbDP = MDBDataPageValidator(self.db.dbversion)
					self.mdbDP.handleMDBDataPage(buf)	
					
					if self.mdbDP.versionset == True:
						self.versionno = self.mdbDP.versionno
						self.buildno = self.mdbDP.buildno
					
				elif type == MDBValidatorMarkers.DBTABLEDEFINITION:
				
					if i == MDBValidatorMarkers.MSYSOBJECTSPAGE:		# want MSysObjects #from design view
						self.mdbTDEF = MDBTableDefinitionValidator()		# definitions table 2nd page of DB
						self.mdbTDEF.handleMDBTableDefinition(buf)
					
				#TODO:
				#if type == MDBValidatorMarkers.DBDEFINITION:
				#elif type == MDBValidatorMarkers.DBINTERINDEXPAGE:
				#elif type == MDBValidatorMarkers.DBLEAFINDEXPAGE:
				#elif type == MDBValidatorMarkers.DBPAGEUSAGEBMP:
				#elif type == MDBValidatorMarkers.DBPAGENOID: 

			else:
				self.updatecount(-1)

			i+=1
		
		# Write to stdout...
		#self.db.outputObjectData()
		self.outputObjectData()

	def updatecount(self, type):
		c = MDBValidatorMarkers.DBPAGECOUNT[type]
		c+=1
		MDBValidatorMarkers.DBPAGECOUNT[type] = c	

	def __writeAll2File__():
		doSomething = 0
		
		#for each object... (put all page objects into an array?)
			# object.__write2file__()
			# object.__write2file__()
			# object.__write2file__()
			# object.__write2file__()

	# Output code

	def incrementVersion(self, versionno):
		if versionno[0:2] == '06':
			return "7.0"
		elif versionno[0:2] == '07':
			return "8.0"
		elif versionno[0:2] == '08':
			return "9.0"
		elif versionno[0:2] == '09':
			return "10.0"
		else:
			return "0"

	def outputObjectData(self):
		mdbutil = MDBUtilityClass()
		
		# File system metadata
		stats = os.stat(self.mdb)
		
		mdbutil.__stdout__("")
		mdbutil.__fmttime__("Created : ", stats.st_ctime)	#created
		mdbutil.__fmttime__("Modified: ", self.db.mtime)	#modified
		mdbutil.__fmttime__("Accessed: ", self.db.atime)	#accessed
		mdbutil.__stdout__("")
		mdbutil.__stdout__("Filesize: " + str(self.db.dbfilesize) + " bytes")
		mdbutil.__stdout__("")

		mdbutil.__stdout__("Magic:     " + self.db.magic)
		mdbutil.__stdout__("")
		mdbutil.__stdout__("Format ID: " + self.db.formatid)
		
		if self.db.versiontext == MDBDefinitionMarkers.JETVER[MDBDefinitionMarkers.JET3]:
			puid = 'x-fmt/238 x-fmt/239'
		elif self.db.versiontext == MDBDefinitionMarkers.JETVER[MDBDefinitionMarkers.JET4]:
			puid = 'x-fmt/240, x-fmt/241'

		mdbutil.__stdout__("Version:   " + self.db.versiontext)

		mdbutil.__stdout__("Access Version / Build Number: " + self.versionno + "." + self.buildno + " (" + 		self.incrementVersion(self.versionno) + "." + self.buildno + ")")
		mdbutil.__stdout__("")
		mdbutil.__stdout__("PUID: " + puid)

		#TODO: Version Number Switch, plus all by one -ish
		
		mdbutil.__stdout__("")
		mdbutil.__stdout__("Password: "******"Code page    : " + self.db.t_codepage)
		mdbutil.__stdout__("DB key       : " + self.db.t_dbkey)
		mdbutil.__stdout__("Creation Date: " + self.db.t_creationdate) 


		x = MDBValidatorMarkers.DBPAGEINDEX.itervalues()
		mdbutil.__stdout__("")
		mdbutil.__stdout__("Page count")
		mdbutil.__stdout__("---")
		
		count = 0
		for v in x:
			c = MDBValidatorMarkers.DBPAGECOUNT.get(v)
			count = count + c
			mdbutil.__stdout__(MDBValidatorMarkers.DBPAGETYPE.get(v) + ": " + str(c))
		
		expectedpages = self.db.dbfilesize / self.db.dbpagesize
		
		mdbutil.__stdout__("---")
		mdbutil.__stdout__("Total (count/expected): " + str(count) + " / " + str(expectedpages))