File: dpkg_certdb.py

package info (click to toggle)
dpkg-scriptlib 0.1-2hamm1
  • links: PTS
  • area: main
  • in suites: hamm, slink
  • size: 188 kB
  • ctags: 230
  • sloc: python: 1,685; perl: 534; makefile: 41; sh: 18
file content (78 lines) | stat: -rw-r--r-- 1,841 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
import gdbm, time, pgp, strfile, types
import dpkg_packages, dpkg_util, dpkg_certificate

class dpkg_certdb:
	
	def __init__ (self, fn):
		self.fn = fn

	def store (self, key, val, logger):
		while 1:
			try:
				db = gdbm.open (self.fn, 'w')
				break
			except gdbm.error, v:
				logger ('info', "error %d opening gdbm file ('%s'), retrying" % v)
				time.sleep (5)
		db[key] = val
		db.close ()

	def keys (self):
		db = gdbm.open (self.fn, 'r')
		r = db.keys (); db.close (); return r

	def create (self):
		db = gdbm.open (self.fn, 'c')
		db.close ()

	def clear (self):
		db = gdbm.open (self.fn, 'n')
		db.close ()

	def fetch_key (self, key):
		db = gdbm.open (self.fn, 'r')
		r = db[key]; db.close (); return r

	def fetch_package (self, package, architecture, log):
	
		db = gdbm.open (self.fn, 'r')

		if (type (package) == types.StringType):
			pname = package
		else:
			pname = package['package'] + '_' + dpkg_packages.package_canon_version (package)
			if (db.has_key (pname + '_' + architecture)):
				pname = pname + '_' + architecture
			elif (db.has_key (pname + '_' + 'all')):
				pname = pname + '_' + 'all'
			else:
				raise KeyError, pname

		signed = db[pname]
		db.close ()

		body, sig = pgp.parse_message (signed)

		pgp.verify (body, sig, dpkg_util.verifier_keyname, dpkg_util.verifier_keyid)
			
		f = strfile.strfile (body)
		c = dpkg_certificate.read_entry (f, log.log)
		f.close ()

		cname = dpkg_packages.package_canon_name (c)
		if (cname != pname):
			raise ValueError, 'corrupt certificate database (certificate for key "%s" is actually "%s")' % (pname, cname)
		
		return c

	def iterate (self, f):
		db = gdbm.open (self.fn, 'r')
		for key in db.keys():
			f (key, db)

	def has_key (self, key):
		db = gdbm.open (self.fn, 'r')
		r = db.has_key (key); db.close (); return r

	def close (self):
		pass