Authnfactor Configs
Authnfactor Config APIs for ID360, to manage authnfactor configurations in your account.
Attribute
- EmailAuthenticator
- FIDOAuthenticator
- GoogleAuthenticator
- MicrosoftAuthenticator
- ZohoOneAuthAuthenticator
- CustomTOTPAuthenticator
- SMSAuthenticator
- DUOAuthenticator
- SmartCardAuthenticator
- SQAAuthenticator
- SAMLAuthenticator
- info
- warning
- critical
- CertificateExpiringSoon
- CertificateExpired
- all_allowed
- blacklist
- whitelist
- all_allowed
- blacklist
- whitelist
- attribute
- naming_format
- totp
- hotp
- software
- hardware
- SHA1
- SHA256
- SHA512
- 10
- 15
- 20
- 25
- 30
- 35
- 40
- 45
- 50
- 55
- 60
- all
- platform
- cross_platform
- discouraged
- preferred
- required
- okta
- rsa cloud
- onelogin
- adfs
- line works
- custom saml
- attribute
- naming_format
- self_signed
- ca_signed
Note: The file should be in .cer format;
{
"id": "1525000000165354",
"ca_policies_usage_count": 5,
"disableable": false,
"disabled_reason": "The configuration cannot be disabled as this authenticator is currently used in Conditional Access Policies",
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"display_name": "Custom TOTP 1",
"factor_logo": "",
"removable": true,
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_private_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"sp_config_details": {
"sp_issuer_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901",
"sp_acs_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901/acs",
"sp_metadata": "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor.....></md:EntityDescriptor>",
"sp_signing_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_signing_cert_expired": false,
"sp_signing_cert_expiry_time": "2025-09-08T20:14:45.000Z",
"sp_encryption_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...",
"sp_encryption_cert_expired": false,
"sp_encryption_cert_expiry_time": "2025-09-08T20:14:45.000Z"
},
"ca_configs": [
{
"id": "1525000000178381",
"is_enabled": true,
"ca_file": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"subject_name": "CN=idprotection,CN=Users,DC=Com",
"thumbprint": "deuejnjenje2endd32ejdjebjfer",
"certificate_mapping_attribute": "emailAddress",
"expires_on": "2025-09-08T20:14:45.000Z",
"added_time": "2025-09-08T20:14:45.000Z"
}
],
"is_revocation_check_enabled": true
}
}
Get All Authnfactor Configs
The Get All Authnfactor Configs API can be used to get the details of all authnfactor configurations in your account.
OAuth Scope : id360.auth.READ,id360.auth.ALL
Query Parameters
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs"
type: GET
headers: headers_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs")
.get()
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'GET',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
}
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
conn.request("GET", "/api/v1/protection/authnfactor-configs", headers=headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "GET",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.end();
curl --request GET \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
{
"data": [
{
"id": "1525000000165354",
"factor_type": "EmailAuthenticator",
"is_enabled": true
},
{
"id": "1525000001335049",
"factor_type": "FIDOAuthenticator",
"is_enabled": true
},
{
"id": "1525000000779281",
"factor_type": "GoogleAuthenticator",
"is_enabled": false
},
{
"id": "1525000000853039",
"factor_type": "MicrosoftAuthenticator",
"is_enabled": false
},
{
"id": "1525000000853033",
"factor_type": "ZohoOneAuthAuthenticator",
"is_enabled": false
},
{
"id": "1525000001335033",
"factor_type": "CustomTOTPAuthenticator",
"display_name": "ctotp1",
"is_enabled": true,
"factor_logo": "<Base64 encoded image>"
},
{
"id": "1525000001335173",
"factor_type": "CustomTOTPAuthenticator",
"display_name": "ctotp3",
"is_enabled": true,
"factor_logo": "<Base64 encoded image>"
},
{
"id": "1525000001335021",
"factor_type": "SMSAuthenticator",
"is_enabled": true
},
{
"id": "1525000001335061",
"factor_type": "DUOAuthenticator",
"is_enabled": true
},
{
"id": "1525000000165354",
"factor_type": "SmartCardAuthenticator",
"is_enabled": true
},
{
"id": "1525000000193567",
"factor_type": "SQAAuthenticator",
"is_enabled": true
},
{
"id": "1525000000193569",
"factor_type": "SAMLAuthenticator",
"is_enabled": true,
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
]
}
]
}
{
"error": {
"code": "00000107",
"title": "Invalid Parameter",
"detail": "The parameter select is invalid."
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Create Authnfactor Config
The Create Authnfactor Config API can be used to create a new authnfactor configuration in your account.
OAuth Scope : id360.auth.CREATE,id360.auth.WRITE,id360.auth.ALL
Arguments
- EmailAuthenticator
- FIDOAuthenticator
- GoogleAuthenticator
- MicrosoftAuthenticator
- ZohoOneAuthAuthenticator
- CustomTOTPAuthenticator
- SMSAuthenticator
- DUOAuthenticator
- SmartCardAuthenticator
- SQAAuthenticator
- SAMLAuthenticator
- info
- warning
- critical
- CertificateExpiringSoon
- CertificateExpired
- all_allowed
- blacklist
- whitelist
- all_allowed
- blacklist
- whitelist
- attribute
- naming_format
- totp
- hotp
- software
- hardware
- SHA1
- SHA256
- SHA512
- 10
- 15
- 20
- 25
- 30
- 35
- 40
- 45
- 50
- 55
- 60
- all
- platform
- cross_platform
- discouraged
- preferred
- required
- okta
- rsa cloud
- onelogin
- adfs
- line works
- custom saml
- attribute
- naming_format
- self_signed
- ca_signed
Note: The file should be in .cer format;
parameters_data='{"field1":"value1","field2":"value2"}';
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs"
type: POST
headers: headers_data
content-type: application/json
parameters: parameters_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\"field1\":\"value1\",\"field2\":\"value2\"}");
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs")
.post(body)
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.addHeader("content-type", "application/json")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'POST',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f',
'content-type': 'application/json'
},
body: '{"field1":"value1","field2":"value2"}'
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
payload = "{\"field1\":\"value1\",\"field2\":\"value2\"}"
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f",
'content-type': "application/json"
}
conn.request("POST", "/api/v1/protection/authnfactor-configs", payload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "POST",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f",
"content-type": "application/json"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.write(JSON.stringify({field1: 'value1', field2: 'value2'}));
req.end();
curl --request POST \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f' \
--header 'content-type: application/json' \
--data '{"field1":"value1","field2":"value2"}'
{
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"factor_logo": "",
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_private_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"ca_configs": [
{
"is_enabled": true,
"ca_file": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"certificate_mapping_attribute": "emailAddress"
}
],
"is_revocation_check_enabled": true
}
}
{
"data": {
"id": "1525000000165354",
"ca_policies_usage_count": 5,
"disableable": false,
"disabled_reason": "The configuration cannot be disabled as this authenticator is currently used in Conditional Access Policies",
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"display_name": "Custom TOTP 1",
"factor_logo": "",
"removable": true,
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"sp_config_details": {
"sp_issuer_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901",
"sp_acs_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901/acs",
"sp_metadata": "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor.....></md:EntityDescriptor>",
"sp_signing_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_signing_cert_expired": false,
"sp_signing_cert_expiry_time": "2025-09-08T20:14:45.000Z",
"sp_encryption_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...",
"sp_encryption_cert_expired": false,
"sp_encryption_cert_expiry_time": "2025-09-08T20:14:45.000Z"
},
"ca_configs": [
{
"id": "1525000000178381",
"is_enabled": true,
"subject_name": "CN=idprotection,CN=Users,DC=Com",
"thumbprint": "deuejnjenje2endd32ejdjebjfer",
"certificate_mapping_attribute": "emailAddress",
"expires_on": "2025-09-08T20:14:45.000Z",
"added_time": "2025-09-08T20:14:45.000Z"
}
],
"is_revocation_check_enabled": true
}
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Get Authnfactor Config
The Get Authnfactor Config API can be used to get the details of a specific authnfactor configuration in your account.
OAuth Scope : id360.auth.READ,id360.auth.ALL
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354"
type: GET
headers: headers_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354")
.get()
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'GET',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
}
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
conn.request("GET", "/api/v1/protection/authnfactor-configs/1525000000165354", headers=headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "GET",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs/1525000000165354",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.end();
curl --request GET \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354 \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
{
"data": {
"id": "1525000000165354",
"ca_policies_usage_count": 5,
"disableable": false,
"disabled_reason": "The configuration cannot be disabled as this authenticator is currently used in Conditional Access Policies",
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"display_name": "Custom TOTP 1",
"factor_logo": "",
"removable": true,
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"sp_config_details": {
"sp_issuer_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901",
"sp_acs_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901/acs",
"sp_metadata": "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor.....></md:EntityDescriptor>",
"sp_signing_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_signing_cert_expired": false,
"sp_signing_cert_expiry_time": "2025-09-08T20:14:45.000Z",
"sp_encryption_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...",
"sp_encryption_cert_expired": false,
"sp_encryption_cert_expiry_time": "2025-09-08T20:14:45.000Z"
},
"ca_configs": [
{
"id": "1525000000178381",
"is_enabled": true,
"subject_name": "CN=idprotection,CN=Users,DC=Com",
"thumbprint": "deuejnjenje2endd32ejdjebjfer",
"certificate_mapping_attribute": "emailAddress",
"expires_on": "2025-09-08T20:14:45.000Z",
"added_time": "2025-09-08T20:14:45.000Z"
}
],
"is_revocation_check_enabled": true
}
}
}
{
"error": {
"code": "00000107",
"title": "Invalid Parameter",
"detail": "The parameter select is invalid."
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "---",
"title": "Authnfactor Config Not Found",
"detail": "This Authnfactor Config ID does not exist or you do not have permission to access it."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Update Authnfactor Config
The Update Authnfactor Config API can be used to update the details of a specific authnfactor configuration in your account.
OAuth Scope : id360.auth.UPDATE,id360.auth.WRITE,id360.auth.ALL
Arguments
- EmailAuthenticator
- FIDOAuthenticator
- GoogleAuthenticator
- MicrosoftAuthenticator
- ZohoOneAuthAuthenticator
- CustomTOTPAuthenticator
- SMSAuthenticator
- DUOAuthenticator
- SmartCardAuthenticator
- SQAAuthenticator
- SAMLAuthenticator
- info
- warning
- critical
- CertificateExpiringSoon
- CertificateExpired
- all_allowed
- blacklist
- whitelist
- all_allowed
- blacklist
- whitelist
- attribute
- naming_format
- totp
- hotp
- software
- hardware
- SHA1
- SHA256
- SHA512
- 10
- 15
- 20
- 25
- 30
- 35
- 40
- 45
- 50
- 55
- 60
- all
- platform
- cross_platform
- discouraged
- preferred
- required
- okta
- rsa cloud
- onelogin
- adfs
- line works
- custom saml
- attribute
- naming_format
- self_signed
- ca_signed
Note: The file should be in .cer format;
parameters_data='{"is_enabled":true,"factor_type":"EmailAuthenticator","factor_logo":"","notifications":[{"severity":"warning","type":"CertificateExpiringSoon","message":"Signing Certificate will expire in 2 days"}],"factor_settings":{"max_nos_enrollment_per_user":5,"otp_length":7,"is_secondary_emailid_registration_enabled":true,"secondary_emailid_registration_settings":{"is_forced":false,"format_restriction_type":"all_allowed","formats":["example.com","hu.ki"]},"is_secondary_mobileno_registration_enabled":true,"secondary_mobileno_registration_settings":{"is_forced":false,"country_code_restriction_type":"all_allowed","country_codes":["IN","JP"]},"username_format":{"name":"firstName","type":"naming_format"},"oath_type":"hotp","token_type":"software","hash_algorithm":"SHA1","totp_time_step":30,"issuer_text":"Identity360","totp_length":6,"clock_drift_factor":5,"api_hostname":"api-d361021d.duosecurity.com","websdk_client_id":"DIGIG3B5K0UA4GPZ4MQ6","websdk_client_secret":"xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0","dmp_client_id":"DI093J791C98JYGB24X0","dmp_client_secret":"9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd","authapi_secret_key":"cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv","authapi_integ_key":"DIBC9B5II50KNZNOK39E","fido_types":"all","user_verification_requirement":"discouraged","is_synced_passkey_allowed":false,"predefined_ques_count":2,"user_defined_ques_count":1,"min_ques_length":10,"min_ans_length":6,"is_username_in_ans_denied":true,"is_duplicate_ans_denied":true,"is_ques_word_as_ans_denied":true,"is_multibyte_chars_in_ans_denied":true,"enabled_predefined_questions":[{"question_id":"2000000283042","is_mandatory":true}],"saml_provider":"custom","saml_provider_display_name":"Custom SAML AuthenticatoR","issuer_url":"https://example-idp.com/iamapps/ssologin/custom/abc","login_url":"https://example-idp.com/iamapps/ssologin/custom/abc","public_key":"-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----","saml_request_signed":true,"saml_authn_context":["PPT"],"saml_subject_include":true,"saml_subject_format":{"name":"FirstName + LastName","type":"attribute"},"saml_response_signed":true,"saml_assertion_signed":true,"saml_assertion_signature_algo":"SHA256","saml_assertion_encrypted":true,"encryption_cert_selected":"self_signed","ca_signed_public_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_private_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_public_key_file_name":"caencpublic.pem","ca_signed_private_key_file_name":"caencprivate.pem","ca_configs":[{"is_enabled":true,"ca_file":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","certificate_mapping_attribute":"emailAddress"}],"is_revocation_check_enabled":true}}';
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354"
type: PATCH
headers: headers_data
content-type: application/json
parameters: parameters_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json");
RequestBody body = RequestBody.create(mediaType, "{\"is_enabled\":true,\"factor_type\":\"EmailAuthenticator\",\"factor_logo\":\"\",\"notifications\":[{\"severity\":\"warning\",\"type\":\"CertificateExpiringSoon\",\"message\":\"Signing Certificate will expire in 2 days\"}],\"factor_settings\":{\"max_nos_enrollment_per_user\":5,\"otp_length\":7,\"is_secondary_emailid_registration_enabled\":true,\"secondary_emailid_registration_settings\":{\"is_forced\":false,\"format_restriction_type\":\"all_allowed\",\"formats\":[\"example.com\",\"hu.ki\"]},\"is_secondary_mobileno_registration_enabled\":true,\"secondary_mobileno_registration_settings\":{\"is_forced\":false,\"country_code_restriction_type\":\"all_allowed\",\"country_codes\":[\"IN\",\"JP\"]},\"username_format\":{\"name\":\"firstName\",\"type\":\"naming_format\"},\"oath_type\":\"hotp\",\"token_type\":\"software\",\"hash_algorithm\":\"SHA1\",\"totp_time_step\":30,\"issuer_text\":\"Identity360\",\"totp_length\":6,\"clock_drift_factor\":5,\"api_hostname\":\"api-d361021d.duosecurity.com\",\"websdk_client_id\":\"DIGIG3B5K0UA4GPZ4MQ6\",\"websdk_client_secret\":\"xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0\",\"dmp_client_id\":\"DI093J791C98JYGB24X0\",\"dmp_client_secret\":\"9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd\",\"authapi_secret_key\":\"cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv\",\"authapi_integ_key\":\"DIBC9B5II50KNZNOK39E\",\"fido_types\":\"all\",\"user_verification_requirement\":\"discouraged\",\"is_synced_passkey_allowed\":false,\"predefined_ques_count\":2,\"user_defined_ques_count\":1,\"min_ques_length\":10,\"min_ans_length\":6,\"is_username_in_ans_denied\":true,\"is_duplicate_ans_denied\":true,\"is_ques_word_as_ans_denied\":true,\"is_multibyte_chars_in_ans_denied\":true,\"enabled_predefined_questions\":[{\"question_id\":\"2000000283042\",\"is_mandatory\":true}],\"saml_provider\":\"custom\",\"saml_provider_display_name\":\"Custom SAML AuthenticatoR\",\"issuer_url\":\"https://example-idp.com/iamapps/ssologin/custom/abc\",\"login_url\":\"https://example-idp.com/iamapps/ssologin/custom/abc\",\"public_key\":\"-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----\",\"saml_request_signed\":true,\"saml_authn_context\":[\"PPT\"],\"saml_subject_include\":true,\"saml_subject_format\":{\"name\":\"FirstName + LastName\",\"type\":\"attribute\"},\"saml_response_signed\":true,\"saml_assertion_signed\":true,\"saml_assertion_signature_algo\":\"SHA256\",\"saml_assertion_encrypted\":true,\"encryption_cert_selected\":\"self_signed\",\"ca_signed_public_key\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"ca_signed_private_key\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"ca_signed_public_key_file_name\":\"caencpublic.pem\",\"ca_signed_private_key_file_name\":\"caencprivate.pem\",\"ca_configs\":[{\"is_enabled\":true,\"ca_file\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"certificate_mapping_attribute\":\"emailAddress\"}],\"is_revocation_check_enabled\":true}}");
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354")
.patch(body)
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.addHeader("content-type", "application/json")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'PATCH',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f',
'content-type': 'application/json'
},
body: '{"is_enabled":true,"factor_type":"EmailAuthenticator","factor_logo":"","notifications":[{"severity":"warning","type":"CertificateExpiringSoon","message":"Signing Certificate will expire in 2 days"}],"factor_settings":{"max_nos_enrollment_per_user":5,"otp_length":7,"is_secondary_emailid_registration_enabled":true,"secondary_emailid_registration_settings":{"is_forced":false,"format_restriction_type":"all_allowed","formats":["example.com","hu.ki"]},"is_secondary_mobileno_registration_enabled":true,"secondary_mobileno_registration_settings":{"is_forced":false,"country_code_restriction_type":"all_allowed","country_codes":["IN","JP"]},"username_format":{"name":"firstName","type":"naming_format"},"oath_type":"hotp","token_type":"software","hash_algorithm":"SHA1","totp_time_step":30,"issuer_text":"Identity360","totp_length":6,"clock_drift_factor":5,"api_hostname":"api-d361021d.duosecurity.com","websdk_client_id":"DIGIG3B5K0UA4GPZ4MQ6","websdk_client_secret":"xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0","dmp_client_id":"DI093J791C98JYGB24X0","dmp_client_secret":"9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd","authapi_secret_key":"cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv","authapi_integ_key":"DIBC9B5II50KNZNOK39E","fido_types":"all","user_verification_requirement":"discouraged","is_synced_passkey_allowed":false,"predefined_ques_count":2,"user_defined_ques_count":1,"min_ques_length":10,"min_ans_length":6,"is_username_in_ans_denied":true,"is_duplicate_ans_denied":true,"is_ques_word_as_ans_denied":true,"is_multibyte_chars_in_ans_denied":true,"enabled_predefined_questions":[{"question_id":"2000000283042","is_mandatory":true}],"saml_provider":"custom","saml_provider_display_name":"Custom SAML AuthenticatoR","issuer_url":"https://example-idp.com/iamapps/ssologin/custom/abc","login_url":"https://example-idp.com/iamapps/ssologin/custom/abc","public_key":"-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----","saml_request_signed":true,"saml_authn_context":["PPT"],"saml_subject_include":true,"saml_subject_format":{"name":"FirstName + LastName","type":"attribute"},"saml_response_signed":true,"saml_assertion_signed":true,"saml_assertion_signature_algo":"SHA256","saml_assertion_encrypted":true,"encryption_cert_selected":"self_signed","ca_signed_public_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_private_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_public_key_file_name":"caencpublic.pem","ca_signed_private_key_file_name":"caencprivate.pem","ca_configs":[{"is_enabled":true,"ca_file":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","certificate_mapping_attribute":"emailAddress"}],"is_revocation_check_enabled":true}}'
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
payload = "{\"is_enabled\":true,\"factor_type\":\"EmailAuthenticator\",\"factor_logo\":\"\",\"notifications\":[{\"severity\":\"warning\",\"type\":\"CertificateExpiringSoon\",\"message\":\"Signing Certificate will expire in 2 days\"}],\"factor_settings\":{\"max_nos_enrollment_per_user\":5,\"otp_length\":7,\"is_secondary_emailid_registration_enabled\":true,\"secondary_emailid_registration_settings\":{\"is_forced\":false,\"format_restriction_type\":\"all_allowed\",\"formats\":[\"example.com\",\"hu.ki\"]},\"is_secondary_mobileno_registration_enabled\":true,\"secondary_mobileno_registration_settings\":{\"is_forced\":false,\"country_code_restriction_type\":\"all_allowed\",\"country_codes\":[\"IN\",\"JP\"]},\"username_format\":{\"name\":\"firstName\",\"type\":\"naming_format\"},\"oath_type\":\"hotp\",\"token_type\":\"software\",\"hash_algorithm\":\"SHA1\",\"totp_time_step\":30,\"issuer_text\":\"Identity360\",\"totp_length\":6,\"clock_drift_factor\":5,\"api_hostname\":\"api-d361021d.duosecurity.com\",\"websdk_client_id\":\"DIGIG3B5K0UA4GPZ4MQ6\",\"websdk_client_secret\":\"xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0\",\"dmp_client_id\":\"DI093J791C98JYGB24X0\",\"dmp_client_secret\":\"9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd\",\"authapi_secret_key\":\"cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv\",\"authapi_integ_key\":\"DIBC9B5II50KNZNOK39E\",\"fido_types\":\"all\",\"user_verification_requirement\":\"discouraged\",\"is_synced_passkey_allowed\":false,\"predefined_ques_count\":2,\"user_defined_ques_count\":1,\"min_ques_length\":10,\"min_ans_length\":6,\"is_username_in_ans_denied\":true,\"is_duplicate_ans_denied\":true,\"is_ques_word_as_ans_denied\":true,\"is_multibyte_chars_in_ans_denied\":true,\"enabled_predefined_questions\":[{\"question_id\":\"2000000283042\",\"is_mandatory\":true}],\"saml_provider\":\"custom\",\"saml_provider_display_name\":\"Custom SAML AuthenticatoR\",\"issuer_url\":\"https://example-idp.com/iamapps/ssologin/custom/abc\",\"login_url\":\"https://example-idp.com/iamapps/ssologin/custom/abc\",\"public_key\":\"-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----\",\"saml_request_signed\":true,\"saml_authn_context\":[\"PPT\"],\"saml_subject_include\":true,\"saml_subject_format\":{\"name\":\"FirstName + LastName\",\"type\":\"attribute\"},\"saml_response_signed\":true,\"saml_assertion_signed\":true,\"saml_assertion_signature_algo\":\"SHA256\",\"saml_assertion_encrypted\":true,\"encryption_cert_selected\":\"self_signed\",\"ca_signed_public_key\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"ca_signed_private_key\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"ca_signed_public_key_file_name\":\"caencpublic.pem\",\"ca_signed_private_key_file_name\":\"caencprivate.pem\",\"ca_configs\":[{\"is_enabled\":true,\"ca_file\":\"-----BEGIN CERTIFICATE-----\\r\\nMIIDWjCCAk.....\\r\\n-----END CERTIFICATE-----\\r\\n\",\"certificate_mapping_attribute\":\"emailAddress\"}],\"is_revocation_check_enabled\":true}}"
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f",
'content-type': "application/json"
}
conn.request("PATCH", "/api/v1/protection/authnfactor-configs/1525000000165354", payload, headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "PATCH",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs/1525000000165354",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f",
"content-type": "application/json"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.write(JSON.stringify({
is_enabled: true,
factor_type: 'EmailAuthenticator',
factor_logo: '',
notifications: [
{
severity: 'warning',
type: 'CertificateExpiringSoon',
message: 'Signing Certificate will expire in 2 days'
}
],
factor_settings: {
max_nos_enrollment_per_user: 5,
otp_length: 7,
is_secondary_emailid_registration_enabled: true,
secondary_emailid_registration_settings: {
is_forced: false,
format_restriction_type: 'all_allowed',
formats: ['example.com', 'hu.ki']
},
is_secondary_mobileno_registration_enabled: true,
secondary_mobileno_registration_settings: {
is_forced: false,
country_code_restriction_type: 'all_allowed',
country_codes: ['IN', 'JP']
},
username_format: {name: 'firstName', type: 'naming_format'},
oath_type: 'hotp',
token_type: 'software',
hash_algorithm: 'SHA1',
totp_time_step: 30,
issuer_text: 'Identity360',
totp_length: 6,
clock_drift_factor: 5,
api_hostname: 'api-d361021d.duosecurity.com',
websdk_client_id: 'DIGIG3B5K0UA4GPZ4MQ6',
websdk_client_secret: 'xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0',
dmp_client_id: 'DI093J791C98JYGB24X0',
dmp_client_secret: '9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd',
authapi_secret_key: 'cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv',
authapi_integ_key: 'DIBC9B5II50KNZNOK39E',
fido_types: 'all',
user_verification_requirement: 'discouraged',
is_synced_passkey_allowed: false,
predefined_ques_count: 2,
user_defined_ques_count: 1,
min_ques_length: 10,
min_ans_length: 6,
is_username_in_ans_denied: true,
is_duplicate_ans_denied: true,
is_ques_word_as_ans_denied: true,
is_multibyte_chars_in_ans_denied: true,
enabled_predefined_questions: [{question_id: '2000000283042', is_mandatory: true}],
saml_provider: 'custom',
saml_provider_display_name: 'Custom SAML AuthenticatoR',
issuer_url: 'https://example-idp.com/iamapps/ssologin/custom/abc',
login_url: 'https://example-idp.com/iamapps/ssologin/custom/abc',
public_key: '-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----',
saml_request_signed: true,
saml_authn_context: ['PPT'],
saml_subject_include: true,
saml_subject_format: {name: 'FirstName + LastName', type: 'attribute'},
saml_response_signed: true,
saml_assertion_signed: true,
saml_assertion_signature_algo: 'SHA256',
saml_assertion_encrypted: true,
encryption_cert_selected: 'self_signed',
ca_signed_public_key: '-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n',
ca_signed_private_key: '-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n',
ca_signed_public_key_file_name: 'caencpublic.pem',
ca_signed_private_key_file_name: 'caencprivate.pem',
ca_configs: [
{
is_enabled: true,
ca_file: '-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n',
certificate_mapping_attribute: 'emailAddress'
}
],
is_revocation_check_enabled: true
}
}));
req.end();
curl --request PATCH \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354 \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f' \
--header 'content-type: application/json' \
--data '{"is_enabled":true,"factor_type":"EmailAuthenticator","factor_logo":"","notifications":[{"severity":"warning","type":"CertificateExpiringSoon","message":"Signing Certificate will expire in 2 days"}],"factor_settings":{"max_nos_enrollment_per_user":5,"otp_length":7,"is_secondary_emailid_registration_enabled":true,"secondary_emailid_registration_settings":{"is_forced":false,"format_restriction_type":"all_allowed","formats":["example.com","hu.ki"]},"is_secondary_mobileno_registration_enabled":true,"secondary_mobileno_registration_settings":{"is_forced":false,"country_code_restriction_type":"all_allowed","country_codes":["IN","JP"]},"username_format":{"name":"firstName","type":"naming_format"},"oath_type":"hotp","token_type":"software","hash_algorithm":"SHA1","totp_time_step":30,"issuer_text":"Identity360","totp_length":6,"clock_drift_factor":5,"api_hostname":"api-d361021d.duosecurity.com","websdk_client_id":"DIGIG3B5K0UA4GPZ4MQ6","websdk_client_secret":"xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0","dmp_client_id":"DI093J791C98JYGB24X0","dmp_client_secret":"9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd","authapi_secret_key":"cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv","authapi_integ_key":"DIBC9B5II50KNZNOK39E","fido_types":"all","user_verification_requirement":"discouraged","is_synced_passkey_allowed":false,"predefined_ques_count":2,"user_defined_ques_count":1,"min_ques_length":10,"min_ans_length":6,"is_username_in_ans_denied":true,"is_duplicate_ans_denied":true,"is_ques_word_as_ans_denied":true,"is_multibyte_chars_in_ans_denied":true,"enabled_predefined_questions":[{"question_id":"2000000283042","is_mandatory":true}],"saml_provider":"custom","saml_provider_display_name":"Custom SAML AuthenticatoR","issuer_url":"https://example-idp.com/iamapps/ssologin/custom/abc","login_url":"https://example-idp.com/iamapps/ssologin/custom/abc","public_key":"-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----","saml_request_signed":true,"saml_authn_context":["PPT"],"saml_subject_include":true,"saml_subject_format":{"name":"FirstName + LastName","type":"attribute"},"saml_response_signed":true,"saml_assertion_signed":true,"saml_assertion_signature_algo":"SHA256","saml_assertion_encrypted":true,"encryption_cert_selected":"self_signed","ca_signed_public_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_private_key":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","ca_signed_public_key_file_name":"caencpublic.pem","ca_signed_private_key_file_name":"caencprivate.pem","ca_configs":[{"is_enabled":true,"ca_file":"-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n","certificate_mapping_attribute":"emailAddress"}],"is_revocation_check_enabled":true}}'
{
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"factor_logo": "",
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_private_key": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"ca_configs": [
{
"is_enabled": true,
"ca_file": "-----BEGIN CERTIFICATE-----\r\nMIIDWjCCAk.....\r\n-----END CERTIFICATE-----\r\n",
"certificate_mapping_attribute": "emailAddress"
}
],
"is_revocation_check_enabled": true
}
}
{
"data": {
"id": "1525000000165354",
"ca_policies_usage_count": 5,
"disableable": false,
"disabled_reason": "The configuration cannot be disabled as this authenticator is currently used in Conditional Access Policies",
"is_enabled": true,
"factor_type": "EmailAuthenticator",
"display_name": "Custom TOTP 1",
"factor_logo": "",
"removable": true,
"notifications": [
{
"severity": "warning",
"type": "CertificateExpiringSoon",
"message": "Signing Certificate will expire in 2 days"
}
],
"factor_settings": {
"max_nos_enrollment_per_user": 5,
"otp_length": 7,
"is_secondary_emailid_registration_enabled": true,
"secondary_emailid_registration_settings": {
"is_forced": false,
"format_restriction_type": "all_allowed",
"formats": [
"example.com",
"hu.ki"
]
},
"is_secondary_mobileno_registration_enabled": true,
"secondary_mobileno_registration_settings": {
"is_forced": false,
"country_code_restriction_type": "all_allowed",
"country_codes": [
"IN",
"JP"
]
},
"username_format": {
"name": "firstName",
"type": "naming_format"
},
"oath_type": "hotp",
"token_type": "software",
"hash_algorithm": "SHA1",
"totp_time_step": 30,
"issuer_text": "Identity360",
"totp_length": 6,
"clock_drift_factor": 5,
"api_hostname": "api-d361021d.duosecurity.com",
"websdk_client_id": "DIGIG3B5K0UA4GPZ4MQ6",
"websdk_client_secret": "xHgNCG1HqbtHzQwjOktB9w8fhOxz6cuD4KSYjil0",
"dmp_client_id": "DI093J791C98JYGB24X0",
"dmp_client_secret": "9xzBgtk5RtOBGfcK2f1VruvqgAizrkWbjVHMOSqd",
"authapi_secret_key": "cOgtuAii3O4rzJkpwHPizOnovU7I5cLB1ZsC9xnv",
"authapi_integ_key": "DIBC9B5II50KNZNOK39E",
"fido_types": "all",
"user_verification_requirement": "discouraged",
"is_synced_passkey_allowed": false,
"predefined_ques_count": 2,
"user_defined_ques_count": 1,
"min_ques_length": 10,
"min_ans_length": 6,
"is_username_in_ans_denied": true,
"is_duplicate_ans_denied": true,
"is_ques_word_as_ans_denied": true,
"is_multibyte_chars_in_ans_denied": true,
"enabled_predefined_questions": [
{
"question_id": "2000000283042",
"is_mandatory": true
}
],
"saml_provider": "custom",
"saml_provider_display_name": "Custom SAML AuthenticatoR",
"issuer_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"login_url": "https://example-idp.com/iamapps/ssologin/custom/abc",
"public_key": "-----BEGIN CERTIFICATE-----MIICcTCC...-----END CERTIFICATE-----",
"saml_request_signed": true,
"saml_authn_context": [
"PPT"
],
"saml_subject_include": true,
"saml_subject_format": {
"name": "FirstName + LastName",
"type": "attribute"
},
"saml_response_signed": true,
"saml_assertion_signed": true,
"saml_assertion_signature_algo": "SHA256",
"saml_assertion_encrypted": true,
"encryption_cert_selected": "self_signed",
"ca_signed_public_key_file_name": "caencpublic.pem",
"ca_signed_private_key_file_name": "caencprivate.pem",
"sp_config_details": {
"sp_issuer_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901",
"sp_acs_url": "https://id360.manageengine.com/saml/v1/f0af1d6cc6fe5c807f9dfd92885d955eb04f1901/acs",
"sp_metadata": "<?xml version=\"1.0\" encoding=\"UTF-8\"?><md:EntityDescriptor.....></md:EntityDescriptor>",
"sp_signing_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_signing_cert_expired": false,
"sp_signing_cert_expiry_time": "2025-09-08T20:14:45.000Z",
"sp_encryption_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...",
"sp_encryption_cert_expired": false,
"sp_encryption_cert_expiry_time": "2025-09-08T20:14:45.000Z"
},
"ca_configs": [
{
"id": "1525000000178381",
"is_enabled": true,
"subject_name": "CN=idprotection,CN=Users,DC=Com",
"thumbprint": "deuejnjenje2endd32ejdjebjfer",
"certificate_mapping_attribute": "emailAddress",
"expires_on": "2025-09-08T20:14:45.000Z",
"added_time": "2025-09-08T20:14:45.000Z"
}
],
"is_revocation_check_enabled": true
}
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "---",
"title": "Authnfactor Config Not Found",
"detail": "This Authnfactor Config ID does not exist or you do not have permission to access it."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Delete Authnfactor Config
Delete Authnfactor Config API can be used to delete a specific authnfactor configuration in your account.
OAuth Scope : id360.auth.DELETE,id360.auth.WRITE,id360.auth.ALL
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354"
type: DELETE
headers: headers_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354")
.delete(null)
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'DELETE',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
}
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
conn.request("DELETE", "/api/v1/protection/authnfactor-configs/1525000000165354", headers=headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "DELETE",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs/1525000000165354",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.end();
curl --request DELETE \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354 \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "---",
"title": "Authnfactor Config Not Found",
"detail": "This Authnfactor Config ID does not exist or you do not have permission to access it."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Regenerate SAML Signing Certificate
The Regenerate SAML Signing Certificate API can be used to regenerate the SAML signing certificate for a specific authnFactor configuration.
OAuth Scope : id360.auth.WRITE,id360.auth.ALL,id360.auth.CREATE
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert"
type: POST
headers: headers_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert")
.post(null)
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'POST',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
}
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
conn.request("POST", "/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert", headers=headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "POST",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.end();
curl --request POST \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-signing-cert \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
{
"data": {
"sp_signing_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_signing_cert_expired": false,
"sp_signing_cert_expiry_time": "2025-09-08T20:14:45.000Z"
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "---",
"title": "Authnfactor Config Not Found",
"detail": "This Authnfactor Config ID does not exist or you do not have permission to access it."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}
Regenerate SAML Encryption Certificate
The Regenerate SAML encryption Certificate API can be used to regenerate the SAML encryption certificate for a specific authnFactor configuration.
OAuth Scope : id360.auth.WRITE,id360.auth.ALL,id360.auth.CREATE
headers_data = Map();
headers_data.put("Accept", "application/json");
headers_data.put("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f");
response = invokeUrl
[
url: "https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert"
type: POST
headers: headers_data
connection: <connection_name>
];
info response;
OkHttpClient client = new OkHttpClient();
Request request = new Request.Builder()
.url("https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert")
.post(null)
.addHeader("Accept", "application/json")
.addHeader("Authorization", "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f")
.build();
Response response = client.newCall(request).execute();
const options = {
method: 'POST',
headers: {
Accept: 'application/json',
Authorization: 'Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
}
};
fetch('https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert', options)
.then(response => response.json())
.then(response => console.log(response))
.catch(err => console.error(err));
import http.client
conn = http.client.HTTPSConnection("id360.manageengine.com")
headers = {
'Accept': "application/json",
'Authorization': "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
conn.request("POST", "/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert", headers=headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
const http = require("https");
const options = {
"method": "POST",
"hostname": "id360.manageengine.com",
"port": null,
"path": "/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert",
"headers": {
"Accept": "application/json",
"Authorization": "Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f"
}
};
const req = http.request(options, function (res) {
const chunks = [];
res.on("data", function (chunk) {
chunks.push(chunk);
});
res.on("end", function () {
const body = Buffer.concat(chunks);
console.log(body.toString());
});
});
req.end();
curl --request POST \
--url https://id360.manageengine.com/api/v1/protection/authnfactor-configs/1525000000165354/regenerate-saml-encryption-cert \
--header 'Accept: application/json' \
--header 'Authorization: Zoho-oauthtoken 1000.41d9xxxxxxxxxxxxxxxxxxxxxxxxc2d1.8fccxxxxxxxxxxxxxxxxxxxxxxxx125f'
{
"data": {
"sp_encryption_cert": "-----BEGIN CERTIFICATE-----MIIDWjCC...-----END CERTIFICATE-----",
"sp_encryption_cert_expired": false,
"sp_encryption_cert_expiry_time": "2025-09-08T20:14:45.000Z"
}
}
{
"error": {
"code": "00000101",
"title": "Unauthorized",
"detail": "The OAuth token is invalid."
}
}
{
"error": {
"code": "---",
"title": "Authnfactor Config Not Found",
"detail": "This Authnfactor Config ID does not exist or you do not have permission to access it."
}
}
{
"error": {
"code": "00000000",
"title": "Internal Server Error",
"detail": "An unexpected internal error has occurred on the server. Please try again later."
}
}