Applied Ere's global client-authentication patch.
[yazproxy-moved-to-github.git] / src / proxyp.h
1 /* $Id: proxyp.h,v 1.18 2006-06-28 23:38:23 adam Exp $
2    Copyright (c) 1998-2006, Index Data.
3
4 This file is part of the yazproxy.
5
6 YAZ proxy is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 2, or (at your option) any later
9 version.
10
11 YAZ proxy is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with YAZ proxy; see the file LICENSE.  If not, write to the
18 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
19 02111-1307, USA.
20  */
21
22 #if HAVE_XSLT
23 #include <libxml/parser.h>
24 #include <libxml/tree.h>
25 #include <libxml/xinclude.h>
26 #include <libxslt/xsltutils.h>
27 #include <libxslt/transform.h>
28 #endif
29
30 #if HAVE_USEMARCON
31 #include <objectlist.h>
32 #endif
33
34 #include <yazpp/record-cache.h>
35 #include <yazproxy/proxy.h>
36 #include <yazproxy/module.h>
37
38 struct Yaz_RecordCache_Entry;
39
40 class Yaz_usemarcon {
41  public:
42     Yaz_usemarcon();
43     ~Yaz_usemarcon();
44
45     int convert(const char *stage1, const char *stage2,
46                 const char *input, int input_len,
47                 char **output, int *output_len);
48 #if HAVE_USEMARCON
49     CDetails *m_stage1;
50     CDetails *m_stage2;
51 #else
52     int dummy;
53 #endif
54 };
55
56 class Yaz_CharsetConverter {
57 public:
58     Yaz_CharsetConverter();
59     ~Yaz_CharsetConverter();
60     void set_target_query_charset(const char *s);
61     void set_client_query_charset(const char *org);
62     const char *get_client_query_charset(void);
63     const char *get_target_query_charset(void);
64     void convert_type_1(Z_RPNQuery *q, ODR o);
65     void set_client_charset_selected(int sel);
66     int get_client_charset_selected();
67 private:
68     void convert_type_1(char *buf_in, int len_in,
69                         char **buf_out, int *len_out,
70                         ODR o);
71     void convert_type_1(Z_Term *q, ODR o);
72     void convert_type_1(Z_RPNStructure *q, ODR o);
73     void convert_type_1(Z_Operand *q, ODR o);
74     char *m_target_query_charset;
75     char *m_client_query_charset;
76     int m_client_charset_selected;
77     yaz_iconv_t m_ct;
78     WRBUF m_wrbuf;
79 };
80
81 class Yaz_ProxyConfig {
82 public:
83     Yaz_ProxyConfig();
84     ~Yaz_ProxyConfig();
85     int read_xml(const char *fname);
86
87     int get_target_no(int no,
88                       const char **name,
89                       const char **url,
90                       int *limit_bw,
91                       int *limit_pdu,
92                       int *limit_req,
93                       int *limit_search,
94                       int *target_idletime,
95                       int *client_idletime,
96                       int *max_clients,
97                       int *keepalive_limit_bw,
98                       int *keepalive_limit_pdu,
99                       int *pre_init,
100                       const char **cql2rpn,
101                       const char **authentication,
102                       const char **negotiation_charset,
103                       const char **negotiation_lang,
104                       const char **query_charset,
105                       const char **default_client_query_charset);
106
107     void get_generic_info(int *log_mask, int *max_clients,
108                           int *max_connect, int *limit_connect,
109                           int *period_connect,
110                           int *msg_threads);
111
112     int get_file_access_info(const char *path);
113
114     void get_target_info(const char *name, const char **url,
115                          int *limit_bw, int *limit_pdu, int *limit_req,
116                          int *limit_search,
117                          int *target_idletime, int *client_idletime,
118                          int *max_clients,
119                          int *keepalive_limit_bw, int *keepalive_limit_pdu,
120                          int *pre_init,
121                          const char **cql2rpn,
122                          const char **negotiation_charset,
123                          const char **negotiation_lang,
124                          const char **query_charset,
125                          const char **default_client_query_charset);
126
127     const char *check_mime_type(const char *path);
128     int check_query(ODR odr, const char *name, Z_Query *query, char **addinfo);
129     int check_syntax(ODR odr, const char *name,
130                      Odr_oid *syntax, Z_RecordComposition *comp,
131                      char **addinfo, char **stylesheet, char **schema,
132                      char **backend_type, char **backend_charset,
133                      char **usemarcon_ini_stage1, char **usemarcon_ini_stage2);
134
135     void target_authentication(const char *name,
136                                ODR odr,
137                                Z_InitRequest *req);
138
139     int client_authentication(const char *name,
140                               const char *user, const char *group,
141                               const char *password,
142                               const char *peer_IP);
143     int global_client_authentication(const char *user, const char *group,
144                                      const char *password,
145                                      const char *peer_IP);
146     char *get_explain_doc(ODR odr, const char *name, const char *db,
147                           int *len);
148     const char *get_explain_name(const char *db, const char **backend_db);
149  private:
150     void operator=(const Yaz_ProxyConfig &conf);
151     class Yaz_ProxyConfigP *m_cp;
152 };
153
154 class Yaz_ProxyClient : public yazpp_1::Z_Assoc {
155     friend class Yaz_Proxy;
156     Yaz_ProxyClient(yazpp_1::IPDU_Observable *the_PDU_Observable,
157                     Yaz_Proxy *parent);
158     ~Yaz_ProxyClient();
159     void recv_GDU(Z_GDU *apdu, int len);
160     void recv_Z_PDU(Z_APDU *apdu, int len);
161     void recv_HTTP_response(Z_HTTP_Response *apdu, int len);
162     IPDU_Observer* sessionNotify
163         (yazpp_1::IPDU_Observable *the_PDU_Observable, int fd);
164     void shutdown();
165     Yaz_Proxy *m_server;
166     void failNotify();
167     void timeoutNotify();
168     void connectNotify();
169     int send_to_target(Z_APDU *apdu);
170     const char *get_session_str();
171     char *m_cookie;
172     Yaz_ProxyClient *m_next;
173     Yaz_ProxyClient **m_prev;
174     int m_init_flag;
175     yazpp_1::Yaz_Z_Query *m_last_query;
176     yazpp_1::Yaz_Z_Databases m_last_databases;
177     char *m_last_resultSetId;
178     int m_last_ok;
179     int m_last_resultCount;
180     int m_sr_transform;
181     int m_seqno;
182     int m_waiting;
183     int m_resultSetStartPoint;
184     int m_bytes_sent;
185     int m_bytes_recv;
186     int m_pdu_recv;
187     ODR m_init_odr;
188     Z_APDU *m_initResponse;
189     Z_Options *m_initResponse_options;
190     Z_ProtocolVersion *m_initResponse_version;
191     int m_initResponse_preferredMessageSize;
192     int m_initResponse_maximumRecordSize;
193     yazpp_1::RecordCache m_cache;
194     void pre_init_client();
195     int m_target_idletime;
196     Yaz_Proxy *m_root;
197     char *m_idAuthentication_ber_buf;
198     int m_idAuthentication_ber_size;
199     ODR m_idAuthentication_odr;
200     void set_idAuthentication(Z_APDU *apdu);
201     bool compare_idAuthentication(Z_APDU *apdu);
202     bool compare_charset(Z_APDU *apdu);
203 };
204
205 /*
206  * Local variables:
207  * c-basic-offset: 4
208  * indent-tabs-mode: nil
209  * End:
210  * vim: shiftwidth=4 tabstop=8 expandtab
211  */
212