/[LeafOK_CVS]/lbbs/src/bbs_net.c
ViewVC logotype

Diff of /lbbs/src/bbs_net.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.38 by sysadm, Tue May 13 02:21:39 2025 UTC Revision 1.42 by sysadm, Thu May 15 06:24:11 2025 UTC
# Line 57  int load_bbsnet_conf(const char *file_co Line 57  int load_bbsnet_conf(const char *file_co
57  {  {
58          FILE *fp;          FILE *fp;
59          MENU *p_menu;          MENU *p_menu;
60          MENU_ITEM *p_menuitem;          MENU_ITEM *p_menu_item;
61            MENU_ITEM_ID menu_item_id;
62          char t[256], *t1, *t2, *t3, *t4, *saveptr;          char t[256], *t1, *t2, *t3, *t4, *saveptr;
         int item_count = 0;  
63    
64          fp = fopen(file_config, "r");          fp = fopen(file_config, "r");
65          if (fp == NULL)          if (fp == NULL)
# Line 67  int load_bbsnet_conf(const char *file_co Line 67  int load_bbsnet_conf(const char *file_co
67                  return -1;                  return -1;
68          }          }
69    
70          p_menu = bbsnet_menu.p_menu[0] = malloc(sizeof(MENU));          bbsnet_menu.p_menu_pool = calloc(1, sizeof(MENU));
71            if (bbsnet_menu.p_menu_pool == NULL)
72            {
73                    log_error("calloc(p_menu_pool) error\n");
74                    return -3;
75            }
76            bbsnet_menu.menu_count = 1;
77    
78            bbsnet_menu.p_menu_item_pool = calloc(MAXSTATION, sizeof(MENU_ITEM));
79            if (bbsnet_menu.p_menu_item_pool == NULL)
80            {
81                    log_error("calloc(p_menu_item_pool) error\n");
82                    return -3;
83            }
84            bbsnet_menu.menu_item_count = MAXSTATION;
85    
86            p_menu = (MENU *)get_menu_by_id(&bbsnet_menu, 0);
87    
88          strncpy(p_menu->name, "BBSNET", sizeof(p_menu->name) - 1);          strncpy(p_menu->name, "BBSNET", sizeof(p_menu->name) - 1);
89          p_menu->name[sizeof(p_menu->name) - 1] = '\0';          p_menu->name[sizeof(p_menu->name) - 1] = '\0';
90          p_menu->title.show = 0;          p_menu->title.show = 0;
91          p_menu->screen.show = 0;          p_menu->screen_show = 0;
92    
93          while (fgets(t, 255, fp) && item_count < MAXSTATION)          menu_item_id = 0;
94            while (fgets(t, 255, fp) && menu_item_id < MAXSTATION)
95          {          {
96                  t1 = strtok_r(t, MENU_CONF_DELIM, &saveptr);                  t1 = strtok_r(t, MENU_CONF_DELIM, &saveptr);
97                  t2 = strtok_r(NULL, MENU_CONF_DELIM, &saveptr);                  t2 = strtok_r(NULL, MENU_CONF_DELIM, &saveptr);
# Line 85  int load_bbsnet_conf(const char *file_co Line 103  int load_bbsnet_conf(const char *file_co
103                          continue;                          continue;
104                  }                  }
105    
106                  strncpy(bbsnet_conf[item_count].host1, t2, sizeof(bbsnet_conf[item_count].host1) - 1);                  strncpy(bbsnet_conf[menu_item_id].host1, t2, sizeof(bbsnet_conf[menu_item_id].host1) - 1);
107                  bbsnet_conf[item_count].host1[sizeof(bbsnet_conf[item_count].host1) - 1] = '\0';                  bbsnet_conf[menu_item_id].host1[sizeof(bbsnet_conf[menu_item_id].host1) - 1] = '\0';
108                  strncpy(bbsnet_conf[item_count].host2, t1, sizeof(bbsnet_conf[item_count].host2) - 1);                  strncpy(bbsnet_conf[menu_item_id].host2, t1, sizeof(bbsnet_conf[menu_item_id].host2) - 1);
109                  bbsnet_conf[item_count].host2[sizeof(bbsnet_conf[item_count].host2) - 1] = '\0';                  bbsnet_conf[menu_item_id].host2[sizeof(bbsnet_conf[menu_item_id].host2) - 1] = '\0';
110                  strncpy(bbsnet_conf[item_count].ip, t3, sizeof(bbsnet_conf[item_count].ip) - 1);                  strncpy(bbsnet_conf[menu_item_id].ip, t3, sizeof(bbsnet_conf[menu_item_id].ip) - 1);
111                  bbsnet_conf[item_count].ip[sizeof(bbsnet_conf[item_count].ip) - 1] = '\0';                  bbsnet_conf[menu_item_id].ip[sizeof(bbsnet_conf[menu_item_id].ip) - 1] = '\0';
112                  bbsnet_conf[item_count].port = (in_port_t)(t4 ? atoi(t4) : 23);                  bbsnet_conf[menu_item_id].port = (in_port_t)(t4 ? atoi(t4) : 23);
   
                 p_menuitem = p_menu->items[item_count] = malloc(sizeof(MENU_ITEM));  
                 p_menuitem->row = 2 + item_count / STATION_PER_LINE;  
                 p_menuitem->col = 5 + item_count % STATION_PER_LINE * 20;  
                 snprintf(p_menuitem->action, sizeof(p_menuitem->action), "%d", item_count);  
                 p_menuitem->submenu = 0;  
                 p_menuitem->priv = 0;  
                 p_menuitem->level = 0;  
                 p_menuitem->display = 0;  
                 p_menuitem->name[0] =  
                         (char)(item_count < MAXSTATION / 2 ? 'A' + item_count : 'a' + item_count);  
                 p_menuitem->name[1] = '\0';  
                 snprintf(p_menuitem->text, sizeof(p_menuitem->text), "%c. %s",  
                                  p_menuitem->name[0], bbsnet_conf[item_count].host1);  
113    
114                  item_count++;                  p_menu_item = get_menu_item_by_id(&bbsnet_menu, menu_item_id);
115          }                  if (p_menu_item == NULL)
116          fclose(fp);                  {
117                            log_error("get_menu_item_by_id(%d) return NULL pointer\n", menu_item_id);
118                            return -1;
119                    }
120    
121          p_menu->item_count = item_count;                  p_menu_item->row = (int16_t)(2 + menu_item_id / STATION_PER_LINE);
122          p_menu->item_cur_pos = 0;                  p_menu_item->col = (int16_t)(5 + menu_item_id % STATION_PER_LINE * 20);
123                    snprintf(p_menu_item->action, sizeof(p_menu_item->action), "%d", (int16_t)menu_item_id);
124                    p_menu_item->submenu = 0;
125                    p_menu_item->priv = 0;
126                    p_menu_item->level = 0;
127                    p_menu_item->name[0] =
128                            (char)(menu_item_id < MAXSTATION / 2 ? 'A' + menu_item_id : 'a' + menu_item_id);
129                    p_menu_item->name[1] = '\0';
130                    snprintf(p_menu_item->text, sizeof(p_menu_item->text), "%c. %s",
131                                     p_menu_item->name[0], bbsnet_conf[menu_item_id].host1);
132    
133                    p_menu->items[p_menu->item_count] = menu_item_id;
134                    p_menu->item_count++;
135                    menu_item_id++;
136            }
137    
138            bbsnet_menu.menu_item_count = (int16_t)menu_item_id;
139            bbsnet_menu.menu_id_path[0] = 0;
140            bbsnet_menu.menu_item_pos[0] = 0;
141            bbsnet_menu.choose_step = 0;
142    
143          bbsnet_menu.menu_count = 1;          fclose(fp);
         bbsnet_menu.menu_select_depth = 0;  
         bbsnet_menu.p_menu_select[0] = bbsnet_menu.p_menu[0];  
