diff options
author | Rob Austein <sra@hactrn.net> | 2010-01-07 01:22:04 +0000 |
---|---|---|
committer | Rob Austein <sra@hactrn.net> | 2010-01-07 01:22:04 +0000 |
commit | c1654df50faaf3313fefa7a103026d0dd5f52b67 (patch) | |
tree | 07d6b1e29ec50819b8da16f94e3b4346f69f46f8 | |
parent | 1941a578fafd9d20c95c834d72a330957cee4f62 (diff) |
Don't attempt to withdraw a manifest or CRL that was never published
when cleaning up a dead ca_detail.
svn path=/rpkid/rpki/rpki_engine.py; revision=2934
-rw-r--r-- | rpkid/rpki/rpki_engine.py | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/rpkid/rpki/rpki_engine.py b/rpkid/rpki/rpki_engine.py index a3315fb0..3ea72260 100644 --- a/rpkid/rpki/rpki_engine.py +++ b/rpkid/rpki/rpki_engine.py @@ -661,10 +661,12 @@ class ca_detail_obj(rpki.sql.sql_persistent): handler = False if allow_failure else None) for roa in self.roas(): roa.revoke(publisher = publisher, allow_failure = allow_failure) - publisher.withdraw(cls = rpki.publication.manifest_elt, uri = self.manifest_uri(ca), obj = self.latest_manifest, repository = repository, - handler = False if allow_failure else None) - publisher.withdraw(cls = rpki.publication.crl_elt, uri = self.crl_uri(ca), obj = self.latest_crl, repository = repository, - handler = False if allow_failure else None) + if self.latest_manifest is not None: + publisher.withdraw(cls = rpki.publication.manifest_elt, uri = self.manifest_uri(ca), obj = self.latest_manifest, repository = repository, + handler = False if allow_failure else None) + if self.latest_crl is not None: + publisher.withdraw(cls = rpki.publication.crl_elt, uri = self.crl_uri(ca), obj = self.latest_crl, repository = repository, + handler = False if allow_failure else None) for cert in self.child_certs() + self.revoked_certs(): cert.sql_delete() self.sql_delete() |