forked from public/pysim
sysmoISIM-SJA2: Add support for programming Proxy Call Session Control Function address
Example: ./pySim-prog.py -p 0 -x 001 -y 01 -s 8988211900000000004 -i 001011234567895 -k 8baf473f2f8fd09487cccbd7097c6862 --op 11111111111111111111111111111111 -o 8E27B6AF0E692E750F32667A3B14605D -a 85524953 -n isim.test --msisdn 0598765432100 --epdgid epdg.epc.mnc001.mcc001.pub.3gppnetwork.org --pcscf pcscf.testims.org Change-Id: Ic654baa93e2ecb91ced596b49dde4c1f208ecda2
This commit is contained in:
committed by
herlesupreeth
parent
5ad9aec98f
commit
cf727f2733
@@ -153,6 +153,9 @@ def parse_options():
|
|||||||
parser.add_option("--epdgSelection", dest="epdgSelection",
|
parser.add_option("--epdgSelection", dest="epdgSelection",
|
||||||
help="Set PLMN for ePDG Selection Information. (Only Operator Identifier FQDN format supported)",
|
help="Set PLMN for ePDG Selection Information. (Only Operator Identifier FQDN format supported)",
|
||||||
)
|
)
|
||||||
|
parser.add_option("--pcscf", dest="pcscf",
|
||||||
|
help="Set Proxy Call Session Control Function (P-CSCF) Address. (Only FQDN format supported)",
|
||||||
|
)
|
||||||
parser.add_option("--read-imsi", dest="read_imsi", action="store_true",
|
parser.add_option("--read-imsi", dest="read_imsi", action="store_true",
|
||||||
help="Read the IMSI from the CARD", default=False
|
help="Read the IMSI from the CARD", default=False
|
||||||
)
|
)
|
||||||
@@ -460,6 +463,7 @@ def gen_parameters(opts):
|
|||||||
'msisdn' : opts.msisdn,
|
'msisdn' : opts.msisdn,
|
||||||
'epdgid' : opts.epdgid,
|
'epdgid' : opts.epdgid,
|
||||||
'epdgSelection' : opts.epdgSelection,
|
'epdgSelection' : opts.epdgSelection,
|
||||||
|
'pcscf' : opts.pcscf,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -326,6 +326,16 @@ class IsimCard(Card):
|
|||||||
pcscf_recs += "\tP-CSCF: Can't read, response code = %s\n" % (sw)
|
pcscf_recs += "\tP-CSCF: Can't read, response code = %s\n" % (sw)
|
||||||
return pcscf_recs
|
return pcscf_recs
|
||||||
|
|
||||||
|
def update_pcscf(self, pcscf):
|
||||||
|
if len(pcscf) > 0:
|
||||||
|
content = enc_addr_tlv(pcscf)
|
||||||
|
else:
|
||||||
|
# Just the tag value
|
||||||
|
content = '80'
|
||||||
|
rec_size_bytes = self._scc.record_size(EF_ISIM_ADF_map['PCSCF'])
|
||||||
|
data, sw = self._scc.update_record(EF_ISIM_ADF_map['PCSCF'], 1, rpad(content, rec_size_bytes*2))
|
||||||
|
return sw
|
||||||
|
|
||||||
|
|
||||||
class _MagicSimBase(Card):
|
class _MagicSimBase(Card):
|
||||||
"""
|
"""
|
||||||
@@ -1208,6 +1218,16 @@ class SysmoISIMSJA2(UsimCard, IsimCard):
|
|||||||
if p.get('opc'):
|
if p.get('opc'):
|
||||||
self._scc.update_binary('af20', p['opc'], 17)
|
self._scc.update_binary('af20', p['opc'], 17)
|
||||||
|
|
||||||
|
# update EF.P-CSCF in ADF.ISIM
|
||||||
|
if self.file_exists(EF_ISIM_ADF_map['PCSCF']):
|
||||||
|
if p.get('pcscf'):
|
||||||
|
sw = self.update_pcscf(p['pcscf'])
|
||||||
|
else:
|
||||||
|
sw = self.update_pcscf("")
|
||||||
|
if sw != '9000':
|
||||||
|
print("Programming P-CSCF failed with code %s"%sw)
|
||||||
|
|
||||||
|
|
||||||
if '9000' == self.select_adf_by_aid():
|
if '9000' == self.select_adf_by_aid():
|
||||||
# update EF-USIM_AUTH_KEY in ADF.USIM
|
# update EF-USIM_AUTH_KEY in ADF.USIM
|
||||||
if p.get('ki'):
|
if p.get('ki'):
|
||||||
|
|||||||
Reference in New Issue
Block a user