python libraires and command line tools for SIM/UICC/USIM/ISIM card analysis and programming. https://osmocom.org/projects/pysim
Go to file
Harald Welte 46bc6d25d6 HACK: support for SIM factory file formats
Change-Id: I23cd37fc06b6e2d21964fd4f2694d9ee3c6012d4
2020-09-15 10:47:45 +02:00
contrib Add support for automatic card handling 2019-09-12 11:21:47 +02:00
pySim fix 'TabError: inconsistent use of tabs and spaces in indentation' 2020-08-31 15:05:14 +02:00
pysim-testdata Add support for ADF_USIM/EF_EHPLMN 2020-08-28 08:32:55 +00:00
tests pySim-prog, pySim-read, do not echo reader id 2020-05-12 18:11:38 +00:00
.gitignore Add README, COPYING, .gitignor 2009-12-27 09:43:51 +01:00
.gitreview add .gitreview 2018-07-19 23:51:00 +02:00
COPYING Add README, COPYING, .gitignor 2009-12-27 09:43:51 +01:00
README.md Fix compatibility with Python 3: print() is a function 2020-02-14 22:46:38 +07:00
csv-format pySim-prog: Use CSV format with headers 2019-09-03 20:11:48 +02:00
execute_ipr.py HACK: support for SIM factory file formats 2020-09-15 10:47:45 +02:00
format_ipr.py HACK: support for SIM factory file formats 2020-09-15 10:47:45 +02:00
format_ldr.py HACK: support for SIM factory file formats 2020-09-15 10:47:45 +02:00
ldr_to_ipr.py HACK: support for SIM factory file formats 2020-09-15 10:47:45 +02:00
pySim-prog.py Implement Generic SIM Access interface as per 3GPP TS 27.007 2020-06-02 21:51:07 +07:00
pySim-read.py Add support for ADF_USIM/EF_EHPLMN 2020-08-28 08:32:55 +00:00
script_format.py HACK: support for SIM factory file formats 2020-09-15 10:47:45 +02:00

README.md

pySim-prog - Utility for programmable SIM/USIM-Cards

This repository contains a Python-language program that can be used to program (write) certain fields/parameters on so-called programmable SIM/USIM cards.

Such SIM/USIM cards are special cards, which - unlike those issued by regular commercial operators - come with the kind of keys that allow you to write the files/fields that normally only an operator can program.

This is useful particularly if you are running your own cellular network, and want to issue your own SIM/USIM cards for that network.

Homepage

The official homepage of the project is http://osmocom.org/projects/pysim/wiki

GIT Repository

You can clone from the official libosmocore.git repository using

git clone git://git.osmocom.org/pysim.git

There is a cgit interface at http://git.osmocom.org/pysim/

Dependencies

pysim requires:

  • pyscard
  • serial
  • pytlv (for specific card types)

Example for Debian:

apt-get install python-pyscard python-serial python-pip
pip install pytlv

Mailing List

There is no separate mailing list for this project. However, discussions related to pysim-prog are happening on the openbsc@lists.osmocom.org mailing list, please see https://lists.osmocom.org/mailman/listinfo/openbsc for subscription options and the list archive.

Please observe the Osmocom Mailing List Rules when posting.

Contributing

Our coding standards are described at https://osmocom.org/projects/cellular-infrastructure/wiki/Coding_standards

We are currently accepting patches by e-mail to the above-mentioned mailing list.

Usage

  • Program customizable SIMs. Two modes are possible:
  • one where you specify every parameter manually :

./pySim-prog.py -n 26C3 -c 49 -x 262 -y 42 -i -s

  • one where they are generated from some minimal set :

./pySim-prog.py -n 26C3 -c 49 -x 262 -y 42 -z <random_string_of_choice> -j <card_num>

With <random_string_of_choice> and <card_num>, the soft will generate
'predictable' IMSI and ICCID, so make sure you choose them so as not to
conflict with anyone. (for eg. your name as <random_string_of_choice> and
0 1 2 ... for <card num>).

You also need to enter some parameters to select the device : -t TYPE : type of card (supersim, magicsim, fakemagicsim or try 'auto') -d DEV : Serial port device (default /dev/ttyUSB0) -b BAUD : Baudrate (default 9600)

  • Interact with SIMs from a python interactive shell (ipython for eg :)

from pySim.transport.serial import SerialSimLink from pySim.commands import SimCardCommands

sl = SerialSimLink(device='/dev/ttyUSB0', baudrate=9600) sc = SimCardCommands(sl)

sl.wait_for_card()

# Print IMSI

print(sc.read_binary(['3f00', '7f20', '6f07']))

# Run A3/A8

print(sc.run_gsm('00112233445566778899aabbccddeeff'))