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

Annotation of /lbbs/src/user_info_display.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.26 - (hide annotations)
Fri Dec 19 06:16:27 2025 UTC (2 months, 3 weeks ago) by sysadm
Branch: MAIN
Changes since 1.25: +3 -3 lines
Content type: text/x-csrc
Append \n to the end of logging message by log_...()
Remove ending \n from each logging message

1 sysadm 1.19 /* SPDX-License-Identifier: GPL-3.0-or-later */
2     /*
3     * user_list_display
4     * - display user information
5     *
6 sysadm 1.20 * Copyright (C) 2004-2025 Leaflet <leaflet@leafok.com>
7 sysadm 1.19 */
8 sysadm 1.1
9 sysadm 1.23 #ifdef HAVE_CONFIG_H
10     #include "config.h"
11     #endif
12    
13 sysadm 1.11 #include "bbs.h"
14 sysadm 1.2 #include "ip_mask.h"
15 sysadm 1.1 #include "lml.h"
16     #include "log.h"
17     #include "screen.h"
18     #include "str_process.h"
19     #include "user_list.h"
20     #include "user_info_display.h"
21 sysadm 1.2 #include "user_priv.h"
22 sysadm 1.6 #include <ctype.h>
23 sysadm 1.1 #include <string.h>
24 sysadm 1.2 #include <time.h>
25 sysadm 1.1 #include <sys/param.h>
26    
27 sysadm 1.21 enum _user_info_display_constant_t
28     {
29     BBS_max_sessions_per_user = 10,
30     LAST_LOGIN_DT_MAX_LEN = 50,
31 sysadm 1.24 ASTRO_STR_MAX_LEN = 64,
32     USER_INFO_MAX_LEN = 8192,
33 sysadm 1.21 };
34 sysadm 1.1
35 sysadm 1.4 static int display_user_info_key_handler(int *p_key, DISPLAY_CTX *p_ctx)
36 sysadm 1.1 {
37     return 0;
38     }
39    
40     int user_info_display(USER_INFO *p_user_info)
41     {
42     USER_ONLINE_INFO sessions[BBS_max_sessions_per_user];
43     int session_cnt = BBS_max_sessions_per_user;
44 sysadm 1.2 int article_cnt;
45 sysadm 1.5 const char *astro_name;
46 sysadm 1.24 char astro_str[ASTRO_STR_MAX_LEN];
47 sysadm 1.2 struct tm tm_last_login;
48     char str_last_login_dt[LAST_LOGIN_DT_MAX_LEN + 1];
49     struct tm tm_last_logout;
50     char str_last_logout_dt[LAST_LOGIN_DT_MAX_LEN + 1];
51     char login_ip[IP_ADDR_LEN];
52     int ip_mask_level;
53 sysadm 1.9 const char *p_action_title;
54 sysadm 1.1 char action_str[LINE_BUFFER_LEN];
55 sysadm 1.13 int life;
56     int user_level;
57 sysadm 1.7 const char *user_level_name;
58 sysadm 1.18 char intro_f[BBS_user_intro_max_len + 1];
59 sysadm 1.2 int intro_len;
60 sysadm 1.24 char user_info_f[USER_INFO_MAX_LEN];
61 sysadm 1.2 long line_offsets[BBS_user_intro_max_line + 1];
62     long lines;
63 sysadm 1.1 char *p;
64 sysadm 1.2 const char *q;
65 sysadm 1.1 int ret;
66     int i;
67    
68 sysadm 1.14 if (p_user_info == NULL)
69     {
70 sysadm 1.26 log_error("NULL pointer error");
71 sysadm 1.14 return -1;
72     }
73    
74 sysadm 1.2 article_cnt = get_user_article_cnt(p_user_info->uid);
75    
76 sysadm 1.5 astro_name = get_astro_name(p_user_info->birthday);
77     if (p_user_info->gender_pub && toupper(p_user_info->gender) == 'M')
78     {
79     snprintf(astro_str, sizeof(astro_str),
80     "\033[1;36m%s座\033[m",
81     astro_name);
82     }
83     else if (p_user_info->gender_pub && toupper(p_user_info->gender) == 'F')
84     {
85     snprintf(astro_str, sizeof(astro_str),
86     "\033[1;35m%s座\033[m",
87     astro_name);
88     }
89     else
90     {
91     snprintf(astro_str, sizeof(astro_str),
92     "\033[1;33m%s座\033[m",
93     astro_name);
94     }
95    
96 sysadm 1.2 localtime_r(&(p_user_info->last_login_dt), &tm_last_login);
97 sysadm 1.12 strftime(str_last_login_dt, sizeof(str_last_login_dt), "%F %H:%M", &tm_last_login);
98 sysadm 1.4 if (p_user_info->last_logout_dt <= p_user_info->last_login_dt)
99 sysadm 1.3 {
100     strncpy(str_last_logout_dt, str_last_login_dt, sizeof(str_last_logout_dt) - 1);
101     str_last_logout_dt[sizeof(str_last_logout_dt) - 1] = '\0';
102     }
103     else
104     {
105     localtime_r(&(p_user_info->last_logout_dt), &tm_last_logout);
106 sysadm 1.12 strftime(str_last_logout_dt, sizeof(str_last_logout_dt), "%F %H:%M", &tm_last_logout);
107 sysadm 1.3 }
108 sysadm 1.2
109 sysadm 1.1 action_str[0] = '\0';
110    
111     ret = query_user_online_info_by_uid(p_user_info->uid, sessions, &session_cnt, 0);
112     if (ret < 0)
113     {
114 sysadm 1.26 log_error("query_user_online_info_by_uid(uid=%d, cnt=%d) error: %d",
115 sysadm 1.1 p_user_info->uid, session_cnt, ret);
116 sysadm 1.2 session_cnt = 0;
117 sysadm 1.1 }
118 sysadm 1.2
119     p = action_str;
120     for (i = 0; i < session_cnt; i++)
121 sysadm 1.1 {
122 sysadm 1.9 p_action_title = (sessions[i].current_action_title != NULL
123     ? sessions[i].current_action_title
124     : sessions[i].current_action);
125    
126     if (p + strlen(p_action_title) + 4 >= action_str + sizeof(action_str)) // buffer overflow
127 sysadm 1.2 {
128 sysadm 1.26 log_error("action_str of user(uid=%d) truncated at i=%d", p_user_info->uid, i);
129 sysadm 1.2 break;
130     }
131     *p++ = '[';
132 sysadm 1.9 for (q = p_action_title; *q != '\0';)
133 sysadm 1.1 {
134 sysadm 1.2 *p++ = *q++;
135 sysadm 1.1 }
136 sysadm 1.2 *p++ = ']';
137     *p++ = ' ';
138 sysadm 1.1 }
139 sysadm 1.2 *p++ = '\n';
140     *p = '\0';
141 sysadm 1.1
142 sysadm 1.2 if (session_cnt > 0)
143     {
144     strncpy(login_ip, sessions[0].ip, sizeof(login_ip) - 1);
145     login_ip[sizeof(login_ip) - 1] = '\0';
146    
147     ip_mask_level = checklevel(&BBS_priv, P_ADMIN_M | P_ADMIN_S);
148     ip_mask(login_ip, (ip_mask_level ? 1 : 2), '*');
149     }
150     else
151     {
152     login_ip[0] = '\0';
153     }
154 sysadm 1.1
155 sysadm 1.13 if (p_user_info->life == 333 || p_user_info->life == 365 || p_user_info->life == 666 || p_user_info->life == 999) // Immortal
156     {
157     life = p_user_info->life;
158     }
159     else
160     {
161     life = p_user_info->life - (int)((time(NULL) - p_user_info->last_login_dt) / 86400 + 1);
162     }
163    
164     user_level = get_user_level(p_user_info->exp);
165     user_level_name = get_user_level_name(user_level);
166 sysadm 1.7
167 sysadm 1.17 intro_len = lml_render(p_user_info->intro, intro_f, sizeof(intro_f), SCREEN_COLS, 0);
168 sysadm 1.1
169 sysadm 1.2 snprintf(user_info_f, sizeof(user_info_f),
170     "\n%s (%s) 上站 [%d] 发文 [%d]\n"
171     "上次在 [%s] 从 [%s] 访问本站 经验值 [%d]\n"
172 sysadm 1.13 "离线于 [%s] 生命 [%d] 等级 [%s(%d)] 星座 [%s]\n"
173 sysadm 1.2 "%s\033[1m%s\033[m"
174     "%s\n%s\n",
175     p_user_info->username, p_user_info->nickname, p_user_info->visit_count, article_cnt,
176     str_last_login_dt, (session_cnt > 0 ? login_ip : "未知"), p_user_info->exp,
177 sysadm 1.13 (session_cnt > 0 ? "在线或因断线不详" : str_last_logout_dt), life, user_level_name, user_level + 1, astro_str,
178 sysadm 1.22 (session_cnt > 0 ? "目前在线,状态如下: \n" : ""), (session_cnt > 0 ? action_str : ""),
179     (intro_len > 0 ? "\033[0;36m个人说明档如下: \033[m" : "\033[0;36m没有个人说明档\033[m"),
180 sysadm 1.1 intro_f);
181    
182 sysadm 1.25 lines = split_data_lines(user_info_f, SCREEN_COLS + 1, line_offsets, MIN(SCREEN_ROWS - 1, BBS_user_intro_max_line + 9), 1, NULL);
183 sysadm 1.1
184     clearscr();
185 sysadm 1.4 display_data(user_info_f, lines, line_offsets, 1, display_user_info_key_handler, DATA_READ_HELP);
186 sysadm 1.1
187     return 0;
188     }

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