Skip to content

Commit

Permalink
Merge pull request #319 from AndyTaylorTweet/master
Browse files Browse the repository at this point in the history
Update DMRAccessControl.cpp
  • Loading branch information
g4klx authored Jul 10, 2017
2 parents 8e9309f + c8e6b3d commit 52775c5
Showing 1 changed file with 10 additions and 7 deletions.
17 changes: 10 additions & 7 deletions DMRAccessControl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@
#include <algorithm>
#include <vector>
#include <cstring>
#include <string>

std::vector<unsigned int> CDMRAccessControl::m_blackList;
std::vector<unsigned int> CDMRAccessControl::m_whiteList;
Expand Down Expand Up @@ -50,12 +49,16 @@ void CDMRAccessControl::init(const std::vector<unsigned int>& blacklist, const s
bool CDMRAccessControl::validateSrcId(unsigned int id)
{
if (m_selfOnly) {
std::string str_id = std::to_string(id); // DMR ID from RF
std::string str_m_id = std::to_string(m_id); // MMDVMHost ID from Config
if ((id == m_id) || (str_m_id.compare(0,7,str_id) == 0)) {// if the RF ID matched the configured ID or if the first 7 digits of the MMDVMHost ID match the WHOLE of the RF ID
return true; // then allow the connection
} else {
return false; // if not, reject it
if (m_id > 9999999) { // Check that the Config DMR-ID is bigger than 7 digits
if ((id == m_id/10) || (id == m_id/100)) { // does RF ID match Config ID / 10 or Config ID / 100
return true;
}
else {
return false;
}
}
else {
return id == m_id; // Origional Method
}
}

Expand Down

0 comments on commit 52775c5

Please sign in to comment.