144    
145          return 0;          return 0;
146  }  }
147    
148  static void process_bar(int n, int len)  void unload_bbsnet_conf(void)
149    {
150            bbsnet_menu.menu_count = 0;
151            bbsnet_menu.menu_item_count = 0;
152    
153            free(bbsnet_menu.p_menu_pool);
154            bbsnet_menu.p_menu_pool = NULL;
155            free(bbsnet_menu.p_menu_item_pool);
156            bbsnet_menu.p_menu_item_pool = NULL;
157    }
158    
159    void process_bar(int n, int len)
160  {  {
161          char buf[LINE_BUFFER_LEN];          char buf[LINE_BUFFER_LEN];
162          char buf2[LINE_BUFFER_LEN];          char buf2[LINE_BUFFER_LEN];
# Line 226  int bbsnet_connect(int n) Line 261  int bbsnet_connect(int n)
261          prints("\033[1;32m穿梭进度条提示您当前已使用的时间,按\033[1;33mCtrl+C\033[1;32m中断。\033[m\r\n");          prints("\033[1;32m穿梭进度条提示您当前已使用的时间,按\033[1;33mCtrl+C\033[1;32m中断。\033[m\r\n");
262          process_bar(0, MAX_PROCESS_BAR_LEN);          process_bar(0, MAX_PROCESS_BAR_LEN);
263    
264            // Set socket as non-blocking
265            flags_sock = fcntl(sock, F_GETFL, 0);
266            fcntl(sock, F_SETFL, flags_sock | O_NONBLOCK);
267    
268            // Set STDIN/STDOUT as non-blocking
269            flags_stdin = fcntl(STDIN_FILENO, F_GETFL, 0);
270            flags_stdout = fcntl(STDOUT_FILENO, F_GETFL, 0);
271            fcntl(STDIN_FILENO, F_SETFL, flags_stdin | O_NONBLOCK);
272            fcntl(STDOUT_FILENO, F_SETFL, flags_stdout | O_NONBLOCK);
273    
274          epollfd = epoll_create1(0);          epollfd = epoll_create1(0);
275          if (epollfd < 0)          if (epollfd < 0)
276          {          {
# Line 238  int bbsnet_connect(int n) Line 283  int bbsnet_connect(int n)
283          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, sock, &ev) == -1)          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, sock, &ev) == -1)
284          {          {
285                  log_error("epoll_ctl(socket) error (%d)\n", errno);                  log_error("epoll_ctl(socket) error (%d)\n", errno);
286                  return -1;                  goto cleanup;
287          }          }
288    
289          ev.events = EPOLLIN;          ev.events = EPOLLIN;
# Line 246  int bbsnet_connect(int n) Line 291  int bbsnet_connect(int n)
291          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, STDIN_FILENO, &ev) == -1)          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, STDIN_FILENO, &ev) == -1)
292          {          {
293                  log_error("epoll_ctl(STDIN_FILENO) error (%d)\n", errno);                  log_error("epoll_ctl(STDIN_FILENO) error (%d)\n", errno);
294                  return -1;                  goto cleanup;
295          }          }
296    
         // Set socket as non-blocking  
         flags_sock = fcntl(sock, F_GETFL, 0);  
         fcntl(sock, F_SETFL, flags_sock | O_NONBLOCK);  
   
