Skip to main content

Suspend / Activate eSIM

Block (suspend) or restore (activate) network access for an eSIM.

eSIMfly packages only

This operation is only available for eSIMfly eSIMs, which expose subscriber-level network control. Calling it for any other provider returns UNSUPPORTED_PROVIDER.

Endpoint

POST /api/v1/business/esims/suspend

Authentication

This endpoint requires HMAC authentication. See Authentication for details.

Request Headers

HeaderTypeRequiredDescription
RT-AccessCodeStringYesYour API access code
RT-RequestIDStringYesUnique request ID (UUID v4)
RT-TimestampStringYesRequest timestamp in milliseconds
RT-SignatureStringYesHMAC-SHA256 signature
Content-TypeStringYesMust be "application/json"

Request Body

FieldTypeRequiredDescription
actionStringYes"suspend" to block network access, or "activate" to restore it
iccidStringYes*The ICCID of the eSIM
esimIdIntegerYes*The eSIM id (used if iccid is not provided)

* Provide either iccid or esimId.

Suspend:

{
"iccid": "8948010010036785060",
"action": "suspend"
}

Activate:

{
"iccid": "8948010010036785060",
"action": "activate"
}

Response

Success Response (200 OK)

Suspend:

{
"success": true,
"message": "eSIM suspended. Network access has been blocked.",
"data": {
"iccid": "8948010010036785060",
"action": "suspend",
"esim_status": "Disconnected"
}
}

Activate:

{
"success": true,
"message": "eSIM activated. Network access has been restored.",
"data": {
"iccid": "8948010010036785060",
"action": "activate",
"esim_status": "Active"
}
}

Response Fields

FieldTypeDescription
successBooleanWhether the status change succeeded
messageStringHuman-readable result
data.iccidStringThe affected eSIM ICCID
data.actionStringThe action performed (suspend / activate)
data.esim_statusStringNew eSIM status (Disconnected when suspended, Active when activated)

Error Responses

400 Bad Request

Invalid action:

{ "success": false, "message": "action must be \"suspend\" or \"activate\"", "code": "INVALID_ACTION" }

Missing identifier:

{ "success": false, "message": "Provide either iccid or esimId", "code": "MISSING_IDENTIFIER" }

Unsupported provider:

{ "success": false, "message": "Suspend/activate is only available for eSIMfly eSIMs", "code": "UNSUPPORTED_PROVIDER" }

404 Not Found

{ "success": false, "message": "eSIM not found", "code": "ESIM_NOT_FOUND" }

Example

const crypto = require('crypto');
const { v4: uuidv4 } = require('uuid');

async function setEsimNetwork(iccid, action) { // action: 'suspend' | 'activate'
const accessCode = 'esf_your_access_code';
const secretKey = 'sk_your_secret_key';

const body = JSON.stringify({ iccid, action });
const timestamp = Date.now().toString();
const requestId = uuidv4();
const signData = timestamp + requestId + accessCode + body;
const signature = crypto.createHmac('sha256', secretKey)
.update(signData)
.digest('hex')
.toUpperCase();

const response = await fetch('https://esimfly.net/api/v1/business/esims/suspend', {
method: 'POST',
headers: {
'RT-AccessCode': accessCode,
'RT-RequestID': requestId,
'RT-Timestamp': timestamp,
'RT-Signature': signature,
'Content-Type': 'application/json'
},
body
});

return response.json();
}

Notes

  • Suspend blocks the eSIM from connecting to any network; activate restores it. The change takes effect on the carrier network shortly after the call succeeds.
  • Suspending does not cancel the eSIM or refund anything — use Cancel eSIM for that.
  • An eSIM can be suspended and re-activated as many times as needed.