[Zope-Checkins] CVS: ZODB3/ZEO - zeopasswd.py:1.4 version.txt:1.10 monitor.py:1.4 __init__.py:1.20 StorageServer.py:1.100 ServerStub.py:1.17 DebugServer.py:1.2 CommitLog.py:1.6 ClientStorage.py:1.110

Jeremy Hylton jeremy at zope.com
Thu Oct 2 14:17:55 EDT 2003


Update of /cvs-repository/ZODB3/ZEO
In directory cvs.zope.org:/tmp/cvs-serv18770/ZEO

Modified Files:
	zeopasswd.py version.txt monitor.py __init__.py 
	StorageServer.py ServerStub.py DebugServer.py CommitLog.py 
	ClientStorage.py 
Log Message:
Merge changes from Zope-2_7-branch to the trunk.


=== ZODB3/ZEO/zeopasswd.py 1.3 => 1.4 ===
--- ZODB3/ZEO/zeopasswd.py:1.3	Wed Jul 30 16:39:54 2003
+++ ZODB3/ZEO/zeopasswd.py	Thu Oct  2 14:17:22 2003
@@ -17,16 +17,12 @@
 usage: python zeopasswd.py [options] username [password]
 
 -C/--configuration URL -- configuration file or URL
--p/--protocol -- authentication protocol name
--f/--filename -- authentication database filename
--r/--realm -- authentication database realm
 -d/--delete -- delete user instead of updating password
 """
 
 import getopt
 import getpass
 import sys
-import os
 
 import ZConfig
 import ZEO
@@ -39,41 +35,22 @@
 def options(args):
     """Password-specific options loaded from regular ZEO config file."""
 
+    schema = ZConfig.loadSchema(os.path.join(os.path.dirname(ZEO.__file__),
+                                             "schema.xml"))
+
     try:
-        options, args = getopt.getopt(args, "dr:p:f:C:", ["configure=", 
-                                                          "protocol=", 
-                                                          "filename=",
-                                                          "realm"])
+        options, args = getopt.getopt(args, "C:", ["configure="])
     except getopt.error, msg:
         usage(msg)
     config = None
-    delete = 0
-    auth_protocol = None
-    auth_db = "" 
-    auth_realm = None
+    delete = False
     for k, v in options:
         if k == '-C' or k == '--configure':
-            schemafile = os.path.join(os.path.dirname(ZEO.__file__),
-                                                     "schema.xml")
-            schema = ZConfig.loadSchema(schemafile)
             config, nil = ZConfig.loadConfig(schema, v)
         if k == '-d' or k == '--delete':
-            delete = 1
-        if k == '-p' or k == '--protocol':
-            auth_protocol = v
-        if k == '-f' or k == '--filename':
-            auth_db = v
-        if k == '-r' or k == '--realm':
-            auth_realm = v
-
-    if config is not None:
-        if auth_protocol or auth_db:
-            usage("Conflicting options; use either -C *or* -p and -f")
-        auth_protocol = config.zeo.authentication_protocol
-        auth_db = config.zeo.authentication_database
-        auth_realm = config.zeo.authentication_realm
-    elif not (auth_protocol and auth_db):
-        usage("Must specifiy configuration file or protocol and database")
+            delete = True
+    if config is None:
+        usage("Must specifiy configuration file")
 
     password = None
     if delete:
@@ -91,22 +68,21 @@
             username = args[0]
         else:
             username, password = args
-        
-    return auth_protocol, auth_db, auth_realm, delete, username, password
+
+    return config.zeo, delete, username, password
 
 def main(args=None):
-    p, auth_db, auth_realm, delete, username, password = options(args)
+    options, delete, username, password = options(args)
+    p = options.authentication_protocol
     if p is None:
         usage("ZEO configuration does not specify authentication-protocol")
     if p == "digest":
         from ZEO.auth.auth_digest import DigestDatabase as Database
     elif p == "srp":
         from ZEO.auth.auth_srp import SRPDatabase as Database
-    else:
-        raise ValueError, "Unknown database type %r" % p
-    if auth_db is None:
+    if options.authentication_database is None:
         usage("ZEO configuration does not specify authentication-database")
-    db = Database(auth_db, auth_realm)
+    db = Database(options.authentication_database)
     if delete:
         db.del_user(username)
     else:
@@ -116,5 +92,4 @@
     db.save()
 
 if __name__ == "__main__":
-    main(sys.argv[1:])
-
+    main(sys.argv)


=== ZODB3/ZEO/version.txt 1.9 => 1.10 ===
--- ZODB3/ZEO/version.txt:1.9	Mon Jun 16 17:49:58 2003
+++ ZODB3/ZEO/version.txt	Thu Oct  2 14:17:22 2003
@@ -1,5 +1 @@
-2.1b2
-
-
-
-
+2.2c1


=== ZODB3/ZEO/monitor.py 1.3 => 1.4 ===
--- ZODB3/ZEO/monitor.py:1.3	Wed Jan 15 16:23:16 2003
+++ ZODB3/ZEO/monitor.py	Thu Oct  2 14:17:22 2003
@@ -54,7 +54,7 @@
             elif field == "Active transactions":
                 self.active_txns = int(value)
             elif field == "Commit lock held for":
-                # This assumes 
+                # This assumes
                 self.lock_time = time.time() - int(value)
             elif field == "Commits":
                 self.commits = int(value)
@@ -112,7 +112,7 @@
         n = self.socket.send(s)
         if n < len(s):
             self.buf.append(s[:n])
-            
+
         if self.closed and not self.buf:
             asyncore.dispatcher.close(self)
 


=== ZODB3/ZEO/__init__.py 1.19 => 1.20 ===
--- ZODB3/ZEO/__init__.py:1.19	Mon Jun 16 17:49:58 2003
+++ ZODB3/ZEO/__init__.py	Thu Oct  2 14:17:22 2003
@@ -15,10 +15,10 @@
 
 See the file README.txt in this directory for an overview.
 
-ZEO is now part of ZODB; ZODB's home on the web is 
+ZEO is now part of ZODB; ZODB's home on the web is
 
     http://www.zope.org/Wikis/ZODB
 
 """
 
