Change forms of get_vhost functions.. get_vhost_otherinfo returns
[metaproxy-moved-to-github.git] / src / package.hpp
index b104c85..3fb632b 100644 (file)
@@ -1,47 +1,70 @@
-/* $Id: package.hpp,v 1.11 2006-01-04 11:19:04 adam Exp $
-   Copyright (c) 2005, Index Data.
+/* $Id: package.hpp,v 1.22 2006-08-30 10:48:52 adam Exp $
+   Copyright (c) 2005-2006, Index Data.
 
-%LICENSE%
+   See the LICENSE file for details
  */
 
 #ifndef YP2_PACKAGE_HPP
 #define YP2_PACKAGE_HPP
 
-#include <iostream>
+#include <iosfwd>
 #include <stdexcept>
-#include <yaz++/gdu.h>
+#include <yazpp/gdu.h>
 
 #include "router.hpp"
 #include "filter.hpp"
 #include "session.hpp"
 
-namespace yp2 {
+namespace metaproxy_1
+{
+    class Origin;
+    class Package;
+}
+
+
+namespace std 
+{
+    std::ostream& operator<<(std::ostream& os, metaproxy_1::Origin& o);
+    std::ostream& operator<<(std::ostream& os, metaproxy_1::Package& p);
+}
+
+namespace metaproxy_1 {
     
     class Origin {
+        friend std::ostream& 
+        std::operator<<(std::ostream& os,  metaproxy_1::Origin& o);
+
         enum origin_t {
             API,
             UNIX,
             TCPIP
         } type;
         std::string address; // UNIX+TCPIP
-        int port;            // TCPIP only
+        unsigned long origin_id;
     public:
-        Origin() : type(API) {};
+        Origin();
+        void set_tcpip_address(std::string addr, unsigned long id);
     };
-    
+
     class Package {
     public:
-        Package() ;
+        Package();
+
+        ~Package();
         
-        Package(yp2::Session &session, yp2::Origin &origin);
+        Package(metaproxy_1::Session &session, 
+                const metaproxy_1::Origin &origin);
 
         Package & copy_filter(const Package &p);
 
         /// send Package to it's next Filter defined in Router
         void move();
+
+        /// send Package to other route
+        void move(std::string route);
         
         /// access session - left val in assignment
-        yp2::Session & session();
+        metaproxy_1::Session & session();
         
         /// get function - right val in assignment
         int data() const;
@@ -73,9 +96,9 @@ namespace yp2 {
     private:
         Session m_session;
         Origin m_origin;
-        
-        const filter::Base *m_filter;
-        const Router *m_router;
+
+        RoutePos *m_route_pos;
+
         int m_data;
         
         yazpp_1::GDU m_request_gdu;
@@ -83,6 +106,8 @@ namespace yp2 {
     };
 }
 
+
+
 #endif
 /*
  * Local variables: