X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/852b085dcef99353ae1bedefbaf654b5b72c9f64..e39f173d25ae650ee843e3d1c311abe9c1cb5ee9:/projects/stargazer/plugins/other/radius/config.h diff --git a/projects/stargazer/plugins/other/radius/config.h b/projects/stargazer/plugins/other/radius/config.h index 45ee521f..44d5ed85 100644 --- a/projects/stargazer/plugins/other/radius/config.h +++ b/projects/stargazer/plugins/other/radius/config.h @@ -28,6 +28,11 @@ #include #include +#include // uid_t, gid_t +#include // mode_t + +class USER; + namespace STG { @@ -36,15 +41,42 @@ struct Config typedef std::map Pairs; typedef std::pair Pair; enum Type { UNIX, TCP }; + enum ReturnCode + { + REJECT, // Reject the request immediately. + FAIL, // Module failed. + OK, // Module is OK, continue. + HANDLED, // The request is handled, no further handling. + INVALID, // The request is invalud. + USERLOCK, // Reject the request, user is locked. + NOTFOUND, // User not found. + NOOP, // Module performed no action. + UPDATED // Module sends some updates. + }; + + class Authorize + { + public: + Authorize() : m_auth(false) {} + Authorize(const Pairs& cond) : m_auth(true), m_cond(cond) {} + + bool check(const USER& user, const Pairs& radiusData) const; + bool exists() const { return m_auth; } + private: + bool m_auth; + Pairs m_cond; + }; struct Section { Section() {} - Section(const Pairs& ma, const Pairs& mo, const Pairs& re) - : match(ma), modify(mo), reply(re) {} + Section(const Pairs& ma, const Pairs& mo, const Pairs& re, ReturnCode code, const Authorize& auth) + : match(ma), modify(mo), reply(re), returnCode(code), authorize(auth) {} Pairs match; Pairs modify; Pairs reply; + ReturnCode returnCode; + Authorize authorize; }; Config() {} @@ -59,11 +91,15 @@ struct Config bool verbose; std::string address; - std::string bindAddress; Type connectionType; + std::string bindAddress; std::string portStr; uint16_t port; std::string key; + + uid_t sockUID; + gid_t sockGID; + mode_t sockMode; }; } // namespace STG