-version = "2.1b2"
+version = "2.2c1"


=== ZODB3/ZEO/StorageServer.py 1.99 => 1.100 ===
--- ZODB3/ZEO/StorageServer.py:1.99	Mon Sep 15 12:29:19 2003
+++ ZODB3/ZEO/StorageServer.py	Thu Oct  2 14:17:22 2003
@@ -43,7 +43,7 @@
 from ZODB.POSException import TransactionError, ReadOnlyError, ConflictError
 from ZODB.referencesf import referencesf
 from ZODB.Transaction import Transaction
-from ZODB.utils import u64
+from ZODB.utils import u64, oid_repr
 
 _label = "ZSS" # Default label used for logging.
 
@@ -90,7 +90,7 @@
         self._extensions = {}
         for func in self.extensions:
             self._extensions[func.func_name] = None
-        
+
     def finish_auth(self, authenticated):
         if not self.auth_realm:
             return 1
@@ -99,7 +99,7 @@
 
     def set_database(self, database):
         self.database = database
-        
+
     def notifyConnected(self, conn):
         self.connection = conn # For restart_other() below
         self.client = self.ClientStorageStubClass(conn)
@@ -189,7 +189,7 @@
         if not protocol or protocol == 'none':
             return None
         return protocol
-    
+
     def register(self, storage_id, read_only):
         """Select the storage that this client will use
 
@@ -398,6 +398,7 @@
     def _clear_transaction(self):
         # Common code at end of tpc_finish() and tpc_abort()
         self.transaction = None
+        self.txnlog.close()
         if self.locked:
             self.locked = 0
             self.timeout.end(self)
@@ -483,6 +484,8 @@
             self.store_failed = 1
             if isinstance(err, ConflictError):
                 self.stats.conflicts += 1
+                self.log("conflict error oid=%s msg=%s" %
+                         (oid_repr(oid), str(err)), zLOG.BLATHER)
             if not isinstance(err, TransactionError):
                 # Unexpected errors are logged and passed to the client
                 exc_info = sys.exc_info()
@@ -506,6 +509,7 @@
                 self.invalidated.append((oid, version))
         if newserial == ResolvedSerial:
             self.stats.conflicts_resolved += 1
+            self.log("conflict resolved oid=%s" % oid_repr(oid), zLOG.BLATHER)
         self.serials.append((oid, newserial))
         return err is None
 
@@ -680,7 +684,7 @@
             It should be in a format compatible with the authentication
             protocol used; for instance, "sha" and "srp" require different
             formats.
-            
+
             Note that to implement an authentication protocol, a server
             and client authentication mechanism must be implemented in a
             auth_* module, which should be stored inside the "auth"
@@ -728,7 +732,7 @@
             self.monitor = StatsServer(monitor_address, self.stats)
         else:
             self.monitor = None
-            
+
     def _setup_auth(self, protocol):
         # Can't be done in global scope, because of cyclic references
         from ZEO.auth import get_module
@@ -739,9 +743,9 @@
         if not module:
             log("%s: no such an auth protocol: %s" % (name, protocol))
             return
-        
+
         storage_class, client, db_class = module
-        
+
         if not storage_class or not issubclass(storage_class, ZEOStorage):
             log(("%s: %s isn't a valid protocol, must have a StorageClass" %
                  (name, protocol)))
@@ -750,7 +754,7 @@
         self.ZEOStorageClass = storage_class
 
         log("%s: using auth protocol: %s" % (name, protocol))
-        
+
         # We create a Database instance here for use with the authenticator
         # modules. Having one instance allows it to be shared between multiple
         # storages, avoiding the need to bloat each with a new authenticator
@@ -762,7 +766,7 @@
                              "does not match storage realm %r"
                              % (self.database.realm, self.auth_realm))
 
-        
+
     def new_connection(self, sock, addr):
         """Internal: factory to create a new connection.
 
