Starting to separate the increment of SQN into a seperate function.

master
Pedro Alvarez 7 years ago
parent b9c50a93a8
commit 6a32b5b047

@ -102,7 +102,8 @@ private:
std::vector<std::string> split_string(const std::string &str, char delimiter); std::vector<std::string> split_string(const std::string &str, char delimiter);
void get_uint_vec_from_hex_str(const std::string &key_str, uint8_t *key, uint len); void get_uint_vec_from_hex_str(const std::string &key_str, uint8_t *key, uint len);
void increment_sqn(uint64_t imsi); void increment_ue_sqn(uint64_t imsi);
void increment_sqn(uint8_t *sqn, uint8_t *next_sqn);
void set_sqn(uint64_t imsi, uint8_t *sqn); void set_sqn(uint64_t imsi, uint8_t *sqn);
void set_last_rand(uint64_t imsi, uint8_t *rand); void set_last_rand(uint64_t imsi, uint8_t *rand);

@ -140,7 +140,7 @@ bool
hss::read_db_file(std::string db_filename) hss::read_db_file(std::string db_filename)
{ {
std::ifstream m_db_file; std::ifstream m_db_file;
m_db_file.open(db_filename.c_str(), std::ifstream::in); m_db_file.open(db_filename.c_str(), std::ifstream::in);
if(!m_db_file.is_open()) if(!m_db_file.is_open())
{ {
@ -153,11 +153,12 @@ hss::read_db_file(std::string db_filename)
{ {
if(line[0] != '#') if(line[0] != '#')
{ {
std::vector<std::string> split = split_string(line,','); uint column_size = 7;
if(split.size()!=7) std::vector<std::string> split = split_string(line,',');
if(split.size() != column_size)
{ {
m_hss_log->error("Error parsing UE database. Wrong number of columns in .csv\n"); m_hss_log->error("Error parsing UE database. Wrong number of columns in .csv\n");
m_hss_log->error("Columns: %d\n",split.size()); m_hss_log->error("Columns: %lu, Expected %d.\n",split.size(),column_size);
return false; return false;
} }
hss_ue_ctx_t *ue_ctx = new hss_ue_ctx_t; hss_ue_ctx_t *ue_ctx = new hss_ue_ctx_t;
@ -280,7 +281,7 @@ hss::gen_auth_info_answer(uint64_t imsi, uint8_t *k_asme, uint8_t *autn, uint8_t
ret = gen_auth_info_answer_milenage(imsi, k_asme, autn, rand, xres); ret = gen_auth_info_answer_milenage(imsi, k_asme, autn, rand, xres);
break; break;
} }
increment_sqn(imsi); increment_ue_sqn(imsi);
return ret; return ret;
} }
@ -298,7 +299,7 @@ hss::resync_sqn(uint64_t imsi, uint8_t *auts)
ret = resync_sqn_milenage(imsi, auts); ret = resync_sqn_milenage(imsi, auts);
break; break;
} }
increment_sqn(imsi); increment_ue_sqn(imsi);
return ret; return ret;
} }
@ -354,6 +355,7 @@ hss::resync_sqn_milenage(uint64_t imsi, uint8_t *auts)
sqn_ms[i] = sqn_ms_xor_ak[i] ^ ak[i]; sqn_ms[i] = sqn_ms_xor_ak[i] ^ ak[i];
} }
m_hss_log->debug_hex(sqn_ms, 6, "SQN MS : "); m_hss_log->debug_hex(sqn_ms, 6, "SQN MS : ");
m_hss_log->debug_hex(sqn , 6, "SQN HE : ");
m_hss_log->debug_hex(amf, 2, "AMF : "); m_hss_log->debug_hex(amf, 2, "AMF : ");
@ -579,7 +581,7 @@ hss::get_k_amf_opc_sqn(uint64_t imsi, uint8_t *k, uint8_t *amf, uint8_t *opc, ui
} }
void void
hss::increment_sqn(uint64_t imsi) hss::increment_ue_sqn(uint64_t imsi)
{ {
hss_ue_ctx_t *ue_ctx = NULL; hss_ue_ctx_t *ue_ctx = NULL;
bool ret = get_ue_ctx(imsi, &ue_ctx); bool ret = get_ue_ctx(imsi, &ue_ctx);
@ -589,22 +591,39 @@ hss::increment_sqn(uint64_t imsi)
} }
// Awkward 48 bit sqn and doing arithmetic // Awkward 48 bit sqn and doing arithmetic
uint64_t sqn = 0; //uint64_t sqn = 0;
uint8_t *p = (uint8_t *)&sqn; //uint8_t *p = (uint8_t *)&sqn;
//for(int i = 0; i < 6; i++) {
// p[5-i] = (uint8_t) ((ue_ctx->sqn[i]));
//}
//sqn++;
//for(int i = 0; i < 6; i++){
// ue_ctx->sqn[i] = p[5-i];
//}
increment_sqn(ue_ctx->sqn,ue_ctx->sqn);
m_hss_log->debug("Incremented SQN (IMSI: %" PRIu64 ")" PRIu64 "\n", imsi);
m_hss_log->debug_hex(ue_ctx->sqn, 6, "SQN: ");
}
void
hss::increment_sqn(uint8_t *sqn, uint8_t *next_sqn)
{
// Awkward 48 bit sqn and doing arithmetic
uint64_t tmp_sqn = 0;
uint8_t *p = (uint8_t *)&tmp_sqn;
for(int i = 0; i < 6; i++) { for(int i = 0; i < 6; i++) {
p[5-i] = (uint8_t) ((ue_ctx->sqn[i])); p[5-i] = sqn[i];
} }
sqn++; tmp_sqn++;
m_hss_log->debug("Incremented SQN (IMSI: %" PRIu64 ") SQN: %" PRIu64 "\n", imsi, sqn);
for(int i = 0; i < 6; i++){ for(int i = 0; i < 6; i++){
ue_ctx->sqn[i] = p[5-i]; next_sqn[i] = p[5-i];
} }
return;
} }
void void
hss::set_sqn(uint64_t imsi, uint8_t *sqn) hss::set_sqn(uint64_t imsi, uint8_t *sqn)
{ {

Loading…
Cancel
Save