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

Diff of /lbbs/src/user_info_display.c

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

Revision 1.1 by sysadm, Thu Oct 23 09:55:15 2025 UTC Revision 1.2 by sysadm, Thu Oct 23 11:10:34 2025 UTC
# Line 14  Line 14 
14   *                                                                         *   *                                                                         *
15   ***************************************************************************/   ***************************************************************************/
16    
17    #include "ip_mask.h"
18  #include "lml.h"  #include "lml.h"
19  #include "log.h"  #include "log.h"
20  #include "screen.h"  #include "screen.h"
21  #include "str_process.h"  #include "str_process.h"
22  #include "user_list.h"  #include "user_list.h"
23  #include "user_info_display.h"  #include "user_info_display.h"
24    #include "user_priv.h"
25  #include <string.h>  #include <string.h>
26    #include <time.h>
27  #include <sys/param.h>  #include <sys/param.h>
28    
29  #define BBS_max_sessions_per_user 10  #define BBS_max_sessions_per_user 10
30    #define LAST_LOGIN_DT_MAX_LEN 50
31    
32  static int display_user_intro_key_handler(int *p_key, DISPLAY_CTX *p_ctx)  static int display_user_intro_key_handler(int *p_key, DISPLAY_CTX *p_ctx)
33  {  {
# Line 34  int user_info_display(USER_INFO *p_user_ Line 38  int user_info_display(USER_INFO *p_user_
38  {  {
39          USER_ONLINE_INFO sessions[BBS_max_sessions_per_user];          USER_ONLINE_INFO sessions[BBS_max_sessions_per_user];
40          int session_cnt = BBS_max_sessions_per_user;          int session_cnt = BBS_max_sessions_per_user;
41            int article_cnt;
42            struct tm tm_last_login;
43            char str_last_login_dt[LAST_LOGIN_DT_MAX_LEN + 1];
44            struct tm tm_last_logout;
45            char str_last_logout_dt[LAST_LOGIN_DT_MAX_LEN + 1];
46            char login_ip[IP_ADDR_LEN];
47            int ip_mask_level;
48          char action_str[LINE_BUFFER_LEN];          char action_str[LINE_BUFFER_LEN];
49            char intro_f[BBS_user_intro_max_len];
50            int intro_len;
51            char user_info_f[BUFSIZ];
52            long line_offsets[BBS_user_intro_max_line + 1];
53            long lines;
54          char *p;          char *p;
55            const char *q;
56          int ret;          int ret;
57          int i;          int i;
58    
59            article_cnt = get_user_article_cnt(p_user_info->uid);
60    
61            localtime_r(&(p_user_info->last_login_dt), &tm_last_login);
62            strftime(str_last_login_dt, sizeof(str_last_login_dt), "%c", &tm_last_login);
63            localtime_r(&(p_user_info->last_logout_dt), &tm_last_logout);
64            strftime(str_last_logout_dt, sizeof(str_last_logout_dt), "%c", &tm_last_logout);
65    
66          action_str[0] = '\0';          action_str[0] = '\0';
67    
68          ret = query_user_online_info_by_uid(p_user_info->uid, sessions, &session_cnt, 0);          ret = query_user_online_info_by_uid(p_user_info->uid, sessions, &session_cnt, 0);
# Line 46  int user_info_display(USER_INFO *p_user_ Line 70  int user_info_display(USER_INFO *p_user_
70          {          {
71                  log_error("query_user_online_info_by_uid(uid=%d, cnt=%d) error: %d\n",                  log_error("query_user_online_info_by_uid(uid=%d, cnt=%d) error: %d\n",
72                                    p_user_info->uid, session_cnt, ret);                                    p_user_info->uid, session_cnt, ret);
73                    session_cnt = 0;
74          }          }
75          else  
76            p = action_str;
77            for (i = 0; i < session_cnt; i++)
78          {          {
79                  p = action_str;                  if (p + strlen(sessions[i].current_action_title) + 4 >= action_str + sizeof(action_str)) // buffer overflow
80                  for (i = 0; i < session_cnt; i++)                  {
81                            log_error("action_str of user(uid=%d) truncated at i=%d\n", p_user_info->uid, i);
82                            break;
83                    }
84                    *p++ = '[';
85                    for (q = sessions[i].current_action_title; *q != '\0';)
86                  {                  {
87                          if (p + strlen(sessions[i].current_action_title) + 3 >= action_str + sizeof(action_str)) // buffer overflow                          *p++ = *q++;
                         {  
                                 log_error("action_str of user(uid=%d) truncated at i=%d\n", p_user_info->uid, i);  
                                 break;  
                         }  
                         *p++ = '[';  
                         p = stpncpy(p, sessions[i].current_action_title, strlen(sessions[i].current_action_title));  
                         *p++ = ']';  
                         *p++ = ' ';  
88                  }                  }
89                  *p = '\0';                  *p++ = ']';
90                    *p++ = ' ';
91          }          }
92            *p++ = '\n';
93            *p = '\0';
94    
95          char intro_f[BBS_user_intro_max_len];          if (session_cnt > 0)
96          char profile_f[BUFSIZ];          {
97          long line_offsets[BBS_user_intro_max_line + 1];                  strncpy(login_ip, sessions[0].ip, sizeof(login_ip) - 1);
98          long lines;                  login_ip[sizeof(login_ip) - 1] = '\0';
99    
100                    ip_mask_level = checklevel(&BBS_priv, P_ADMIN_M | P_ADMIN_S);
101                    ip_mask(login_ip, (ip_mask_level ? 1 : 2), '*');
102            }
103            else
104            {
105                    login_ip[0] = '\0';
106            }
107    
108          lml_render(p_user_info->intro, intro_f, sizeof(intro_f), 0);          intro_len = lml_render(p_user_info->intro, intro_f, sizeof(intro_f), 0);
109    
110          snprintf(profile_f, sizeof(profile_f),          snprintf(user_info_f, sizeof(user_info_f),
111                           "已选中用户 [%s]\n发帖数:%d\n%s\n%s\n",                           "\n%s (%s) 上站 [%d] 发文 [%d]\n"
112                           p_user_info->username,                           "上次在 [%s] 从 [%s] 访问本站 经验值 [%d]\n"
113                           get_user_article_cnt(p_user_info->uid),                           "离线于 [%s] 等级 [%s]\n"
114                           action_str,                           "%s\033[1m%s\033[m"
115                             "%s\n%s\n",
116                             p_user_info->username, p_user_info->nickname, p_user_info->visit_count, article_cnt,
117                             str_last_login_dt, (session_cnt > 0 ? login_ip : "未知"), p_user_info->exp,
118                             (session_cnt > 0 ? "在线或因断线不详" : str_last_logout_dt), "?",
119                             (session_cnt > 0 ? "目前在线,状态如下:\n" : ""), (session_cnt > 0 ? action_str : ""),
120                             (intro_len > 0 ? "\033[0;36m个人说明档如下:\033[m" : "\033[0;36m没有个人说明档\033[m"),
121                           intro_f);                           intro_f);
122    
123          lines = split_data_lines(profile_f, SCREEN_COLS, line_offsets, MIN(SCREEN_ROWS - 1, BBS_user_intro_max_line + 4), 1, NULL);          lines = split_data_lines(user_info_f, SCREEN_COLS, line_offsets, MIN(SCREEN_ROWS - 1, BBS_user_intro_max_line + 8), 1, NULL);
124    
125          clearscr();          clearscr();
126          display_data(profile_f, lines, line_offsets, 2, display_user_intro_key_handler, DATA_READ_HELP);          display_data(user_info_f, lines, line_offsets, 1, display_user_intro_key_handler, DATA_READ_HELP);
         press_any_key();  
127    
128          return 0;          return 0;
129  }  }


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

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