ZooKeeperObserverManager.java 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. package org.apache.zookeeper.server.util;
  19. import java.util.HashSet;
  20. import java.util.Set;
  21. import org.apache.zookeeper.server.DataTree;
  22. import org.apache.zookeeper.server.ServerCnxn;
  23. import org.apache.zookeeper.server.ZooKeeperObserverNotifier;
  24. import org.apache.zookeeper.server.quorum.QuorumPeer;
  25. /**
  26. * Zookeeper specific implementation of ObserverManager. It implements a mapping
  27. * of observer classes to a set of observer instances.
  28. */
  29. public class ZooKeeperObserverManager extends ObserverManager {
  30. private ZooKeeperObserverManager(){}
  31. /**
  32. * Explicitly set this class as a concrete instance of ObserverManager.
  33. */
  34. public static void setAsConcrete(){
  35. setInstance(new ZooKeeperObserverManager());
  36. }
  37. protected Set<Object> getObserverList(Object ob){
  38. if(ob instanceof ConnectionObserver || ob instanceof ServerCnxn)
  39. return connectionObservers;
  40. else if(ob instanceof ServerObserver || ob instanceof ZooKeeperObserverNotifier)
  41. return serverObservers;
  42. else if(ob instanceof QuorumPeerObserver || ob instanceof QuorumPeer)
  43. return quorumPeerObservers;
  44. else if(ob instanceof DataTreeObserver || ob instanceof DataTree)
  45. return dataTreeObservers;
  46. assert false;
  47. return null;
  48. }
  49. private Set<Object> serverObservers=new HashSet<Object>();
  50. private Set<Object> connectionObservers=new HashSet<Object>();
  51. private Set<Object> dataTreeObservers=new HashSet<Object>();
  52. private Set<Object> quorumPeerObservers=new HashSet<Object>();
  53. }