297          while (!SYS_server_exit)          while (!SYS_server_exit)
298          {          {
299                  if ((ret = connect(sock, (struct sockaddr *)&sin, sizeof(sin))) < 0)                  if ((ret = connect(sock, (struct sockaddr *)&sin, sizeof(sin))) < 0)
300                  {                  {
301                          if (errno == EAGAIN || errno == EALREADY || errno == EINPROGRESS)                          if (errno == EAGAIN || errno == EALREADY || errno == EINPROGRESS)
302                          {                          {
                                 log_std("Debug: %d\n", errno);  
303                                  // Use select / epoll to check writability of the socket,                                  // Use select / epoll to check writability of the socket,
304                                  // then use getsockopt to check the status of the socket.                                  // then use getsockopt to check the status of the socket.
305                                  // See man connect(2)                                  // See man connect(2)
# Line 272  int bbsnet_connect(int n) Line 312  int bbsnet_connect(int n)
312                          else                          else
313                          {                          {
314                                  log_error("connect(socket) error (%d)\n", errno);                                  log_error("connect(socket) error (%d)\n", errno);
315    
316                                  prints("\033[1;31m连接失败!\033[m\r\n");                                  prints("\033[1;31m连接失败!\033[m\r\n");
317                                  press_any_key();                                  press_any_key();
318                                  return -1;  
319                                    goto cleanup;
320                          }                          }
321                  }                  }
322          }          }
# Line 288  int bbsnet_connect(int n) Line 330  int bbsnet_connect(int n)
330                          if (errno != EINTR)                          if (errno != EINTR)
331                          {                          {
332                                  log_error("epoll_wait() error (%d)\n", errno);                                  log_error("epoll_wait() error (%d)\n", errno);
333                                  return -1;                                  break;
334                          }                          }
335                  }                  }
336                  else if (nfds == 0) // timeout                  else if (nfds == 0) // timeout
# Line 305  int bbsnet_connect(int n) Line 347  int bbsnet_connect(int n)
347                                          if (getsockopt(sock, SOL_SOCKET, SO_ERROR, &error, (socklen_t *)&len) < 0)                                          if (getsockopt(sock, SOL_SOCKET, SO_ERROR, &error, (socklen_t *)&len) < 0)
348                                          {                                          {
349                                                  log_error("getsockopt() error (%d) !\n", error);                                                  log_error("getsockopt() error (%d) !\n", error);
350                                                  return -1;                                                  goto cleanup;
351                                          }                                          }
352                                          if (error == 0)                                          if (error == 0)
353                                          {                                          {
# Line 317  int bbsnet_connect(int n) Line 359  int bbsnet_connect(int n)
359                                          ch = igetch(0);                                          ch = igetch(0);
360                                          if (ch == Ctrl('C'))                                          if (ch == Ctrl('C'))
361                                          {                                          {
362                                                  return 0;                                                  goto cleanup;
363                                          }                                          }
364                                  }                                  }
365                          }                          }
# Line 325  int bbsnet_connect(int n) Line 367  int bbsnet_connect(int n)
367          }          }
368          if (SYS_server_exit)          if (SYS_server_exit)
369          {          {
370                  return 0;                  goto cleanup;
371          }          }
372          if (!sock_connected)          if (!sock_connected)
373          {          {
374                  prints("\033[1;31m连接超时!\033[m\r\n");                  prints("\033[1;31m连接失败!\033[m\r\n");
375                  press_any_key();                  press_any_key();
376                  return -1;  
377                    goto cleanup;
378          }          }
379    
380          tos = IPTOS_LOWDELAY;          tos = IPTOS_LOWDELAY;
# Line 349  int bbsnet_connect(int n) Line 392  int bbsnet_connect(int n)
392          if (epoll_ctl(epollfd, EPOLL_CTL_MOD, sock, &ev) == -1)          if (epoll_ctl(epollfd, EPOLL_CTL_MOD, sock, &ev) == -1)
393          {          {
394                  log_error("epoll_ctl(socket) error (%d)\n", errno);                  log_error("epoll_ctl(socket) error (%d)\n", errno);
395                  return -1;                  goto cleanup;
396          }          }
397    
398          ev.events = EPOLLOUT;          ev.events = EPOLLOUT;
# Line 357  int bbsnet_connect(int n) Line 400  int bbsnet_connect(int n)
400          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, STDOUT_FILENO, &ev) == -1)          if (epoll_ctl(epollfd, EPOLL_CTL_ADD, STDOUT_FILENO, &ev) == -1)
401          {          {
402                  log_error("epoll_ctl(STDOUT_FILENO) error (%d)\n", errno);                  log_error("epoll_ctl(STDOUT_FILENO) error (%d)\n", errno);
403                  return -1;                  goto cleanup;
404          }          }
405    
         // Set STDIN/STDOUT as non-blocking  
         flags_stdin = fcntl(STDIN_FILENO, F_GETFL, 0);  
         flags_stdout = fcntl(STDOUT_FILENO, F_GETFL, 0);  
         fcntl(STDIN_FILENO, F_SETFL, flags_stdin | O_NONBLOCK);  
         fcntl(STDOUT_FILENO, F_SETFL, flags_stdout | O_NONBLOCK);  
   
