source: branches/monitor-improvement/globals.h@ 1265

Last change on this file since 1265 was 1265, checked in by alno, 11 years ago

WebIf:

  • Merging revisions 1261-1263 of trunk
File size: 25.1 KB
Line 
1#include <stdlib.h>
2#include <stdio.h>
3#include <assert.h>
4#include <fcntl.h>
5#include <sys/ioctl.h>
6#include <sys/poll.h>
7#include <ctype.h>
8#include <sys/types.h>
9#include <sys/stat.h>
10#include <sys/shm.h>
11#include <sys/wait.h>
12#include <unistd.h>
13#include <sys/mman.h>
14#include <stdarg.h>
15#include <time.h>
16#include <sys/timeb.h>
17#include <limits.h>
18
19#include <sys/socket.h>
20#include <netinet/in.h>
21#include <arpa/inet.h>
22#include <netdb.h>
23#include <string.h>
24#include <signal.h>
25#include <errno.h>
26
27#include <pthread.h>
28
29#ifndef CS_GLOBALS
30#define CS_GLOBALS
31#define CS_VERSION "0.99.4svn"
32
33#if defined(__GNUC__)
34# define GCC_PACK __attribute__((packed))
35#else
36# define GCC_PACK
37#endif
38
39#include "oscam-config.h"
40#ifndef USE_CMAKE
41# include "oscam-ostype.h"
42#endif
43#include "oscam-types.h"
44#include "cscrypt/cscrypt.h"
45
46#ifdef HAVE_PCSC
47#include <PCSC/pcsclite.h>
48#ifdef OS_MACOSX
49#include <PCSC/wintypes.h>
50#else
51#include <PCSC/reader.h>
52#endif
53#endif
54
55#ifndef CS_CONFDIR
56#define CS_CONFDIR "/usr/local/etc"
57#endif
58#ifndef CS_MMAPFILE
59#define CS_MMAPFILE "/tmp/oscam.mem"
60#endif
61#ifndef CS_LOGFILE
62#define CS_LOGFILE "/var/log/oscam.log"
63#endif
64#define CS_QLEN 128 // size of request queue
65#define CS_MAXQLEN 128 // size of request queue for cardreader
66#define CS_MAXCAIDTAB 32 // max. caid-defs/user
67#define CS_MAXTUNTAB 16 // max. betatunnel mappings
68#define CS_MAXPROV 32
69#define CS_MAXPORTS 32 // max server ports
70#define CS_MAXFILTERS 16
71
72#define CS_MAXCARDS 4096
73#define CS_MAXIGNORE 1024
74#define CS_MAXLOCALS 16
75#define CS_ECMSTORESIZE 16 // use MD5()
76#define CS_EMMSTORESIZE 270
77#define CS_CLIENT_TIMEOUT 5000
78#define CS_CLIENT_MAXIDLE 120
79#define CS_BIND_TIMEOUT 120
80#define CS_DELAY 0
81#define CS_RESOLVE_DELAY 30
82#define CS_MAXLOGHIST 30
83#define CS_LOGHISTSIZE 160 // 32+128: username + logline
84
85#ifdef OLD_DEFS
86#ifdef CS_EMBEDDED
87#define CS_MAXPENDING 32
88#define CS_ECMCACHESIZE 32
89#define CS_EMMCACHESIZE 64
90#define CS_MAXPID 32
91#define CS_MAXREADER 8
92#else
93#define CS_MAXPENDING 128
94#define CS_ECMCACHESIZE 128
95#define CS_EMMCACHESIZE 256
96#define CS_MAXPID 128
97#define CS_MAXREADER 64
98#endif
99#endif
100
101#ifdef CS_EMBEDDED
102#define CS_MAXPID 32
103#define CS_MAXREADER (CS_MAXPID>>1)
104#define CS_MAXPENDING CS_MAXPID
105#define CS_ECMCACHESIZE CS_MAXPID
106#define CS_EMMCACHESIZE (CS_MAXPID<<1)
107#else
108#define CS_MAXPID 512
109#define CS_MAXREADER (CS_MAXPID>>2)
110#define CS_MAXPENDING (CS_MAXPID<<1)
111#define CS_ECMCACHESIZE CS_MAXPID
112#define CS_EMMCACHESIZE (CS_MAXPID<<1)
113#define CS_RDR_INIT_HIST
114#endif
115
116#define D_DUMP 1 // Debug Dumps
117#define D_MASTER 2 // Debug Master Process
118#define D_READER 4 // Debug Reader/Proxy Process
119#define D_CLIENT 8 // Debug Client Process
120#define D_DEVICE 16 // Debug Reader I/O
121#define D_WATCHDOG 32 // Debug Watchdog
122#define D_ALL_DUMP 63
123
124#define R_MOUSE 0x1 // Reader smartcard mouse
125#define R_INTERNAL 0x2 // Reader smartcard intern
126#define R_DB2COM1 0x3 // Reader Dbox2 @ com1
127#define R_DB2COM2 0x4 // Reader Dbox2 @ com1
128#define R_SMART 0x5 // Smartreader+
129#ifdef HAVE_PCSC
130 #define R_PCSC 0x6 // PCSC
131#endif
132#define R_CAMD35 0x10 // Reader cascading camd 3.5x
133#define R_CAMD33 0x11 // Reader cascading camd 3.3x
134#define R_NEWCAMD 0x12 // Reader cascading newcamd
135#define R_RADEGAST 0x13 // Reader cascading radegast
136#define R_CS378X 0x14 // Reader cascading camd 3.5x TCP
137#define R_GBOX 0x20 // Reader cascading gbox
138#define R_CCCAM 0x25 // Reader cascading cccam
139#define R_SERIAL 0x80 // Reader serial
140#define R_IS_NETWORK 0x70
141#define R_IS_CASCADING 0xF0
142
143
144#define CS_MAX_MOD 12
145#define MOD_CONN_TCP 1
146#define MOD_CONN_UDP 2
147#define MOD_CONN_NET 3
148#define MOD_CONN_SERIAL 4
149
150#ifdef CS_CORE
151char *PIP_ID_TXT[] = { "ECM", "EMM", "LOG", "CIN", "HUP", NULL };
152char *RDR_CD_TXT[] = { "cd", "dsr", "cts", "ring", "none",
153#ifdef USE_GPIO
154 "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7", //felix: changed so that gpio can be used
155#endif
156 NULL };
157#else
158extern char *PIP_ID_TXT[];
159extern char *RDR_CD_TXT[];
160#endif
161
162#define PIP_ID_ECM 0
163#define PIP_ID_EMM 1
164#define PIP_ID_LOG 2
165#define PIP_ID_CIN 3 // CARD_INFO
166#define PIP_ID_HUP 4
167#define PIP_ID_MAX PIP_ID_HUP
168#define PIP_ID_DCW 5
169
170#define PIP_ID_ERR (-1)
171#define PIP_ID_DIR (-2)
172#define PIP_ID_NUL (-3)
173
174#define cdiff *c_start
175
176#define NCD_AUTO 0
177#define NCD_524 1
178#define NCD_525 2
179
180#define CS_ANTICASC
181
182// moved from reader-common.h
183#define CARD_INSERTED 1
184#define CARD_NEED_INIT 2
185#define CARD_FAILURE 4
186
187enum {E1_GLOBAL=0, E1_USER, E1_READER, E1_SERVER, E1_LSERVER};
188enum {E2_GLOBAL=0, E2_GROUP, E2_CAID, E2_IDENT, E2_CLASS, E2_CHID, E2_QUEUE,
189 E2_EA_LEN, E2_F0_LEN, E2_OFFLINE, E2_SID};
190
191//typedef unsigned char uchar;
192//typedef unsigned long ulong;
193
194typedef unsigned char uint8;
195typedef unsigned short uint16;
196typedef unsigned int uint32;
197typedef unsigned long long uint64;
198
199// constants
200#define CTA_RES_LEN 512
201
202typedef struct s_classtab
203{
204 uchar an;
205 uchar bn;
206 uchar aclass[31];
207 uchar bclass[31];
208} GCC_PACK CLASSTAB;
209
210typedef struct s_caidtab
211{
212 ushort caid[CS_MAXCAIDTAB];
213 ushort mask[CS_MAXCAIDTAB];
214 ushort cmap[CS_MAXCAIDTAB];
215} GCC_PACK CAIDTAB;
216
217typedef struct s_tuntab
218{
219 ushort bt_caidfrom[CS_MAXTUNTAB];
220 ushort bt_caidto[CS_MAXTUNTAB];
221 ushort bt_srvid[CS_MAXTUNTAB];
222} GCC_PACK TUNTAB;
223
224typedef struct s_sidtab
225{
226 char label[33];
227 ushort num_caid;
228 ushort num_provid;
229 ushort num_srvid;
230 ushort *caid;
231 ulong *provid;
232 ushort *srvid;
233 struct s_sidtab *next;
234} GCC_PACK SIDTAB;
235
236
237typedef struct s_filter
238{
239 ushort caid;
240 uchar nprids;
241 ulong prids[CS_MAXPROV];
242} GCC_PACK FILTER;
243
244typedef struct s_ftab
245{
246 int nfilts;
247 FILTER filts[CS_MAXFILTERS];
248} GCC_PACK FTAB;
249
250typedef struct s_port
251{
252 int fd;
253 int s_port;
254 FTAB ftab;
255} GCC_PACK PORT;
256
257typedef struct s_ptab
258{
259 int nports;
260 PORT ports[CS_MAXPORTS];
261} GCC_PACK PTAB;
262
263struct s_ecm
264{
265 uchar ecmd5[CS_ECMSTORESIZE];
266 uchar cw[16];
267 ushort caid;
268 ulong prid;
269 ulong grp;
270// int level;
271};
272
273struct s_emm
274{
275 uchar emm[CS_EMMSTORESIZE];
276 uchar type;
277 int count;
278};
279
280struct s_module
281{
282 //int fd;
283 int multi;
284 int type;
285 int watchdog;
286 char desc[16];
287 char *logtxt;
288 //int s_port;
289 in_addr_t s_ip;
290 void (*s_handler)();
291 int (*recv)();
292 void (*send_dcw)();
293 void (*cleanup)();
294 int c_multi;
295 int (*c_recv_chk)();
296 int (*c_init)();
297 int (*c_send_ecm)();
298 int (*c_init_log)();
299 int (*c_recv_log)();
300 int c_port;
301 PTAB *ptab;
302};
303
304struct s_irdeto_quess
305{
306 int b47;
307 ushort caid;
308 ushort sid;
309 struct s_irdeto_quess *next;
310};
311
312struct s_client
313{
314 pid_t pid;
315 in_addr_t ip;
316 in_port_t port;
317 time_t login;
318 time_t last;
319 time_t lastswitch;
320 time_t lastemm;
321 time_t lastecm;
322 time_t expirationdate;
323 ulong grp;
324 int crypted;
325 int dup;
326 int au;
327 char autoau;
328 int monlvl;
329 int dbglvl;
330 CAIDTAB ctab;
331 TUNTAB ttab;
332 ulong sidtabok; // positiv services
333 ulong sidtabno; // negative services
334 int typ;
335 int ctyp;
336 int stat;
337 int ufd;
338 int last_srvid;
339 int last_caid;
340 int tosleep;
341 char usr[32];
342 int udp_fd;
343 int fd_m2c;
344 struct sockaddr_in udp_sa;
345 int log;
346 int logcounter;
347 int cwfound;
348 int cwcache;
349 int cwnot;
350 uchar ucrc[4]; // needed by monitor and used by camd35
351 ulong pcrc; // pwd crc
352 AES_KEY aeskey; // needed by monitor and used by camd33, camd35
353 ushort ncd_msgid;
354 uchar ncd_skey[16];
355 int port_idx; // index in server ptab
356 int ncd_server; // newcamd server?
357#ifdef CS_ANTICASC
358 ushort ac_idx;
359 ushort ac_limit;
360 uchar ac_penalty;
361#endif
362 FTAB fchid;
363 FTAB ftab; // user [caid] and ident filter
364 CLASSTAB cltab;
365};
366
367struct s_reader
368{
369 int cs_idx;
370 int fd;
371 ulong grp;
372 int fallback;
373 int typ;
374 int card_system;
375 char label[32];
376 char device[128];
377 int handle; //device handle
378 char pcsc_name[128];
379 int pcsc_has_card;
380 int detect;
381 int mhz; //actual clock rate of reader in 10khz steps
382 int cardmhz; //standard clock speed your card should have in 10khz steps; normally 357 but for Irdeto cards 600
383 int r_port;
384 char r_usr[64];
385 char r_pwd[64];
386 int r_crypted;
387 int l_port;
388 int log_port;
389 CAIDTAB ctab;
390 ulong boxid;
391 uchar nagra_boxkey[16]; //n3 boxkey 8byte or tiger idea key 16byte
392 int has_rsa;
393 uchar aes_key[16];
394 uchar rsa_mod[120]; //rsa modulus for nagra cards.
395 ulong sidtabok; // positiv services
396 ulong sidtabno; // negative services
397 uchar hexserial[8];
398 int nprov;
399 uchar prid[CS_MAXPROV][8];
400 uchar availkeys[CS_MAXPROV][16]; // viaccess; misused in seca, if availkeys[PROV][0]=0 then expired, 1 then valid.
401 uchar sa[CS_MAXPROV][4]; // viaccess & seca
402 ushort acs; // irdeto
403 ushort caid[16];
404 uchar b_nano[256];
405 uchar emmfile[128];
406 char pincode[5];
407 int logemm;
408 int cachemm;
409 int rewritemm;
410 int online;
411 int card_status; //highlevel status
412 unsigned short status; //lowlevel status: states whether card inserted and/or change of status FIXME look at integration with pcsc_has_card/detect/card_status
413 unsigned long baudrate; //we are storing the (for overclocking uncorrected) baudrate to prevent unnecessary conversions from/to termios structure
414 struct s_module ph;
415 uchar ncd_key[16];
416 uchar ncd_skey[16];
417 int ncd_disable_server_filt;
418 ushort ncd_msgid;
419 int ncd_proto;
420 char cc_version[7]; // cccam version
421 char cc_build[5]; // cccam build number
422 int cc_maxhop; // cccam max distance
423 void *cc; // ptr to cccam internal data struct
424 uchar tcp_connected;
425 int tcp_ito; // inactivity timeout
426 int tcp_rto; // reconnect timeout
427 time_t last_g; // get (if last_s-last_g>tcp_rto - reconnect )
428 time_t last_s; // send
429 uchar show_cls; // number of classes subscription showed on kill -31
430 int maxqlen; // max queue length
431 int qlen; // current queue length
432 FTAB fchid;
433 FTAB ftab;
434 CLASSTAB cltab;
435 uchar gbox_pwd[4];
436 uchar gbox_timecode[7];
437 int gbox_online;
438 uchar gbox_vers;
439 uchar gbox_prem;
440 int gbox_fd;
441 struct timeb gbox_lasthello; // incoming time stamp
442#ifdef CS_RDR_INIT_HIST
443 uchar init_history[4096];
444 int init_history_pos;
445#endif
446 int msg_idx;
447#ifdef HAVE_PCSC
448 SCARDCONTEXT hContext;
449 SCARDHANDLE hCard;
450 DWORD dwActiveProtocol;
451#endif
452
453};
454
455#ifdef CS_ANTICASC
456
457struct s_acasc_shm {
458 ushort ac_count : 15;
459 ushort ac_deny : 1;
460};
461
462struct s_acasc {
463 ushort stat[10];
464 uchar idx; // current active index in stat[]
465};
466
467struct s_cpmap
468{
469 ushort caid;
470 ulong provid;
471 ushort sid;
472 ushort chid;
473 ushort dwtime;
474 struct s_cpmap *next;
475};
476#endif
477
478struct s_auth
479{
480 char usr[33];
481 char pwd[33];
482 int uniq;
483 int au;
484 int autoau;
485 int monlvl;
486 ulong grp;
487 int tosleep;
488 CAIDTAB ctab;
489 ulong sidtabok; // positiv services
490 ulong sidtabno; // negative services
491 FTAB fchid;
492 FTAB ftab; // user [caid] and ident filter
493 CLASSTAB cltab;
494 TUNTAB ttab;
495#ifdef CS_ANTICASC
496 int ac_idx;
497 int ac_users; // 0 - unlimited
498 uchar ac_penalty; // 0 - log, >0 - fake dw
499#endif
500 in_addr_t dynip;
501 uchar dyndns[64];
502 time_t expirationdate;
503 struct s_auth *next;
504};
505
506struct s_srvid
507{
508 int srvid;
509 int ncaid;
510 int caid[10];
511 char prov[33];
512 char name[33];
513 char type[33];
514 char desc[33];
515 struct s_srvid *next;
516};
517
518struct s_ip
519{
520 in_addr_t ip[2];
521 struct s_ip *next;
522};
523
524struct s_config
525{
526 int nice;
527 ulong netprio;
528 ulong ctimeout;
529 ulong ftimeout;
530 ulong cmaxidle;
531 int ulparent;
532 ulong delay;
533 int bindwait;
534 int resolvedelay;
535 int tosleep;
536 in_addr_t srvip;
537 char pidfile[128];
538 char usrfile[128];
539 char cwlogdir[128];
540 struct s_auth *account;
541 struct s_srvid *srvid;
542 struct s_sidtab *sidtab;
543 int mon_port;
544 in_addr_t mon_srvip;
545 struct s_ip *mon_allowed;
546 int mon_aulow;
547 int mon_hideclient_to;
548 int mon_level;
549 int http_port;
550 char http_user[65];
551 char http_pwd[65];
552 char http_css[128];
553 char http_tpl[128];
554 int http_refresh;
555 int http_hide_idle_clients;
556 int c33_port;
557 in_addr_t c33_srvip;
558 uchar c33_key[16];
559 int c33_crypted;
560 int c33_passive;
561 struct s_ip *c33_plain;
562 int c35_port;
563 in_addr_t c35_srvip;
564 PTAB c35_tcp_ptab;
565 in_addr_t c35_tcp_srvip;
566 PTAB ncd_ptab;
567 in_addr_t ncd_srvip;
568 uchar ncd_key[16];
569 PTAB cc_ptab;
570 int rad_port;
571 in_addr_t rad_srvip;
572 struct s_ip *rad_allowed;
573 char rad_usr[32];
574 char ser_device[512];
575 ulong srtimeout; // SerialReaderTimeount in millisec
576 int max_log_size;
577 int show_ecm_dw;
578 int waitforcards;
579 int preferlocalcards;
580#ifdef CS_WITH_GBOX
581 uchar gbox_pwd[8];
582 uchar ignorefile[512];
583 uchar cardfile[512];
584 uchar gbxShareOnl[512];
585 int maxdist;
586 int num_locals;
587 unsigned long locals[CS_MAXLOCALS];
588#endif
589 //struct s_irdeto_quess *itab[0xff];
590#ifdef HAVE_DVBAPI
591 int dvbapi_enabled;
592 int dvbapi_au;
593 char dvbapi_usr[33];
594 char dvbapi_boxtype[20];
595 char dvbapi_priority[64];
596 char dvbapi_ignore[64];
597#endif
598#ifdef CS_ANTICASC
599 char ac_enabled;
600 int ac_users; // num of users for account (0 - default)
601 int ac_stime; // time to collect AC statistics (3 min - default)
602 int ac_samples; // qty of samples
603 int ac_penalty; // 0 - write to log
604 int ac_fakedelay; // 100-1000 ms
605 int ac_denysamples;
606 char ac_logfile[128];
607 struct s_cpmap *cpmap;
608#endif
609// struct s_reader reader[];
610};
611
612typedef struct ecm_request_t
613{
614
615 uchar ecm[256];
616 uchar cw[16];
617 uchar ecmd5[CS_ECMSTORESIZE];
618// uchar l;
619 short l;
620 ushort caid;
621 ushort ocaid;
622 ushort srvid;
623 ushort chid;
624 ushort pid;
625 ushort idx;
626 ulong prid;
627 int reader[CS_MAXREADER];
628 int cidx; // client index
629 int cpti; // client pending table index
630 int stage; // processing stage in server module
631 int level; // send-level in client module
632 int rc;
633 uchar rcEx;
634 struct timeb tps; // incoming time stamp
635 uchar locals_done;
636 ushort gbxCWFrom;
637 ushort gbxFrom;
638 ushort gbxTo;
639
640 uchar gbxForward[16];
641 int gbxRidx;
642} GCC_PACK ECM_REQUEST;
643
644typedef struct emm_packet_t
645{
646 uchar emm[258];
647 uchar l;
648 uchar caid[2];
649 uchar provid[4];
650 uchar hexserial[8];
651 uchar type;
652 int cidx;
653} GCC_PACK EMM_PACKET;
654
655// oscam-simples
656extern char *remote_txt(void);
657extern char *trim(char *);
658extern char *strtolower(char *);
659extern int gethexval(char);
660extern int cs_atob(uchar *, char *, int);
661extern ulong cs_atoi(char *, int, int);
662extern int byte_atob(char *);
663extern long word_atob(char *);
664extern int key_atob(char *, uchar *);
665extern int key_atob14(char *, uchar *);
666extern int key_atob_l(char *, uchar *, int);
667extern char *key_btoa(char *, uchar *);
668extern char *cs_hexdump(int, uchar *, int);
669extern in_addr_t cs_inet_order(in_addr_t);
670extern char *cs_inet_ntoa(in_addr_t);
671extern in_addr_t cs_inet_addr(char *txt);
672extern ulong b2i(int, uchar *);
673extern ullong b2ll(int, uchar *);
674extern uchar *i2b(int, ulong);
675extern ulong a2i(char *, int);
676extern int boundary(int, int);
677extern void cs_ftime(struct timeb *);
678extern void cs_sleepms(int);
679extern int bytes_available(int);
680extern void cs_setpriority(int);
681extern struct s_auth *find_user(char *);
682extern int x2i(int i);
683extern void urldecode(char *s);
684extern char to_hex(char code);
685extern char *urlencode(char *str);
686extern void long2bitchar(long value, char *result);
687extern char *char_to_hex(const unsigned char* p_array, unsigned int p_array_len, char hex2ascii[256][2]);
688extern void create_rand_str(char *dst, int size);
689extern int file_exists(const char * filename);
690extern void clear_sip(struct s_ip **sip);
691extern void clear_ptab(struct s_ptab *ptab);
692extern int safe_overwrite_with_bak(char *destfile, char *tmpfile, char *bakfile, int forceBakOverWrite);
693extern void fprintf_conf(FILE *f, int varnameWidth, const char *varname, const char *fmtstring, ...);
694extern void cs_strncpy(char * destination, const char * source, size_t num);
695
696// oscam variables
697extern int pfd, rfd, fd_c2m, fd_m2c, cs_idx, *c_start, cs_ptyp, cs_dblevel, cs_hw;
698extern int *logidx, *loghistidx, *log_fd;
699extern int is_server, *mcl;
700extern uchar mbuf[1024];
701extern ushort len4caid[256];
702extern pid_t master_pid;
703extern struct s_ecm *ecmcache;
704extern struct s_client *client;
705extern struct s_reader *reader;
706
707extern struct card_struct *Cards;
708extern struct idstore_struct *idstore;
709extern unsigned long *IgnoreList;
710
711extern struct s_config *cfg;
712extern char cs_confdir[], *loghist;
713extern EMM_PACKET epg;
714extern struct s_module ph[CS_MAX_MOD];
715extern ECM_REQUEST *ecmtask;
716extern char logfile[256];
717#ifdef CS_ANTICASC
718extern struct s_acasc_shm *acasc;
719extern FILE *fpa;
720extern int use_ac_log;
721#endif
722
723
724// oscam
725extern char *cs_platform(char *);
726extern int recv_from_udpipe(uchar *);
727extern char* username(int);
728extern int idx_from_pid(pid_t);
729extern int chk_bcaid(ECM_REQUEST *, CAIDTAB *);
730extern void cs_exit(int sig);
731extern int cs_fork(in_addr_t, in_port_t);
732extern void wait4master(void);
733extern int cs_auth_client(struct s_auth *, char*);
734extern void cs_disconnect_client(void);
735extern int check_ecmcache(ECM_REQUEST *, ulong);
736extern void store_logentry(char *);
737extern int write_to_pipe(int, int, uchar *, int);
738extern int read_from_pipe(int, uchar **, int);
739extern int write_ecm_request(int, ECM_REQUEST *);
740extern int write_ecm_answer(int, ECM_REQUEST *);
741extern void log_emm_request(int);
742extern ulong chk_provid(uchar *, ushort);
743extern void guess_cardsystem(ECM_REQUEST *);
744extern void guess_irdeto(ECM_REQUEST *);
745extern void get_cw(ECM_REQUEST *);
746extern void do_emm(EMM_PACKET *);
747extern ECM_REQUEST *get_ecmtask(void);
748extern void request_cw(ECM_REQUEST *, int, int);
749extern int send_dcw(ECM_REQUEST *);
750extern int process_input(uchar *, int, int);
751extern int chk_srvid(ECM_REQUEST *, int);
752extern int chk_sfilter(ECM_REQUEST *, PTAB*);
753extern int chk_ufilters(ECM_REQUEST *);
754extern int chk_rfilter(ECM_REQUEST *, struct s_reader *);
755extern int chk_rsfilter(ECM_REQUEST *, int);
756extern int chk_avail_reader(ECM_REQUEST *, struct s_reader *);
757extern int matching_reader(ECM_REQUEST *, struct s_reader *);
758extern void set_signal_handler(int , int , void (*)(int));
759extern void cs_log_config(void);
760extern void cs_reinit_clients(void);
761extern void cs_resolve(void);
762extern void chk_dcw(int fd);
763
764#ifdef CS_ANTICASC
765//extern void start_anticascader(void);
766extern void init_ac(void);
767extern void ac_init_stat();
768extern int ac_init_log(char*);
769extern void ac_do_stat(void);
770extern void ac_init_client(struct s_auth *);
771extern void ac_chk(ECM_REQUEST*, int);
772#endif
773
774// oscam-nano
775extern int chk_class(ECM_REQUEST *, CLASSTAB*, const char*, const char*);
776
777// oscam-config
778extern int init_config(void);
779extern int init_userdb(void);
780extern int init_readerdb(void);
781extern int init_sidtab(void);
782extern int init_srvid(void);
783extern int search_boxkey(ushort, char *);
784extern void init_len4caid(void);
785extern int init_irdeto_guess_tab(void);
786extern void chk_caidtab(char *caidasc, CAIDTAB *ctab);
787extern void chk_tuntab(char *tunasc, TUNTAB *ttab);
788extern void chk_services(char *labels, ulong *sidok, ulong *sidno);
789extern void chk_ftab(char *zFilterAsc, FTAB *ftab, const char *zType, const char *zName, const char *zFiltName);
790extern void chk_cltab(char *classasc, CLASSTAB *clstab);
791extern void chk_iprange(char *value, struct s_ip **base);
792extern void chk_port_tab(char *portasc, PTAB *ptab);
793#ifdef CS_ANTICASC
794extern void chk_t_ac(char *token, char *value);
795#endif
796extern void chk_t_camd33(char *token, char *value);
797extern void chk_t_camd35(char *token, char *value);
798extern void chk_t_camd35_tcp(char *token, char *value);
799extern void chk_t_newcamd(char *token, char *value);
800extern void chk_t_radegast(char *token, char *value);
801extern void chk_t_serial(char *token, char *value);
802extern void chk_t_gbox(char *token, char *value);
803extern void chk_t_cccam(char *token, char *value);
804extern void chk_t_global(char *token, char *value);
805extern void chk_t_monitor(char *token, char *value);
806extern void chk_t_dvbapi(char *token, char *value);
807extern void chk_account(char *token, char *value, struct s_auth *account);
808extern void chk_sidtab(char *token, char *value, struct s_sidtab *sidtab);
809extern int write_services();
810extern int write_userdb();
811extern int write_config();
812extern char *mk_t_caidtab(CAIDTAB *ctab);
813extern char *mk_t_tuntab(TUNTAB *ttab);
814extern char *mk_t_group(ulong *grp);
815extern char *mk_t_ftab(FTAB *ftab);
816
817// oscam-reader
818extern int ridx, logfd;
819extern int reader_cmd2api(uchar *, int);
820extern int reader_cmd2icc(uchar *, int);
821extern int card_write(uchar *, uchar *);
822extern void cs_ri_brk(int);
823extern void cs_ri_log(char *,...);
824extern void start_cardreader(void);
825extern void reader_card_info(void);
826extern int network_tcp_connection_open();
827extern void network_tcp_connection_close(int);
828
829// oscam-log
830extern int cs_init_log(char *);
831extern void cs_write_log(char *);
832extern void cs_log(char *,...);
833extern void cs_debug(char *,...);
834extern void cs_ddump(uchar *, int, char *, ...);
835extern void cs_close_log(void);
836extern int cs_init_statistics(char *);
837extern void cs_statistics(int);
838extern void cs_dump(uchar *, int, char *, ...);
839
840// oscam-aes
841extern void aes_set_key(char *);
842extern void aes_encrypt_idx(int, uchar *, int);
843extern void aes_decrypt(uchar *, int);
844#define aes_encrypt(b, n) aes_encrypt_idx(cs_idx, b, n)
845
846// reader-common
847extern int reader_device_init(char *);
848extern int reader_checkhealth(void);
849extern void reader_post_process(void);
850extern int reader_ecm(ECM_REQUEST *);
851extern int reader_emm(EMM_PACKET *);
852
853#ifdef HAVE_PCSC
854// reader-pcsc
855extern int pcsc_reader_do_api(struct s_reader *pcsc_reader, uchar *buf, uchar *cta_res, ushort *cta_lr,int l);
856extern int pcsc_activate_card(struct s_reader *pcsc_reader, uchar *atr, ushort *atr_size);
857extern int pcsc_check_card_inserted(struct s_reader *pcsc_reader);
858extern int pcsc_reader_init(struct s_reader *pcsc_reader, char *device);
859#endif
860
861// reader-irdeto
862extern int irdeto_card_init(uchar *);
863extern int irdeto_do_ecm(ECM_REQUEST *);
864extern int irdeto_do_emm(EMM_PACKET *);
865extern int irdeto_card_info(void);
866
867// reader-viaccess
868extern int viaccess_card_init(uchar *);
869extern int viaccess_do_ecm(ECM_REQUEST *);
870extern int viaccess_do_emm(EMM_PACKET *);
871extern int viaccess_card_info(void);
872
873// reader-videoguard
874extern int videoguard_card_init(uchar *, int);
875extern int videoguard_do_ecm(ECM_REQUEST *);
876extern int videoguard_do_emm(EMM_PACKET *);
877extern int videoguard_card_info(void);
878
879// reader-cryptoworks
880extern int cryptoworks_card_init(uchar *);
881extern int cryptoworks_do_ecm(ECM_REQUEST *);
882extern int cryptoworks_do_emm(EMM_PACKET *);
883extern int cryptoworks_card_info(void);
884extern int CheckSctLen(const uchar *, int);
885
886// reader-seca
887extern int seca_card_init(uchar *);
888extern int seca_do_ecm(ECM_REQUEST *);
889extern int seca_do_emm(EMM_PACKET *);
890extern int seca_card_info(void);
891
892// reader-nds
893extern int nds_card_init(uchar *, int);
894extern int nds_do_ecm(ECM_REQUEST *);
895extern int nds_do_emm(EMM_PACKET *);
896extern int nds_card_info(void);
897
898// reader nagra2/3
899extern int nagra2_card_init(uchar *);
900extern int nagra2_do_ecm(ECM_REQUEST *er);
901extern int nagra2_card_info(void);
902extern int nagra2_do_emm(EMM_PACKET *);
903extern void nagra2_post_process();
904
905// reader-conax
906extern int conax_card_init(uchar *);
907extern int conax_do_ecm(ECM_REQUEST *);
908extern int conax_do_emm(EMM_PACKET *);
909extern int conax_card_info(void);
910
911// reader-dre
912extern int dre_card_init(uchar *);
913extern int dre_do_ecm(ECM_REQUEST *);
914extern int dre_do_emm(EMM_PACKET *);
915extern int dre_card_info(void);
916
917// protocol modules
918extern int monitor_send_idx(int, char *);
919extern void module_monitor(struct s_module *);
920extern void module_camd35(struct s_module *);
921extern void module_camd35_tcp(struct s_module *);
922extern void module_camd33(struct s_module *);
923extern void module_newcamd(struct s_module *);
924extern void module_radegast(struct s_module *);
925extern void module_oscam_ser(struct s_module *);
926extern void module_gbox(struct s_module *);
927extern void module_cccam(struct s_module *);
928#ifdef HAVE_DVBAPI
929extern void module_dvbapi(struct s_module *);
930#endif
931extern struct timeval *chk_pending(struct timeb tp_ctimeout);
932
933// module-monitor
934extern char *monitor_get_proto(int idx);
935extern char *monitor_get_srvname(int srvid, int caid);
936extern int cs_idx2ridx(int idx);
937
938// oscam-http
939extern void http_srv();
940
941#endif // CS_GLOBALS
942
Note: See TracBrowser for help on using the repository browser.