You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
/*
|
|
|
|
*
|
|
|
|
* This file is part of the KDE project, module tdesu.
|
|
|
|
* Copyright (C) 1999,2000 Geert Jansen <jansen@kde.org>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __Secure_h_included__
|
|
|
|
#define __Secure_h_included__
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
|
|
|
|
#ifndef HAVE_STRUCT_UCRED
|
|
|
|
|
|
|
|
// `struct ucred' is not defined in glibc 2.0.
|
|
|
|
|
|
|
|
struct ucred {
|
|
|
|
pid_t pid;
|
|
|
|
uid_t uid;
|
|
|
|
gid_t gid;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // HAVE_STRUCT_UCRED
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Socket_security class autheticates the peer for you. It provides
|
|
|
|
* the process-id, user-id and group-id plus the MD5 sum of the connected
|
|
|
|
* binary.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class SocketSecurity {
|
|
|
|
public:
|
|
|
|
SocketSecurity(int fd);
|
|
|
|
|
|
|
|
/** Returns the peer's process-id. */
|
|
|
|
int peerPid() { if (!ok) return -1; return cred.pid; }
|
|
|
|
|
|
|
|
/** Returns the peer's user-id */
|
|
|
|
int peerUid() { if (!ok) return -1; return cred.uid; }
|
|
|
|
|
|
|
|
/** Returns the peer's group-id */
|
|
|
|
int peerGid() { if (!ok) return -1; return cred.gid; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool ok;
|
|
|
|
struct ucred cred;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|