@@ -776,7 +780,7 @@
             zstorage.set_database(self.database)
         else:
             zstorage = self.ZEOStorageClass(self, self.read_only)
-            
+
         c = self.ManagedServerConnectionClass(sock, addr, zstorage, self)
         log("new connection %s: %s" % (addr, `c`))
         return c
@@ -846,12 +850,12 @@
         if not self.invq:
             log("invq empty")
             return None, []
-        
+
         earliest_tid = self.invq[0][0]
         if earliest_tid > tid:
             log("tid to old for invq %s < %s" % (u64(tid), u64(earliest_tid)))
             return None, []
-        
+
         oids = {}
         for tid, L in self.invq:
             for key in L:
@@ -928,6 +932,7 @@
         self._cond.acquire()
         try:
             assert self._client is not None
+            assert self._client is client
             self._client = None
             self._deadline = None
         finally:
@@ -953,7 +958,6 @@
                 self._trigger.pull_trigger(lambda: client.connection.close())
             else:
                 time.sleep(howlong)
-        self.trigger.close()
 
 def run_in_thread(method, *args):
     t = SlowMethodThread(method, args)


=== ZODB3/ZEO/ServerStub.py 1.16 => 1.17 ===
--- ZODB3/ZEO/ServerStub.py:1.16	Fri May 30 15:20:57 2003
+++ ZODB3/ZEO/ServerStub.py	Thu Oct  2 14:17:22 2003
@@ -32,9 +32,13 @@
         zrpc.connection.Connection class.
         """
         self.rpc = rpc
-        if self.rpc.peer_protocol_version == 'Z200':
+        # Wait until we know what version the other side is using.
+        while rpc.peer_protocol_version is None:
+            rpc.pending()
+        if rpc.peer_protocol_version == 'Z200':
             self.lastTransaction = lambda: None
             self.getInvalidations = lambda tid: None
+            self.getAuthProtocol = lambda: None
 
     def extensionMethod(self, name):
         return ExtensionMethodWrapper(self.rpc, name).call
@@ -47,7 +51,7 @@
 
     def getAuthProtocol(self):
         return self.rpc.call('getAuthProtocol')
-    
+
     def lastTransaction(self):
         # Not in protocol version 2.0.0; see __init__()
         return self.rpc.call('lastTransaction')
@@ -150,6 +154,6 @@
     def __init__(self, rpc, name):
         self.rpc = rpc
         self.name = name
-        
+
     def call(self, *a, **kwa):
         return self.rpc.call(self.name, *a, **kwa)


=== ZODB3/ZEO/DebugServer.py 1.1 => 1.2 ===
--- ZODB3/ZEO/DebugServer.py:1.1	Wed Jan 15 16:26:53 2003
+++ ZODB3/ZEO/DebugServer.py	Thu Oct  2 14:17:22 2003
@@ -28,7 +28,7 @@
 ERROR = 4
 
 class DebugManagedServerConnection(ManagedServerConnection):
-    
+
     def __init__(self, sock, addr, obj, mgr):
         # mgr is the DebugServer instance
         self.mgr = mgr
@@ -67,7 +67,7 @@
 
     ZEOStorageClass = DebugZEOStorage
     ManagedServerConnectionClass = DebugManagerConnection
-    
+
     def __init__(self, *args, **kwargs):
         StorageServer.__init__(*args, **kwargs)
         self._setup_record(kwargs["record"])


=== ZODB3/ZEO/CommitLog.py 1.5 => 1.6 ===
--- ZODB3/ZEO/CommitLog.py:1.5	Mon Sep 15 12:29:19 2003
+++ ZODB3/ZEO/CommitLog.py	Thu Oct  2 14:17:22 2003
@@ -42,3 +42,8 @@
         self.read = 1
         self.file.seek(0)
         return self.stores, cPickle.Unpickler(self.file)
+
+    def close(self):
+        if self.file:
+            self.file.close()
+            self.file = None


=== ZODB3/ZEO/ClientStorage.py 1.109 => 1.110 ===
--- ZODB3/ZEO/ClientStorage.py:1.109	Mon Sep 15 12:29:19 2003
+++ ZODB3/ZEO/ClientStorage.py	Thu Oct  2 14:17:22 2003
@@ -99,7 +99,7 @@
                  name='', client=None, debug=0, var=None,
                  min_disconnect_poll=5, max_disconnect_poll=300,
                  wait_for_server_on_startup=None, # deprecated alias for wait
-                 wait=None, # defaults to 1
+                 wait=None, wait_timeout=None,
                  read_only=0, read_only_fallback=0,
                  username='', password='', realm=None):
         """ClientStorage constructor.
