There is an inconsistent use of the MAYBE_UNUSED macro. Sometimes the `int unused(x)` form is used form and others the `unused int x`. We'd like to use the second form always. Related-To: https://github.com/shadow-maint/shadow/issues/918 Suggested-by: Alejandro Colomar <alx@kernel.org> Signed-off-by: Pablo Saavedra <psaavedra@igalia.com>
53 lines
908 B
C
53 lines
908 B
C
/*
|
|
* SPDX-FileCopyrightText: 2023, Iker Pedrosa <ipedrosa@redhat.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#include <config.h>
|
|
|
|
#ident "$Id$"
|
|
|
|
#include "attr.h"
|
|
#include "defines.h"
|
|
#include "prototypes.h"
|
|
|
|
#include <systemd/sd-login.h>
|
|
|
|
int get_session_host (char **out)
|
|
{
|
|
char *host = NULL;
|
|
char *session = NULL;
|
|
int ret;
|
|
|
|
ret = sd_pid_get_session (getpid(), &session);
|
|
if (ret < 0) {
|
|
return ret;
|
|
}
|
|
ret = sd_session_get_remote_host (session, &host);
|
|
if (ret < 0) {
|
|
goto done;
|
|
}
|
|
|
|
*out = host;
|
|
|
|
done:
|
|
free (session);
|
|
return ret;
|
|
}
|
|
|
|
unsigned long active_sessions_count(const char *name, MAYBE_UNUSED unsigned long limit)
|
|
{
|
|
struct passwd *pw;
|
|
unsigned long count = 0;
|
|
|
|
pw = prefix_getpwnam(name);
|
|
if (pw == NULL) {
|
|
return 0;
|
|
}
|
|
|
|
count = sd_uid_get_sessions(pw->pw_uid, 0, NULL);
|
|
|
|
return count;
|
|
}
|