/usr/share/doc/pyro/examples/ssl/server.py is in pyro-examples 1:3.14-1.1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | #!/usr/bin/env python
import sys
import Pyro.naming, Pyro.core, Pyro.util, Pyro.protocol
from Pyro.errors import PyroError,NamingError
from Pyro.protocol import getHostname
######## Custom connections validator.
class printCertValidator(Pyro.protocol.BasicSSLValidator):
def checkCertificate(self,cert):
if cert is None:
return (0,3)
print "Cert issuer: %s" % cert.get_issuer()
print "Cert subject: %s" % cert.get_subject()
print "Cert valid not before: %s" % cert.get_not_before()
print "Cert valid not after: %s" % cert.get_not_after()
return (1,0)
##### test object
class testclass(Pyro.core.ObjBase):
def passSecretMessage(self,arg):
print 'I got a secret message: ',arg
return "Elvis Presley isn't dead, he just went home"
##### main program.
Pyro.config.PYROSSL_CERT="server.pem"
# Pyro.config.PYROSSL_KEY="server.key"
Pyro.config.PYRO_DNS_URI=True
Pyro.config.PYRO_TRACELEVEL=3
Pyro.config.PYRO_NS_DEFAULTGROUP=':test'
Pyro.config.PYRO_LOGFILE='server_log'
print 'Check the logfile for messages: server_log'
# Construct the Pyro Daemon with our own connection validator, using SSL
daemon = Pyro.core.Daemon(prtcol='PYROSSL')
daemon.setNewConnectionValidator(printCertValidator()) ### <<--- !!!
# locate the NS
locator = Pyro.naming.NameServerLocator()
print 'searching for Naming Service...'
ns = locator.getNS()
print 'Naming Service found at',ns.URI.address,'('+(Pyro.protocol.getHostname(ns.URI.address) or '??')+') port',ns.URI.port
# make sure our namespace group exists
try: ns.createGroup(Pyro.config.PYRO_NS_DEFAULTGROUP)
except NamingError: pass
daemon.useNameServer(ns)
# connect a new object implementation (first unregister previous one)
try: ns.unregister('ssl')
except NamingError: pass
uri=daemon.connect(testclass(),'ssl')
print "server uri=",uri
# enter the service loop.
print 'Server object "ssl" ready.'
daemon.requestLoop()
|