eapol.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <ip.h>
  4. #include "dat.h"
  5. #include "protos.h"
  6. typedef struct Hdr Hdr;
  7. struct Hdr
  8. {
  9. uchar vi; /* version */
  10. uchar type;
  11. uchar len[2]; /* length of data following this header */
  12. };
  13. enum
  14. {
  15. EAPOLHDR= 4, /* sizeof(Hdr) */
  16. /* eapol types */
  17. Eap = 0,
  18. Start,
  19. Logoff,
  20. Key,
  21. AsfAlert,
  22. };
  23. enum
  24. {
  25. Ot, /* type */
  26. };
  27. static Mux p_mux[] =
  28. {
  29. { "eap", Eap, },
  30. { "eapol_start", Start, },
  31. { "eapol_logoff", Logoff, },
  32. { "eapol_key", Key, },
  33. { "asf_alert", AsfAlert, },
  34. { 0 }
  35. };
  36. static void
  37. p_compile(Filter *f)
  38. {
  39. Mux *m;
  40. for(m = p_mux; m->name != nil; m++)
  41. if(strcmp(f->s, m->name) == 0){
  42. f->pr = m->pr;
  43. f->ulv = m->val;
  44. f->subop = Ot;
  45. return;
  46. }
  47. sysfatal("unknown eapol field or type: %s", f->s);
  48. }
  49. static int
  50. p_filter(Filter *f, Msg *m)
  51. {
  52. Hdr *h;
  53. if(m->pe - m->ps < EAPOLHDR)
  54. return 0;
  55. h = (Hdr*)m->ps;
  56. /* len does not include header */
  57. m->ps += EAPOLHDR;
  58. switch(f->subop){
  59. case Ot:
  60. return h->type == f->ulv;
  61. }
  62. return 0;
  63. }
  64. static char*
  65. op(int i)
  66. {
  67. static char x[20];
  68. switch(i){
  69. case Eap:
  70. return "Eap";
  71. case Start:
  72. return "Start";
  73. case Logoff:
  74. return "Logoff";
  75. case Key:
  76. return "Key";
  77. case AsfAlert:
  78. return "AsfAlert";
  79. default:
  80. sprint(x, "%1d", i);
  81. return x;
  82. }
  83. }
  84. static int
  85. p_seprint(Msg *m)
  86. {
  87. Hdr *h;
  88. int len;
  89. if(m->pe - m->ps < EAPOLHDR)
  90. return -1;
  91. h = (Hdr*)m->ps;
  92. /* len does not include header */
  93. m->ps += EAPOLHDR;
  94. /* truncate the message if there's extra */
  95. len = NetS(h->len);
  96. if(m->ps + len < m->pe)
  97. m->pe = m->ps + len;
  98. else if(m->ps+len > m->pe)
  99. return -1;
  100. /* next protocol depending on type*/
  101. demux(p_mux, h->type, h->type, m, &dump);
  102. m->p = seprint(m->p, m->e, "type=%s version=%1d datalen=%1d",
  103. op(h->type), h->vi, len);
  104. return 0;
  105. }
  106. Proto eapol =
  107. {
  108. "eapol",
  109. p_compile,
  110. p_filter,
  111. p_seprint,
  112. p_mux,
  113. "%lud",
  114. nil,
  115. defaultframer,
  116. };