source: message.c @ 50622a5

barnowl_perlaimdebianrelease-1.10release-1.4release-1.5release-1.6release-1.7release-1.8release-1.9
Last change on this file since 50622a5 was e849734, checked in by Nelson Elhage <nelhage@mit.edu>, 18 years ago
Intern hostnames and message attribute keys
  • Property mode set to 100644
File size: 22.8 KB
Line 
1#include <stdlib.h>
2#include <unistd.h>
3#include <string.h>
4#include <sys/socket.h>
5#include <netdb.h>
6#include <sys/types.h>
7#include <sys/socket.h>
8#include <netinet/in.h>
9#include <arpa/inet.h>
10#include <time.h>
11#include "owl.h"
12
13static const char fileIdent[] = "$Id$";
14
15void owl_message_init(owl_message *m)
16{
17  m->id=owl_global_get_nextmsgid(&g);
18  owl_message_set_direction_none(m);
19  m->delete=0;
20  m->hostname=owl_strdup("");
21  m->zwriteline=strdup("");
22  m->invalid_format=1;
23
24  owl_list_create(&(m->attributes));
25 
26  /* save the time */
27  m->time=time(NULL);
28  m->timestr=owl_strdup(ctime(&(m->time)));
29  m->timestr[strlen(m->timestr)-1]='\0';
30
31  /* initialize the fmtext */
32  owl_fmtext_init_null(&(m->fmtext));
33}
34
35/* add the named attribute to the message.  If an attribute with the
36 * name already exists, replace the old value with the new value
37 */
38void owl_message_set_attribute(owl_message *m, char *attrname, char *attrvalue)
39{
40  int i, j;
41  owl_pair *p = NULL, *pair = NULL;
42
43  /* look for an existing pair with this key, */
44  j=owl_list_get_size(&(m->attributes));
45  for (i=0; i<j; i++) {
46    p=owl_list_get_element(&(m->attributes), i);
47    if (!strcmp(owl_pair_get_key(p), attrname)) {
48      owl_free(owl_pair_get_value(p));
49      pair = p;
50      break;
51    }
52  }
53
54  if(pair ==  NULL) {
55    pair = owl_malloc(sizeof(owl_pair));
56    owl_pair_create(pair, owl_global_intern(&g, attrname), NULL);
57    owl_list_append_element(&(m->attributes), pair);
58  }
59  owl_pair_set_value(pair, owl_strdup(attrvalue));
60}
61
62/* return the value associated with the named attribute, or NULL if
63 * the attribute does not exist
64 */
65char *owl_message_get_attribute_value(owl_message *m, char *attrname)
66{
67  int i, j;
68  owl_pair *p;
69
70  j=owl_list_get_size(&(m->attributes));
71  for (i=0; i<j; i++) {
72    p=owl_list_get_element(&(m->attributes), i);
73    if (!strcmp(owl_pair_get_key(p), attrname)) {
74      return(owl_pair_get_value(p));
75    }
76  }
77
78  /*
79  owl_function_debugmsg("No attribute %s found for message %i",
80                        attrname,
81                        owl_message_get_id(m));
82  */
83  return(NULL);
84}
85
86/* We cheat and indent it for now, since we really want this for
87 * the 'info' function.  Later there should just be a generic
88 * function to indent fmtext.
89 */
90void owl_message_attributes_tofmtext(owl_message *m, owl_fmtext *fm) {
91  int i, j;
92  owl_pair *p;
93  char *buff;
94
95  owl_fmtext_init_null(fm);
96
97  j=owl_list_get_size(&(m->attributes));
98  for (i=0; i<j; i++) {
99    p=owl_list_get_element(&(m->attributes), i);
100    buff=owl_sprintf("  %-15.15s: %-35.35s\n", owl_pair_get_key(p), owl_pair_get_value(p));
101    owl_fmtext_append_normal(fm, buff);
102    owl_free(buff);
103  }
104}
105
106void owl_message_invalidate_format(owl_message *m)
107{
108  m->invalid_format=1;
109}
110
111owl_fmtext *owl_message_get_fmtext(owl_message *m)
112{
113  owl_message_format(m);
114  return(&(m->fmtext));
115}
116
117void owl_message_format(owl_message *m)
118{
119  owl_style *s;
120  owl_view *v;
121
122  if (m->invalid_format) {
123    /* for now we assume there's just the one view and use that style */
124    v=owl_global_get_current_view(&g);
125    s=owl_view_get_style(v);
126
127    owl_fmtext_free(&(m->fmtext));
128    owl_fmtext_init_null(&(m->fmtext));
129    owl_style_get_formattext(s, &(m->fmtext), m);
130    m->invalid_format=0;
131  }
132}
133
134void owl_message_set_class(owl_message *m, char *class)
135{
136  owl_message_set_attribute(m, "class", class);
137}
138
139char *owl_message_get_class(owl_message *m)
140{
141  char *class;
142
143  class=owl_message_get_attribute_value(m, "class");
144  if (!class) return("");
145  return(class);
146}
147
148void owl_message_set_instance(owl_message *m, char *inst)
149{
150  owl_message_set_attribute(m, "instance", inst);
151}
152
153char *owl_message_get_instance(owl_message *m)
154{
155  char *instance;
156
157  instance=owl_message_get_attribute_value(m, "instance");
158  if (!instance) return("");
159  return(instance);
160}
161
162void owl_message_set_sender(owl_message *m, char *sender)
163{
164  owl_message_set_attribute(m, "sender", sender);
165}
166
167char *owl_message_get_sender(owl_message *m)
168{
169  char *sender;
170
171  sender=owl_message_get_attribute_value(m, "sender");
172  if (!sender) return("");
173  return(sender);
174}
175
176void owl_message_set_zsig(owl_message *m, char *zsig)
177{
178  owl_message_set_attribute(m, "zsig", zsig);
179}
180
181char *owl_message_get_zsig(owl_message *m)
182{
183  char *zsig;
184
185  zsig=owl_message_get_attribute_value(m, "zsig");
186  if (!zsig) return("");
187  return(zsig);
188}
189
190void owl_message_set_recipient(owl_message *m, char *recip)
191{
192  owl_message_set_attribute(m, "recipient", recip);
193}
194
195char *owl_message_get_recipient(owl_message *m)
196{
197  /* this is stupid for outgoing messages, we need to fix it. */
198
199  char *recip;
200
201  recip=owl_message_get_attribute_value(m, "recipient");
202  if (!recip) return("");
203  return(recip);
204}
205
206void owl_message_set_realm(owl_message *m, char *realm)
207{
208  owl_message_set_attribute(m, "realm", realm);
209}
210
211char *owl_message_get_realm(owl_message *m)
212{
213  char *realm;
214 
215  realm=owl_message_get_attribute_value(m, "realm");
216  if (!realm) return("");
217  return(realm);
218}
219
220void owl_message_set_body(owl_message *m, char *body)
221{
222  owl_message_set_attribute(m, "body", body);
223}
224
225char *owl_message_get_body(owl_message *m)
226{
227  char *body;
228
229  body=owl_message_get_attribute_value(m, "body");
230  if (!body) return("");
231  return(body);
232}
233
234
235void owl_message_set_opcode(owl_message *m, char *opcode)
236{
237  owl_message_set_attribute(m, "opcode", opcode);
238}
239
240char *owl_message_get_opcode(owl_message *m)
241{
242  char *opcode;
243
244  opcode=owl_message_get_attribute_value(m, "opcode");
245  if (!opcode) return("");
246  return(opcode);
247}
248
249
250void owl_message_set_islogin(owl_message *m)
251{
252  owl_message_set_attribute(m, "loginout", "login");
253}
254
255
256void owl_message_set_islogout(owl_message *m)
257{
258  owl_message_set_attribute(m, "loginout", "logout");
259}
260
261int owl_message_is_loginout(owl_message *m)
262{
263  char *res;
264
265  res=owl_message_get_attribute_value(m, "loginout");
266  if (!res) return(0);
267  return(1);
268}
269
270int owl_message_is_login(owl_message *m)
271{
272  char *res;
273
274  res=owl_message_get_attribute_value(m, "loginout");
275  if (!res) return(0);
276  if (!strcmp(res, "login")) return(1);
277  return(0);
278}
279
280
281int owl_message_is_logout(owl_message *m)
282{
283  char *res;
284
285  res=owl_message_get_attribute_value(m, "loginout");
286  if (!res) return(0);
287  if (!strcmp(res, "logout")) return(1);
288  return(0);
289}
290
291void owl_message_set_isprivate(owl_message *m)
292{
293  owl_message_set_attribute(m, "isprivate", "true");
294}
295
296int owl_message_is_private(owl_message *m)
297{
298  char *res;
299
300  res=owl_message_get_attribute_value(m, "isprivate");
301  if (!res) return(0);
302  return(1);
303}
304
305char *owl_message_get_timestr(owl_message *m)
306{
307  if (m->timestr) return(m->timestr);
308  return("");
309}
310
311/* caller must free the return */
312char *owl_message_get_shorttimestr(owl_message *m)
313{
314  struct tm *tmstruct;
315  char *out;
316
317  tmstruct=localtime(&(m->time));
318  out=owl_sprintf("%2.2i:%2.2i", tmstruct->tm_hour, tmstruct->tm_min);
319  if (out) return(out);
320  return("??:??");
321}
322
323void owl_message_set_type_admin(owl_message *m)
324{
325  owl_message_set_attribute(m, "type", "admin");
326}
327
328void owl_message_set_type_loopback(owl_message *m)
329{
330  owl_message_set_attribute(m, "type", "loopback");
331}
332
333void owl_message_set_type_zephyr(owl_message *m)
334{
335  owl_message_set_attribute(m, "type", "zephyr");
336}
337
338void owl_message_set_type_aim(owl_message *m)
339{
340  owl_message_set_attribute(m, "type", "AIM");
341}
342
343void owl_message_set_type(owl_message *m, char* type)
344{
345  owl_message_set_attribute(m, "type", type);
346}
347
348int owl_message_is_type(owl_message *m, char *type) {
349  char * t = owl_message_get_attribute_value(m, "type");
350  if(!t) return 0;
351  return !strcasecmp(t, type);
352}
353                                               
354int owl_message_is_type_admin(owl_message *m)
355{
356  return owl_message_is_type(m, "admin");
357}
358
359int owl_message_is_type_generic(owl_message *m)
360{
361  char * t = owl_message_get_attribute_value(m, "type");
362  return (t == NULL);
363}
364
365int owl_message_is_type_zephyr(owl_message *m)
366{
367  return owl_message_is_type(m, "zephyr");
368}
369
370int owl_message_is_type_aim(owl_message *m)
371{
372  return owl_message_is_type(m, "aim");
373}
374
375/* XXX TODO: deprecate this */
376int owl_message_is_type_jabber(owl_message *m)
377{
378  return owl_message_is_type(m, "jabber");
379}
380
381int owl_message_is_type_loopback(owl_message *m)
382{
383  return owl_message_is_type(m, "loopback");
384}
385
386int owl_message_is_pseudo(owl_message *m)
387{
388  if (owl_message_get_attribute_value(m, "pseudo")) return(1);
389  return(0);
390}
391
392char *owl_message_get_text(owl_message *m)
393{
394  return(owl_fmtext_get_text(&(m->fmtext)));
395}
396
397void owl_message_set_direction_in(owl_message *m)
398{
399  m->direction=OWL_MESSAGE_DIRECTION_IN;
400}
401
402void owl_message_set_direction_out(owl_message *m)
403{
404  m->direction=OWL_MESSAGE_DIRECTION_OUT;
405}
406
407void owl_message_set_direction_none(owl_message *m)
408{
409  m->direction=OWL_MESSAGE_DIRECTION_NONE;
410}
411
412void owl_message_set_direction(owl_message *m, int direction)
413{
414  m->direction=direction;
415}
416
417int owl_message_is_direction_in(owl_message *m)
418{
419  if (m->direction==OWL_MESSAGE_DIRECTION_IN) return(1);
420  return(0);
421}
422
423int owl_message_is_direction_out(owl_message *m)
424{
425  if (m->direction==OWL_MESSAGE_DIRECTION_OUT) return(1);
426  return(0);
427}
428
429int owl_message_is_direction_none(owl_message *m)
430{
431  if (m->direction==OWL_MESSAGE_DIRECTION_NONE) return(1);
432  return(0);
433}
434
435int owl_message_get_numlines(owl_message *m)
436{
437  if (m == NULL) return(0);
438  owl_message_format(m);
439  return(owl_fmtext_num_lines(&(m->fmtext)));
440}
441
442void owl_message_mark_delete(owl_message *m)
443{
444  if (m == NULL) return;
445  m->delete=1;
446}
447
448void owl_message_unmark_delete(owl_message *m)
449{
450  if (m == NULL) return;
451  m->delete=0;
452}
453
454char *owl_message_get_zwriteline(owl_message *m)
455{
456  return(m->zwriteline);
457}
458
459void owl_message_set_zwriteline(owl_message *m, char *line)
460{
461  m->zwriteline=strdup(line);
462}
463
464int owl_message_is_delete(owl_message *m)
465{
466  if (m == NULL) return(0);
467  if (m->delete==1) return(1);
468  return(0);
469}
470
471#ifdef HAVE_LIBZEPHYR
472ZNotice_t *owl_message_get_notice(owl_message *m)
473{
474  return(&(m->notice));
475}
476#else
477void *owl_message_get_notice(owl_message *m)
478{
479  return(NULL);
480}
481#endif
482
483void owl_message_set_hostname(owl_message *m, char *hostname)
484{
485  m->hostname=owl_global_intern(&g, hostname);
486}
487
488char *owl_message_get_hostname(owl_message *m)
489{
490  return(m->hostname);
491}
492
493void owl_message_curs_waddstr(owl_message *m, WINDOW *win, int aline, int bline, int acol, int bcol, int fgcolor, int bgcolor)
494{
495  owl_fmtext a, b;
496
497  /* this will ensure that our cached copy is up to date */
498  owl_message_format(m);
499
500  owl_fmtext_init_null(&a);
501  owl_fmtext_init_null(&b);
502 
503  owl_fmtext_truncate_lines(&(m->fmtext), aline, bline-aline+1, &a);
504  owl_fmtext_truncate_cols(&a, acol, bcol, &b);
505  if (fgcolor!=OWL_COLOR_DEFAULT) {
506    owl_fmtext_colorize(&b, fgcolor);
507  }
508  if (bgcolor!=OWL_COLOR_DEFAULT) {
509    owl_fmtext_colorizebg(&b, bgcolor);
510  }
511
512  if (owl_global_is_search_active(&g)) {
513    owl_fmtext_search_and_highlight(&b, owl_global_get_search_string(&g));
514  }
515     
516  owl_fmtext_curs_waddstr(&b, win);
517
518  owl_fmtext_free(&a);
519  owl_fmtext_free(&b);
520}
521
522int owl_message_is_personal(owl_message *m)
523{
524  if (owl_message_is_type_zephyr(m)) {
525    if (strcasecmp(owl_message_get_class(m), "message")) return(0);
526    if (strcasecmp(owl_message_get_instance(m), "personal")) return(0);
527    if (!strcasecmp(owl_message_get_recipient(m), owl_zephyr_get_sender()) ||
528        !strcasecmp(owl_message_get_sender(m), owl_zephyr_get_sender())) {
529      return(1);
530    }
531  }
532  return(0);
533}
534
535int owl_message_is_question(owl_message *m)
536{
537  if(!owl_message_is_type_admin(m)) return 0;
538  if(owl_message_get_attribute_value(m, "question") != NULL) return 1;
539  return 0;
540}
541
542int owl_message_is_answered(owl_message *m) {
543  if(!owl_message_is_question(m)) return 0;
544  char * q = owl_message_get_attribute_value(m, "question");
545  if(!q) return 0;
546  return !strcmp(q, "answered");
547}
548
549void owl_message_set_isanswered(owl_message *m) {
550  owl_message_set_attribute(m, "question", "answered");
551}
552
553int owl_message_is_from_me(owl_message *m)
554{
555  if (owl_message_is_type_zephyr(m)) {
556    if (!strcasecmp(owl_message_get_sender(m), owl_zephyr_get_sender())) {
557      return(1);
558    } else {
559      return(0);
560    }
561  } else if (owl_message_is_type_aim(m)) {
562    if (!strcasecmp(owl_message_get_sender(m), owl_global_get_aim_screenname(&g))) {
563      return(1);
564    } else {
565      return(0);
566    }
567  } else if (owl_message_is_type_admin(m)) {
568    return(0);
569  }
570  return(0);
571}
572
573int owl_message_is_mail(owl_message *m)
574{
575  if (owl_message_is_type_zephyr(m)) {
576    if (!strcasecmp(owl_message_get_class(m), "mail") && owl_message_is_private(m)) {
577      return(1);
578    } else {
579      return(0);
580    }
581  }
582  return(0);
583}
584
585int owl_message_is_ping(owl_message *m)
586{
587  if (owl_message_is_type_zephyr(m)) {
588    if (!strcasecmp(owl_message_get_opcode(m), "ping")) {
589      return(1);
590    } else {
591      return(0);
592    }
593  }
594  return(0);
595}
596
597int owl_message_is_burningears(owl_message *m)
598{
599  /* we should add a global to cache the short zsender */
600  char sender[LINE], *ptr;
601
602  /* if the message is from us or to us, it doesn't count */
603  if (owl_message_is_from_me(m) || owl_message_is_private(m)) return(0);
604
605  if (owl_message_is_type_zephyr(m)) {
606    strcpy(sender, owl_zephyr_get_sender());
607    ptr=strchr(sender, '@');
608    if (ptr) *ptr='\0';
609  } else if (owl_message_is_type_aim(m)) {
610    strcpy(sender, owl_global_get_aim_screenname(&g));
611  } else {
612    return(0);
613  }
614
615  if (stristr(owl_message_get_body(m), sender)) {
616    return(1);
617  }
618  return(0);
619}
620
621/* caller must free return value. */
622char *owl_message_get_cc(owl_message *m)
623{
624  char *cur, *out, *end;
625
626  cur = owl_message_get_body(m);
627  while (*cur && *cur==' ') cur++;
628  if (strncasecmp(cur, "cc:", 3)) return(NULL);
629  cur+=3;
630  while (*cur && *cur==' ') cur++;
631  out = owl_strdup(cur);
632  end = strchr(out, '\n');
633  if (end) end[0] = '\0';
634  return(out);
635}
636
637int owl_message_get_id(owl_message *m)
638{
639  return(m->id);
640}
641
642char *owl_message_get_type(owl_message *m) {
643  char * type = owl_message_get_attribute_value(m, "type");
644  if(!type) {
645    return "generic";
646  }
647  return type;
648}
649
650char *owl_message_get_direction(owl_message *m) {
651  switch (m->direction) {
652  case OWL_MESSAGE_DIRECTION_IN:
653    return("in");
654  case OWL_MESSAGE_DIRECTION_OUT:
655    return("out");
656  case OWL_MESSAGE_DIRECTION_NONE:
657    return("none");
658  default:
659    return("unknown");
660  }
661}
662
663int owl_message_parse_direction(char *d) {
664  if(!strcmp(d, "in")) {
665    return OWL_MESSAGE_DIRECTION_IN;
666  } else if(!strcmp(d, "out")) {
667    return OWL_MESSAGE_DIRECTION_OUT;
668  } else {
669    return OWL_MESSAGE_DIRECTION_NONE;
670  }
671}
672
673
674char *owl_message_get_login(owl_message *m) {
675  if (owl_message_is_login(m)) {
676    return "login";
677  } else if (owl_message_is_logout(m)) {
678    return "logout";
679  } else {
680    return "none";
681  }
682}
683
684
685char *owl_message_get_header(owl_message *m) {
686  return owl_message_get_attribute_value(m, "adminheader");
687}
688
689/* return 1 if the message contains "string", 0 otherwise.  This is
690 * case insensitive because the functions it uses are
691 */
692int owl_message_search(owl_message *m, char *string)
693{
694
695  owl_message_format(m); /* is this necessary? */
696 
697  return (owl_fmtext_search(&(m->fmtext), string));
698}
699
700
701/* if loginout == -1 it's a logout message
702 *                 0 it's not a login/logout message
703 *                 1 it's a login message
704 */
705void owl_message_create_aim(owl_message *m, char *sender, char *recipient, char *text, int direction, int loginout)
706{
707  owl_message_init(m);
708  owl_message_set_body(m, text);
709  owl_message_set_sender(m, sender);
710  owl_message_set_recipient(m, recipient);
711  owl_message_set_type_aim(m);
712
713  if (direction==OWL_MESSAGE_DIRECTION_IN) {
714    owl_message_set_direction_in(m);
715  } else if (direction==OWL_MESSAGE_DIRECTION_OUT) {
716    owl_message_set_direction_out(m);
717  }
718
719  /* for now all messages that aren't loginout are private */
720  if (!loginout) {
721    owl_message_set_isprivate(m);
722  }
723
724  if (loginout==-1) {
725    owl_message_set_islogout(m);
726  } else if (loginout==1) {
727    owl_message_set_islogin(m);
728  }
729}
730
731void owl_message_create_admin(owl_message *m, char *header, char *text)
732{
733  owl_message_init(m);
734  owl_message_set_type_admin(m);
735  owl_message_set_body(m, text);
736  owl_message_set_attribute(m, "adminheader", header); /* just a hack for now */
737}
738
739/* caller should set the direction */
740void owl_message_create_loopback(owl_message *m, char *text)
741{
742  owl_message_init(m);
743  owl_message_set_type_loopback(m);
744  owl_message_set_body(m, text);
745  owl_message_set_sender(m, "loopsender");
746  owl_message_set_recipient(m, "looprecip");
747  owl_message_set_isprivate(m);
748}
749
750#ifdef HAVE_LIBZEPHYR
751void owl_message_create_from_znotice(owl_message *m, ZNotice_t *n)
752{
753  struct hostent *hent;
754  char *ptr, *tmp, *tmp2;
755
756  owl_message_init(m);
757 
758  owl_message_set_type_zephyr(m);
759  owl_message_set_direction_in(m);
760 
761  /* first save the full notice */
762  memcpy(&(m->notice), n, sizeof(ZNotice_t));
763
764  /* a little gross, we'll replace \r's with ' ' for now */
765  owl_zephyr_hackaway_cr(&(m->notice));
766 
767  /* save the time, we need to nuke the string saved by message_init */
768  if (m->timestr) owl_free(m->timestr);
769  m->time=n->z_time.tv_sec;
770  m->timestr=owl_strdup(ctime(&(m->time)));
771  m->timestr[strlen(m->timestr)-1]='\0';
772
773  /* set other info */
774  owl_message_set_sender(m, n->z_sender);
775  owl_message_set_class(m, n->z_class);
776  owl_message_set_instance(m, n->z_class_inst);
777  owl_message_set_recipient(m, n->z_recipient);
778  if (n->z_opcode) {
779    owl_message_set_opcode(m, n->z_opcode);
780  } else {
781    owl_message_set_opcode(m, "");
782  }
783  owl_message_set_zsig(m, n->z_message);
784
785  if ((ptr=strchr(n->z_recipient, '@'))!=NULL) {
786    owl_message_set_realm(m, ptr+1);
787  } else {
788    owl_message_set_realm(m, owl_zephyr_get_realm());
789  }
790
791  /* Set the "isloginout" attribute if it's a login message */
792  if (!strcasecmp(n->z_class, "login") || !strcasecmp(n->z_class, OWL_WEBZEPHYR_CLASS)) {
793    if (!strcasecmp(n->z_opcode, "user_login") || !strcasecmp(n->z_opcode, "user_logout")) {
794      tmp=owl_zephyr_get_field(n, 1);
795      owl_message_set_attribute(m, "loginhost", tmp);
796      owl_free(tmp);
797
798      tmp=owl_zephyr_get_field(n, 3);
799      owl_message_set_attribute(m, "logintty", tmp);
800      owl_free(tmp);
801    }
802
803    if (!strcasecmp(n->z_opcode, "user_login")) {
804      owl_message_set_islogin(m);
805    } else if (!strcasecmp(n->z_opcode, "user_logout")) {
806      owl_message_set_islogout(m);
807    }
808  }
809
810 
811  /* set the "isprivate" attribute if it's a private zephyr */
812  if (!strcasecmp(n->z_recipient, owl_zephyr_get_sender())) {
813    owl_message_set_isprivate(m);
814  }
815
816  /* set the "isauto" attribute if it's an autoreply */
817  if (!strcasecmp(n->z_message, "Automated reply:") ||
818      !strcasecmp(n->z_opcode, "auto")) {
819    owl_message_set_attribute(m, "isauto", "");
820  }
821
822  m->zwriteline=strdup("");
823
824  /* set the body */
825  tmp=owl_zephyr_get_message(n);
826  if (owl_global_is_newlinestrip(&g)) {
827    tmp2=owl_util_stripnewlines(tmp);
828    owl_message_set_body(m, tmp2);
829    owl_free(tmp2);
830  } else {
831    owl_message_set_body(m, tmp);
832  }
833  owl_free(tmp);
834
835#ifdef OWL_ENABLE_ZCRYPT
836  /* if zcrypt is enabled try to decrypt the message */
837  if (owl_global_is_zcrypt(&g) && !strcasecmp(n->z_opcode, "crypt")) {
838    char *out;
839    int ret;
840
841    out=owl_malloc(strlen(owl_message_get_body(m))*16+20);
842    ret=owl_zcrypt_decrypt(out, owl_message_get_body(m), owl_message_get_class(m), owl_message_get_instance(m));
843    if (ret==0) {
844      owl_message_set_body(m, out);
845    } else {
846      owl_free(out);
847    }
848  }
849#endif 
850
851  /* save the hostname */
852  owl_function_debugmsg("About to do gethostbyaddr");
853  hent=gethostbyaddr((char *) &(n->z_uid.zuid_addr), sizeof(n->z_uid.zuid_addr), AF_INET);
854  if (hent && hent->h_name) {
855    owl_message_set_hostname(m, hent->h_name);
856  } else {
857    owl_message_set_hostname(m, inet_ntoa(n->z_sender_addr));
858  }
859}
860#else
861void owl_message_create_from_znotice(owl_message *m, void *n)
862{
863}
864#endif
865
866/* If 'direction' is '0' it is a login message, '1' is a logout message. */
867void owl_message_create_pseudo_zlogin(owl_message *m, int direction, char *user, char *host, char *time, char *tty)
868{
869  char *longuser, *ptr;
870
871#ifdef HAVE_LIBZEPHYR
872  memset(&(m->notice), 0, sizeof(ZNotice_t));
873#endif
874 
875  longuser=long_zuser(user);
876 
877  owl_message_init(m);
878 
879  owl_message_set_type_zephyr(m);
880  owl_message_set_direction_in(m);
881
882  owl_message_set_attribute(m, "pseudo", "");
883  owl_message_set_attribute(m, "loginhost", host ? host : "");
884  owl_message_set_attribute(m, "logintty", tty ? tty : "");
885
886  owl_message_set_sender(m, longuser);
887  owl_message_set_class(m, "LOGIN");
888  owl_message_set_instance(m, longuser);
889  owl_message_set_recipient(m, "");
890  if (direction==0) {
891    owl_message_set_opcode(m, "USER_LOGIN");
892    owl_message_set_islogin(m);
893  } else if (direction==1) {
894    owl_message_set_opcode(m, "USER_LOGOUT");
895    owl_message_set_islogout(m);
896  }
897
898  if ((ptr=strchr(longuser, '@'))!=NULL) {
899    owl_message_set_realm(m, ptr+1);
900  } else {
901    owl_message_set_realm(m, owl_zephyr_get_realm());
902  }
903
904  m->zwriteline=strdup("");
905
906  owl_message_set_body(m, "<uninitialized>");
907
908  /* save the hostname */
909  owl_function_debugmsg("create_pseudo_login: host is %s", host ? host : "");
910  owl_message_set_hostname(m, host ? host : "");
911  owl_free(longuser);
912}
913
914void owl_message_create_from_zwriteline(owl_message *m, char *line, char *body, char *zsig)
915{
916  owl_zwrite z;
917  int ret;
918  char hostbuff[5000];
919 
920  owl_message_init(m);
921
922  /* create a zwrite for the purpose of filling in other message fields */
923  owl_zwrite_create_from_line(&z, line);
924
925  /* set things */
926  owl_message_set_direction_out(m);
927  owl_message_set_type_zephyr(m);
928  owl_message_set_sender(m, owl_zephyr_get_sender());
929  owl_message_set_class(m, owl_zwrite_get_class(&z));
930  owl_message_set_instance(m, owl_zwrite_get_instance(&z));
931  if (owl_zwrite_get_numrecips(&z)>0) {
932    owl_message_set_recipient(m,
933                              long_zuser(owl_zwrite_get_recip_n(&z, 0))); /* only gets the first user, must fix */
934  }
935  owl_message_set_opcode(m, owl_zwrite_get_opcode(&z));
936  owl_message_set_realm(m, owl_zwrite_get_realm(&z)); /* also a hack, but not here */
937  m->zwriteline=owl_strdup(line);
938  owl_message_set_body(m, body);
939  owl_message_set_zsig(m, zsig);
940 
941  /* save the hostname */
942  ret=gethostname(hostbuff, MAXHOSTNAMELEN);
943  hostbuff[MAXHOSTNAMELEN]='\0';
944  if (ret) {
945    owl_message_set_hostname(m, "localhost");
946  } else {
947    owl_message_set_hostname(m, hostbuff);
948  }
949  owl_zwrite_free(&z);
950
951  if(owl_message_is_personal(m))
952    owl_message_set_isprivate(m);
953}
954
955void owl_message_pretty_zsig(owl_message *m, char *buff)
956{
957  /* stick a one line version of the zsig in buff */
958  char *ptr;
959
960  strcpy(buff, owl_message_get_zsig(m));
961  ptr=strchr(buff, '\n');
962  if (ptr) ptr[0]='\0';
963}
964
965void owl_message_free(owl_message *m)
966{
967  int i, j;
968  owl_pair *p;
969#ifdef HAVE_LIBZEPHYR   
970  if (owl_message_is_type_zephyr(m) && owl_message_is_direction_in(m)) {
971    ZFreeNotice(&(m->notice));
972  }
973#endif
974  if (m->timestr) owl_free(m->timestr);
975  if (m->zwriteline) owl_free(m->zwriteline);
976
977  /* free all the attributes */
978  j=owl_list_get_size(&(m->attributes));
979  for (i=0; i<j; i++) {
980    p=owl_list_get_element(&(m->attributes), i);
981    owl_free(owl_pair_get_key(p));
982    owl_free(owl_pair_get_value(p));
983    owl_free(p);
984  }
985
986  owl_list_free_simple(&(m->attributes));
987 
988  owl_fmtext_free(&(m->fmtext));
989}
Note: See TracBrowser for help on using the repository browser.