406          BBS_last_access_tm = t_used = time(0);          BBS_last_access_tm = t_used = time(0);
407          loop = 1;          loop = 1;
408    
# Line 564  int bbsnet_connect(int n) Line 601  int bbsnet_connect(int n)
601                  }                  }
602          }          }
603    
604    cleanup:
605            if (close(epollfd) < 0)
606            {
607                    log_error("close(epoll) error (%d)\n");
608            }
609    
610          // Restore STDIN/STDOUT flags          // Restore STDIN/STDOUT flags
611          fcntl(STDIN_FILENO, F_SETFL, flags_stdin);          fcntl(STDIN_FILENO, F_SETFL, flags_stdin);
612          fcntl(STDOUT_FILENO, F_SETFL, flags_stdout);          fcntl(STDOUT_FILENO, F_SETFL, flags_stdout);
# Line 644  int bbs_net() Line 687  int bbs_net()
687    
688          clearscr();          clearscr();
689          bbsnet_refresh();          bbsnet_refresh();
690          pos = bbsnet_menu.p_menu[0]->item_cur_pos;          pos = bbsnet_menu.menu_item_pos[0];
691          display_menu(get_menu(&bbsnet_menu, "BBSNET"));          display_menu(&bbsnet_menu);
692          bbsnet_selchange(pos);          bbsnet_selchange(pos);
693    
694          while (!SYS_server_exit)          while (!SYS_server_exit)
695          {          {
696                  ch = igetch(0);                  ch = igetch(100);
697                  switch (ch)                  switch (ch)
698                  {                  {
699                  case KEY_NULL:  // broken pipe                  case KEY_NULL:  // broken pipe
700                  case Ctrl('C'): // user cancel                  case Ctrl('C'): // user cancel
701                          return 0;                          goto cleanup;
702                  case KEY_TIMEOUT:                  case KEY_TIMEOUT:
703                          if (time(0) - BBS_last_access_tm >= MAX_DELAY_TIME)                          if (time(0) - BBS_last_access_tm >= MAX_DELAY_TIME)
704                          {                          {
705                                  return 0;                                  goto cleanup;
706                          }                          }
707                          continue;                          continue;
708                  case CR:                  case CR:
709                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          igetch_reset();
710                            pos = bbsnet_menu.menu_item_pos[0];
711                          bbsnet_connect(pos);                          bbsnet_connect(pos);
712                          bbsnet_refresh();                          bbsnet_refresh();
713                          display_current_menu(&bbsnet_menu);                          display_menu(&bbsnet_menu);
714                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
715                          break;                          break;
716                  case KEY_UP:                  case KEY_UP:
# Line 674  int bbs_net() Line 718  int bbs_net()
718                          {                          {
719                                  menu_control(&bbsnet_menu, KEY_UP);                                  menu_control(&bbsnet_menu, KEY_UP);
720                          }                          }
721                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          pos = bbsnet_menu.menu_item_pos[0];
722                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
723                          break;                          break;
724                  case KEY_DOWN:                  case KEY_DOWN:
# Line 682  int bbs_net() Line 726  int bbs_net()
726                          {                          {
727                                  menu_control(&bbsnet_menu, KEY_DOWN);                                  menu_control(&bbsnet_menu, KEY_DOWN);
728                          }                          }
729                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          pos = bbsnet_menu.menu_item_pos[0];
730                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
731                          break;                          break;
732                  case KEY_LEFT:                  case KEY_LEFT:
733                          menu_control(&bbsnet_menu, KEY_UP);                          menu_control(&bbsnet_menu, KEY_UP);
734                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          pos = bbsnet_menu.menu_item_pos[0];
735                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
736                          break;                          break;
737                  case KEY_RIGHT:                  case KEY_RIGHT:
738                          menu_control(&bbsnet_menu, KEY_DOWN);                          menu_control(&bbsnet_menu, KEY_DOWN);
739                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          pos = bbsnet_menu.menu_item_pos[0];
740                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
741                          break;                          break;
742                  default:                  default:
743                          menu_control(&bbsnet_menu, ch);                          menu_control(&bbsnet_menu, ch);
744                          pos = bbsnet_menu.p_menu[0]->item_cur_pos;                          pos = bbsnet_menu.menu_item_pos[0];
745                          bbsnet_selchange(pos);                          bbsnet_selchange(pos);
746                          break;                          break;
747                  }                  }
748                  BBS_last_access_tm = time(0);                  BBS_last_access_tm = time(0);
749          }          }
750    
751    cleanup:
752            unload_bbsnet_conf();
753    
754          return 0;          return 0;
755  }  }


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1