Small tools to help out with provisioning before and during production of your SoftSIM enabled device.
Provisioning is split in two distinct steps:
- Pre-production: Fetch
n
profiles from the Onomondo API to avoid excessive load on API and to remove any dependencies on stable internet. The profiles are encrypted using your public key. - During production: Continuously get a new unique profile correctly formatted to specifications.
These steps correspond one-to-one with the available commands in the CLI tool.
This command fetches the specified number of profiles from the Onomondo API. Use the SoftSIM API generated in our platform to get access.
This command finds the next unused profile on your local system. The profile is decrypted using the private key pointed to by the --key
argument. After decryption and encoding the file is prepended with __
to invalidate the profile.
Pre-built binaries can be found under releases.
It is optional to build the project from source. See the build section below.
To generate a SoftSIM API key you will also need a key pair. Use 4096 bit keys.
To generate a key pair:
ssh-keygen -t rsa -m PEM -b 4096 -f <path_to_new_key>
The Onomondo SoftSIM CLI tool is not supporting keys, that are protected by password.
The public key is expected to be PEM encoded:
-----BEGIN PUBLIC KEY-----
.....
-----END PUBLIC KEY-----
This can be obtained with:
ssh-keygen -e -m PKCS8 -f <path_to_public_key>.pub
Use the public key to create an API key on https://app.onomondo.com/api-keys/softsim/new
For testing https://cryptotools.net/rsagen can be helpful to quickly get started.
Usage: softsim [OPTIONS] <COMMAND>
Commands:
fetch
Fetch profiles from API
next
Find next available profile. Decrypt and decode the profile and mark it as used
help
Print this message or the help of the given subcommand(s)
Options:
-v, --verbosity...
Verbosity level
-h, --help
Print help
-V, --version
Print version
Set log level to TRACE
softsim -vvv ---help
Pulls profiles from api.onomondo.com and writes to disk. Specify count
to fetch many for production usage. softsim
breaks the count into batches of max. 1000.
Usage: softsim fetch [OPTIONS] --api-key <API_KEY>
Options:
-a, --api-key <API_KEY>
-n, --count <NUM_OF_PROFILES>
[default: 1]
-o, --out <OUTPUT>
[default: profiles]
-u, --url <url>
[default: https://api.onomondo.com/sims/profiles]
-h, --help
Print help
Get 5678 profiles and store under ./profile/
:
softsim fetch -a <your_api_key> -n 5678
Specify output path:
softsim fetch -a <your_api_key> -n 5678 -o "batch1"
Find the next available profile and outputs decrypted and decoded values. Specify format
to change encoding.
HEX
- suitable for SoftSIM integrations made by Onomondo.
JSON
- outputs RAW profile and relevant meta information.
Usage: softsim next [OPTIONS] --key <KEY>
Options:
-k, --key <KEY>
Path to private key
-i, --in <SET_OF_PROFILES>
Path to encrypted profiles [default: ./profiles]
--format[=<FORMAT>]
Output format [default: hex] [possible values: hex, json]
-h, --help
Print help
The SoftSIM profile will be represented in the following format when fetched from Onomondo. The SoftSIM is encrypted in this format.
{"iccid":"89457300000000000000","profile":"gwixsycJq295xfHxOvwjiNwj8feRHeDwIUsR8xhTBej31CxUKc9Axw1LGffdaIMGlBMx2XxGO1M7ZJHqG4kKcypmIc19vn8Iu4vthoxzRtMavTk+w+0yp1dZbZdhnsDZd96Zt3upKPXTNFoG+m8BOwmBR5lGlzdCuJytvHpPV5WcyL0Tdy5K2zyhZh2V9j+DhwrVrVyciJeWWRUzDSScaS+VhhrSo0EtsrfVamIJDv4XtWrseVnn6fh1ArlftTNbMcC/qpT/Q2UGc4lyVaDKjqZeFYoUR6cmVhlK55gRL+kPJ6qYUsbtgh1rcqjrs4S6xpIJnCgvR2wVpFJqGOhnyEtFFw5CgKvZol0ixNn6IPOyMyPHzyUe7UuyyFUPk5kDR29vjb+hZN1hh354lEOwMOpMFYBVt2Ug66Zs5eATVC5Vv7QdOsyTgOqvINmPUDvIwfTFMiG3t7rWXs7wFJKYLiU764rTGrTjS1yTzFIGpEqkze68b9Ehx6APB0KVeUQM2UB2439VUlcZ2CAwN+qvsycPfBlX1iIN2vjG7ZUWi0SQ9jrOA1xEvgBgqa1EDkkv5j1usEtm3Zu5EvZlsLbMdmai2GWX0p99BFf2WpwqPI4FMflntefZ9RdzPPc4XWp1PCBUfMDMCyeqJEb34aGAtASt+DlKLlXmcYczkQoe5mM="}
Following a successful decryption and formatting of the encrypted SoftSIM profile, the CLI tool will export the profile in the following format. It is this and only this format that is accepted by SoftSIM enabled devices.
01120809101010325406360214980010325476981032140320000000000000000000000000000000000420000102030405060708090A0B0C0D0E0F0520000102030405060708090A0B0C0D0E0F0620000102030405060708090A0B0C0D0E0F
Write hex encoded profiles to stdout. Optionally, this can be piped directly to a device, if the device is ready to receive a profile in this specific format.
--key
should point to the private key generated in the previous steps.
softsim next --key <path_to_private_key>
Specify format to json
softsim next --key resources/test/key --format=json
softsim next
can be called from manufacturing scripts as needed.
cargo build --release
After building the SoftSIM executable is located in: target/release/softsim
cargo test
In the scenario of simulating profiles:
hyperfine --runs 1000 --warmup=1 --shell=none './target/release/softsim next --key resources/test/key'
Benchmark 1: ./target/release/softsim next --key resources/test/key
Time (mean ± σ): 3.0 ms ± 0.8 ms [User: 1.5 ms, System: 1.5 ms]
Range (min … max): 2.4 ms … 24.4 ms 1000 runs
This should perform well on the standard production line but can lead to issues when you encounter a threshold of a million profiles.
npm install --save-dev @commitlint/{cli,config-conventional}
npx husky install