@@ -152,6 +152,9 @@
         wait -- A flag indicating whether to wait until a connection
             with a server is made, defaulting to true.
 
+        wait_timeout -- Maximum time to wait for a connection before
+            giving up.  Only meaningful if wait is True.
+
         read_only -- A flag indicating whether this should be a
             read-only storage, defaulting to false (i.e. writing is
             allowed by default).
@@ -302,7 +305,7 @@
                                                     tmax=max_disconnect_poll)
 
         if wait:
-            self._wait()
+            self._wait(wait_timeout)
         else:
             # attempt_connect() will make an attempt that doesn't block
             # "too long," for a very vague notion of too long.  If that
@@ -313,7 +316,9 @@
             if not self._ready.isSet():
                 self._cache.open()
 
-    def _wait(self):
+    def _wait(self, timeout=None):
+        if timeout is not None:
+            deadline = time.time() + timeout
         # Wait for a connection to be established.
         self._rpc_mgr.connect(sync=1)
         # When a synchronous connect() call returns, there is
@@ -326,6 +331,9 @@
                 self._ready.wait(30)
                 if self._ready.isSet():
                     break
+                if timeout and time.time() > deadline:
+                    log2(PROBLEM, "Timed out waiting for connection")
+                    break
                 log2(INFO, "Waiting for cache verification to finish")
         else:
             self._wait_sync()
@@ -434,8 +442,10 @@
         auth = stub.getAuthProtocol()
         log2(INFO, "Server authentication protocol %r" % auth)
         if auth:
-            if self.doAuth(auth, stub):
+            skey = self.doAuth(auth, stub)
+            if skey:
                 log2(INFO, "Client authentication successful")
+                conn.setSessionKey(skey)
             else:
                 log2(ERROR, "Authentication failed")
                 raise AuthError, "Authentication failed"




More information about the Zope-Checkins mailing list