ntlm.c 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. 3APA3A simpliest proxy server
  3. (c) 2002-2016 by Vladimir Dubrovin <3proxy@3proxy.ru>
  4. please read License Agreement
  5. */
  6. #include "proxy.h"
  7. struct ntlmchal {
  8. unsigned char sig[8];
  9. unsigned char messtype[4];
  10. unsigned char dom_len[2];
  11. unsigned char dom_max_len[2];
  12. unsigned char dom_offset[4];
  13. unsigned char flags[4];
  14. unsigned char challenge[8];
  15. unsigned char reserved[8];
  16. unsigned char addr_len[2];
  17. unsigned char addr_max_len[2];
  18. unsigned char addr_offset[4];
  19. unsigned char data[1];
  20. };
  21. struct ntlmreq {
  22. unsigned char sig[8];
  23. unsigned char messtype[4];
  24. unsigned char flags[4];
  25. unsigned char dom_len[2];
  26. unsigned char dom_max_len[2];
  27. unsigned char dom_offset[4];
  28. unsigned char pad1[2];
  29. unsigned char host_len[2];
  30. unsigned char host_max_len[2];
  31. unsigned char host_offset[4];
  32. unsigned char pad2[2];
  33. unsigned char data[1];
  34. };
  35. int text2unicode(const char * text, char * buf, int buflen){
  36. int count = 0;
  37. buflen = ((buflen>>1)<<1);
  38. if(!text || !buflen) return 0;
  39. do {
  40. buf[count++] = toupper(*text++);
  41. buf[count++] = '\0';
  42. } while (*text && count < buflen);
  43. return count;
  44. }
  45. void unicode2text(const char *unicode, char * buf, int len){
  46. int i;
  47. if(!unicode || !len) return;
  48. for(i=0; i<len; i++){
  49. buf[i] = unicode[(i<<1)];
  50. }
  51. buf[i] = 0;
  52. }
  53. void genchallenge(struct clientparam *param, char * challenge, char *buf){
  54. struct ntlmchal *chal;
  55. char tmpbuf[1024];
  56. char hostname[128];
  57. int len, i;
  58. chal = (struct ntlmchal *)tmpbuf;
  59. memset(chal, 0, 1024);
  60. memcpy(chal->sig, "NTLMSSP", 8);
  61. chal->messtype[0] = 2;
  62. gethostname(hostname, 128);
  63. hostname[15] = 0;
  64. len = (((int)strlen(hostname)) << 1);
  65. chal->dom_len[0] = len;
  66. chal->dom_max_len[0] = len;
  67. chal->dom_offset[0] = (unsigned char)((unsigned char *)chal->data - (unsigned char *)chal);
  68. chal->flags[0] = 0x03;
  69. chal->flags[1] = 0x82;
  70. chal->flags[2] = 0x81;
  71. chal->flags[3] = 0xA0;
  72. text2unicode(hostname, (char *)chal->data, 64);
  73. time((time_t *)challenge);
  74. memcpy(challenge+4, SAADDR(&param->sincr), 4);
  75. challenge[1]^=*SAPORT(&param->sincr);
  76. for(i = 0; i < 8; i++) challenge[i] ^= myrand(challenge, 8);
  77. memcpy(chal->challenge, challenge, 8);
  78. en64((unsigned char *)tmpbuf, (unsigned char *)buf, (int)((unsigned char *)chal->data - (unsigned char *)chal) + len);
  79. }