mirror of
https://github.com/Telecominfraproject/wlan-cloud-ucentralgw.git
synced 2025-11-02 03:37:57 +00:00
Signed-off-by: stephb9959 <stephane.bourque@gmail.com>
This commit is contained in:
@@ -98,7 +98,7 @@ namespace OpenWifi {
|
||||
void RADIUSSessionTracker::ProcessAuthenticationSession([[maybe_unused]] OpenWifi::SessionNotification &Notification) {
|
||||
std::lock_guard Guard(Mutex_);
|
||||
|
||||
std::string CallingStationId, AccountingSessionId, AccountingMultiSessionId, UserName, ChargeableUserIdentity, Interface;
|
||||
std::string CallingStationId, AccountingSessionId, AccountingMultiSessionId, UserName, ChargeableUserIdentity, Interface, nasId;
|
||||
for (const auto &attribute : Notification.Packet_.Attrs_) {
|
||||
switch (attribute.type) {
|
||||
case RADIUS::Attributes::AUTH_USERNAME: {
|
||||
@@ -126,6 +126,11 @@ namespace OpenWifi {
|
||||
&Notification.Packet_.P_.attributes[attribute.pos],
|
||||
&Notification.Packet_.P_.attributes[attribute.pos + attribute.len]);
|
||||
} break;
|
||||
case RADIUS::Attributes::NAS_IDENTIFIER:{
|
||||
nasId.assign(
|
||||
&Notification.Packet_.P_.attributes[attribute.pos],
|
||||
&Notification.Packet_.P_.attributes[attribute.pos + attribute.len]);
|
||||
} break;
|
||||
case RADIUS::Attributes::PROXY_STATE: {
|
||||
std::string Tmp;
|
||||
Tmp.assign(
|
||||
@@ -148,7 +153,7 @@ namespace OpenWifi {
|
||||
ap_hint = AccountingSessions_.find(Notification.SerialNumber_);
|
||||
}
|
||||
|
||||
auto Index = CallingStationId + AccountingSessionId; // +AccountingMultiSessionId;
|
||||
auto Index = CallingStationId; // + AccountingSessionId; // +AccountingMultiSessionId;
|
||||
auto session_hint = ap_hint->second.find(Index);
|
||||
if(session_hint==end(ap_hint->second)) {
|
||||
auto NewSession = std::make_shared<GWObjects::RADIUSSession>();
|
||||
@@ -160,6 +165,7 @@ namespace OpenWifi {
|
||||
NewSession->accountingMultiSessionId = AccountingMultiSessionId;
|
||||
NewSession->chargeableUserIdentity = ChargeableUserIdentity;
|
||||
NewSession->interface = Interface;
|
||||
NewSession->nasId = nasId;
|
||||
NewSession->secret = Notification.Secret_;
|
||||
ap_hint->second[Index] = NewSession;
|
||||
} else {
|
||||
@@ -172,6 +178,12 @@ namespace OpenWifi {
|
||||
return (buf[0] << 24) + (buf[1] << 16) + (buf[2] << 8) + (buf[3] << 0);
|
||||
}
|
||||
|
||||
/*
|
||||
std::string RADIUSSessionTracker::ComputeSessionIndex(OpenWifi::RADIUSSessionPtr S) {
|
||||
return "";
|
||||
}
|
||||
*/
|
||||
|
||||
void
|
||||
RADIUSSessionTracker::ProcessAccountingSession(OpenWifi::SessionNotification &Notification) {
|
||||
std::lock_guard Guard(Mutex_);
|
||||
@@ -246,7 +258,7 @@ namespace OpenWifi {
|
||||
}
|
||||
}
|
||||
|
||||
auto Index = CallingStationId + AccountingSessionId; // +AccountingMultiSessionId;
|
||||
auto Index = CallingStationId; // + AccountingSessionId; // +AccountingMultiSessionId;
|
||||
auto ap_hint = AccountingSessions_.find(Notification.SerialNumber_);
|
||||
if(ap_hint==end(AccountingSessions_)) {
|
||||
SessionMap M;
|
||||
@@ -254,7 +266,7 @@ namespace OpenWifi {
|
||||
ap_hint = AccountingSessions_.find(Notification.SerialNumber_);
|
||||
}
|
||||
|
||||
auto session_hint = ap_hint->second.find(Notification.SerialNumber_);
|
||||
auto session_hint = ap_hint->second.find(Index);
|
||||
if(session_hint==end(ap_hint->second)) {
|
||||
// find the calling_station_id
|
||||
// if we are getting a stop for something we do not know, nothing to do...
|
||||
@@ -335,6 +347,8 @@ namespace OpenWifi {
|
||||
P.AppendAttribute(RADIUS::Attributes::ACCT_MULTI_SESSION_ID, session->accountingMultiSessionId);
|
||||
if(!session->chargeableUserIdentity.empty())
|
||||
P.AppendAttribute(RADIUS::Attributes::CHARGEABLE_USER_IDENTITY, session->chargeableUserIdentity);
|
||||
if(!session->nasId.empty())
|
||||
P.AppendAttribute(RADIUS::Attributes::NAS_IDENTIFIER, session->nasId);
|
||||
auto ProxyState = session->serialNumber + ":" + "0.0.0.0" + ":" + "3799" + ":" + session->interface;
|
||||
std::cout << "Proxy state: " << ProxyState << " Secret: " << session->secret << std::endl;
|
||||
// P.AppendAttribute(RADIUS::PROXY_STATE, ProxyState);
|
||||
|
||||
@@ -197,6 +197,8 @@ namespace OpenWifi {
|
||||
|
||||
RADIUSSessionTracker() noexcept
|
||||
: SubSystemServer("RADIUSSessionTracker", "RADIUS-SESSION", "radius.session") {}
|
||||
|
||||
std::string ComputeSessionIndex(RADIUSSessionPtr S);
|
||||
};
|
||||
|
||||
inline auto RADIUSSessionTracker() { return RADIUSSessionTracker::instance(); }
|
||||
|
||||
@@ -630,6 +630,7 @@ namespace OpenWifi::GWObjects {
|
||||
field_to_json(Obj, "chargeableUserIdentity", chargeableUserIdentity);
|
||||
field_to_json(Obj, "interface", interface);
|
||||
field_to_json(Obj, "secret", secret);
|
||||
field_to_json(Obj, "nasId", nasId);
|
||||
}
|
||||
|
||||
void RADIUSSessionList::to_json(Poco::JSON::Object &Obj) const {
|
||||
|
||||
@@ -393,7 +393,8 @@ namespace OpenWifi::GWObjects {
|
||||
callingStationId,
|
||||
chargeableUserIdentity,
|
||||
secret,
|
||||
interface;
|
||||
interface,
|
||||
nasId;
|
||||
std::uint64_t inputPackets = 0,
|
||||
outputPackets = 0,
|
||||
inputOctets = 0,
|
||||
|
||||
Reference in New Issue
Block a user