Client: move trivial functions into the Client class

This commit is contained in:
Max Kellermann 2013-10-19 19:39:40 +02:00
parent 32645b80c4
commit c2d5ce0ca2
5 changed files with 31 additions and 50 deletions

View File

@ -182,7 +182,7 @@ static enum command_return
handle_commands(Client &client, handle_commands(Client &client,
gcc_unused int argc, gcc_unused char *argv[]) gcc_unused int argc, gcc_unused char *argv[])
{ {
const unsigned permission = client_get_permission(client); const unsigned permission = client.GetPermission();
const struct command *cmd; const struct command *cmd;
for (unsigned i = 0; i < num_commands; ++i) { for (unsigned i = 0; i < num_commands; ++i) {
@ -200,7 +200,7 @@ static enum command_return
handle_not_commands(Client &client, handle_not_commands(Client &client,
gcc_unused int argc, gcc_unused char *argv[]) gcc_unused int argc, gcc_unused char *argv[])
{ {
const unsigned permission = client_get_permission(client); const unsigned permission = client.GetPermission();
const struct command *cmd; const struct command *cmd;
for (unsigned i = 0; i < num_commands; ++i) { for (unsigned i = 0; i < num_commands; ++i) {
@ -364,7 +364,7 @@ command_process(Client &client, unsigned num, char *line)
/* look up and invoke the command handler */ /* look up and invoke the command handler */
cmd = command_checked_lookup(client, client_get_permission(client), cmd = command_checked_lookup(client, client.GetPermission(),
argc, argv); argc, argv);
if (cmd) if (cmd)
ret = cmd->handler(client, argc, argv); ret = cmd->handler(client, argc, argv);

View File

@ -22,21 +22,3 @@
#include "util/Domain.hxx" #include "util/Domain.hxx"
const Domain client_domain("client"); const Domain client_domain("client");
int
client_get_uid(const Client &client)
{
return client.uid;
}
unsigned
client_get_permission(const Client &client)
{
return client.permission;
}
void
client_set_permission(Client &client, unsigned permission)
{
client.permission = permission;
}

View File

@ -101,6 +101,30 @@ public:
using FullyBufferedSocket::Write; using FullyBufferedSocket::Write;
/**
* returns the uid of the client process, or a negative value
* if the uid is unknown
*/
int GetUID() const {
return uid;
}
/**
* Is this client running on the same machine, connected with
* a local (UNIX domain) socket?
*/
bool IsLocal() const {
return uid > 0;
}
unsigned GetPermission() const {
return permission;
}
void SetPermission(unsigned _permission) {
permission = _permission;
}
/** /**
* Send "idle" response to this client. * Send "idle" response to this client.
*/ */
@ -124,31 +148,6 @@ void
client_new(EventLoop &loop, Partition &partition, client_new(EventLoop &loop, Partition &partition,
int fd, const struct sockaddr *sa, size_t sa_length, int uid); int fd, const struct sockaddr *sa, size_t sa_length, int uid);
/**
* returns the uid of the client process, or a negative value if the
* uid is unknown
*/
gcc_pure
int
client_get_uid(const Client &client);
/**
* Is this client running on the same machine, connected with a local
* (UNIX domain) socket?
*/
gcc_pure
static inline bool
client_is_local(const Client &client)
{
return client_get_uid(client) > 0;
}
gcc_pure
unsigned
client_get_permission(const Client &client);
void client_set_permission(Client &client, unsigned permission);
/** /**
* Write a C string to the client. * Write a C string to the client.
*/ */

View File

@ -41,7 +41,7 @@ client_allow_file(const Client &client, Path path_fs, Error &error)
error.Set(ack_domain, ACK_ERROR_PERMISSION, "Access denied"); error.Set(ack_domain, ACK_ERROR_PERMISSION, "Access denied");
return false; return false;
#else #else
const int uid = client_get_uid(client); const int uid = client.GetUID();
if (uid >= 0 && (uid_t)uid == geteuid()) if (uid >= 0 && (uid_t)uid == geteuid())
/* always allow access if user runs his own MPD /* always allow access if user runs his own MPD
instance */ instance */

View File

@ -67,7 +67,7 @@ enum command_return
handle_urlhandlers(Client &client, handle_urlhandlers(Client &client,
gcc_unused int argc, gcc_unused char *argv[]) gcc_unused int argc, gcc_unused char *argv[])
{ {
if (client_is_local(client)) if (client.IsLocal())
client_puts(client, "handler: file://\n"); client_puts(client, "handler: file://\n");
print_supported_uri_schemes(client); print_supported_uri_schemes(client);
return COMMAND_RETURN_OK; return COMMAND_RETURN_OK;
@ -262,7 +262,7 @@ handle_password(Client &client, gcc_unused int argc, char *argv[])
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
client_set_permission(client, permission); client.SetPermission(permission);
return COMMAND_RETURN_OK; return COMMAND_RETURN_OK;
} }
@ -271,7 +271,7 @@ enum command_return
handle_config(Client &client, handle_config(Client &client,
gcc_unused int argc, gcc_unused char *argv[]) gcc_unused int argc, gcc_unused char *argv[])
{ {
if (!client_is_local(client)) { if (!client.IsLocal()) {
command_error(client, ACK_ERROR_PERMISSION, command_error(client, ACK_ERROR_PERMISSION,
"Command only permitted to local clients"); "Command only permitted to local clients");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;