Download OpenAPI specification:
CertVault RESTful API Doc
CertVault Self-Signed SSL Certificate Management Platform.
User login
Login entity
username required | string User account(can be username or email) |
password required | string Password of the user |
{- "username": "testadmin",
- "password": 123456
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
{- "code": 200,
- "msg": "OIDC Enabled",
- "data": [
- {
- "provider": "oidc",
- "displayName": "OpenID Connect",
- "logo": ""
}
], - "timestamp": "2025-03-29T00:59:00.06971"
}
OpenID Connect IdP Login Success Callback Endpoint
code required | string Example: code=c1ds5v1... OpenID Connect IdP Response JWT Code |
state required | string Example: state=s1ds5v1... OpenID Connect IdP Response State |
{- "code": 204,
- "msg": "OIDC Disabled",
- "data": null,
- "timestamp": "2025-03-29T00:59:00+08:00"
}
OpenID Connect IdP Login Success Callback Endpoint
provider required | string OIDC provider |
code required | string Example: code=c1ds5v1... OpenID Connect IdP Response JWT Code |
state required | string Example: state=s1ds5v1... OpenID Connect IdP Response State |
{- "code": 204,
- "msg": "OIDC Disabled",
- "data": null,
- "timestamp": "2025-03-29T00:59:00+08:00"
}
Renew the SSL certificate
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 SSL certificate UUID |
New expiry
{- "expiry": 365
}
{- "code": 200,
- "message": "Success",
- "data": {
- "uuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "algorithm": "RSA",
- "keySize": 2048,
- "privkey": null,
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk...",
- "caUuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "notBefore": "2025-03-22T23:05:54+08:00",
- "notAfter": "2035-03-20T23:05:54+08:00",
- "comment": "CertVault Website SSL Certificate"
}
}
Delete the SSL certificate
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 SSL certificate UUID |
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Retrieve all certificate information for the user (paged retrieval)
keyword | string Example: keyword=72267ce5-e94a-4cdb-b35b-63f1f385b253 Search keywords (Can be UUID, comments) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": "72267ce5-e94a-4cdb-b35b-63f1f385b253",
- "caUuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "algorithm": "RSA",
- "keySize": 2048,
- "owner": "gregPerlinLi",
- "comment": "Cert Vault SSL Certificate",
- "notBefore": "2025-03-19T01:38:31+08:00",
- "notAfter": "2025-06-17T01:38:31+08:00",
- "createdAt": "2025-03-19T01:38:31+08:00",
- "modifiedAt": "2025-03-19T01:38:31+08:00"
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Request a new SSL certificate
Request certificate entity
caUuid | string CA UUID |
allowSubCa | boolean Whether to allow sub-CA |
algorithm | string Algorithm (Can be RSA, EC, Ed25519) |
keySize | integer <int32> Key Size |
country required | string Country |
province required | string Province |
city required | string City |
organization required | string Organization |
organizationalUnit required | string Organizational Unit |
commonName required | string Common Name |
expiry required | integer <int32> Expiry (day) |
Array of objects (SubjectAltName) Subject Alternative Name | |
comment | string Comment |
{- "caUuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "algorithm": "RSA",
- "keySize": 2048,
- "country": "CN",
- "province": "Guangdong",
- "city": "Canton",
- "organization": "GregPerlinLi",
- "organizationalUnit": "Cert Vault",
- "commonName": "a.b.c",
- "expiry": 30,
- "subjectAltNames": [
- {
- "type": "DNS_NAME",
- "value": "a.b.c"
}, - {
- "type": "IP_ADDRESS",
- "value": "10.18.0.1"
},
], - "comment": "CertVault SSL Certificate"
}
{- "code": 200,
- "message": "Success",
- "data": {
- "uuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "algorithm": "RSA",
- "keySize": 2048,
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2Z0lCQU...",
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk...",
- "caUuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "notBefore": "2025-03-22T23:05:54+08:00",
- "notAfter": "2035-03-20T23:05:54+08:00",
- "comment": "CertVault Website SSL Certificate"
}
}
Retrieve the private key of the SSL certificate (Need user password verify)
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 SSL certificate UUID |
Confirm password
{- "password": "123456"
}
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Private key parser, used for parsing private key information
Private key Base64
{- "privkey": "MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQC1GAQWvotGCPu1QAB14hzKF5C2bc9WRecF..."
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "algorithm": "RSA",
- "encoded": "MIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQC1GAQWvotGCPu1QAB14hzKF5C2bc9WRecF...",
- "format": "PKCS#8",
- "params": null,
- "privkey": {
- "modulus": "228609759160589102334607729602696527515026450133506517096342257090026912981548985018...",
- "prime": {
- "p": "153760461261178965010117263539283481275456885011494138046055221948725869202108767925782429...",
- "q": "148679158013366268620605192719915250915997392432944427360405967071016077019192990038738873...",
- "exponentP": "15860059479768219531995555205846412460474061105599895832756050786172496083224060777549921...",
- "exponentQ": "70091570654454189775275310653134894674773874858602789687155389453684372424508088869445904..."
}, - "privateExponent": "3299540277858327843787562009722609295153325895010205143986299967674084211807790788851983...",
- "publicExponent": "65537",
- "coefficient": "132134676487591500472106038450127896519064821839151815733859424292775374431869116103238791..."
}
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Convert PEM format certificate and private key to PFX(PKCS12) format
Certificate Base64
{- "cert": "MIIB+zCCAVigAwIBAgIQJz+JlZg97kbB6ZnzUfe8pYDANBgk...",
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2Z0lCQU...",
- "password": "password"
}
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Convert PEM format certificate and private key to DER format
Base64 encoded Certificate and Private Key Information
cert required | string Certificate with BASE64 encoding |
privkey | string Private key with BASE64 encoding |
{- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2QUl..."
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2QUl..."
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Convert DER format certificate and private key to PEM format
Base64 encoded Certificate and Private Key Information
cert required | string Certificate with BASE64 encoding |
privkey | string Private key with BASE64 encoding |
{- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2QUl..."
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2QUl..."
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Certificate parser, used for parsing certificate information
Certificate Base64
{- "cert": "MIIB+zCCAVigAwIBAgIQJz+JlZg97kbB6ZnzUfe8pYDANBgk..."
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "subject": "C=CN,ST=Guangdong,L=Canton,O=GregPerlinLi,OU=CertVault,CN=a.b.c,E=test@example.com",
- "issuer": "C=CN,ST=Guangdong,L=Canton,O=GregPerlinLi,OU=CertVault,CN=CertVault,E=test@example.com",
- "notBefore": "2025-03-16T17:47:31+08:00",
- "notAfter": "2025-04-15T17:47:31+08:00",
- "serialNumber": "270437134803127796822084897079779361349",
- "publicKey": {
- "modulus": "27228785212927428737771860203521436191416421175100205454382431265594855967985632309468958148378247733975427437215287450921497030089159042637171587909338104950951468346622011497774866599914499772913232124067048957473507324932111466579075770019006239562097950887578380380351965073168545804309746900931657224661678530372714410855922734561728488370891868763766725189024112843185736499314827869994102612012859480648578770392684920448854880316939200542419448930131201774453139638113733093803960821686343047917906589960134274152756270862641854968301124244102646389827505217344218437902984794140086188049888289041283304310827",
- "publicExponent": "65537",
- "encoded": "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA17GK+JlZg97kbB6ZnzUfe8pYBO5qScuo/zKGXe6RCBxcps6GrTsagc9BPCpCpfs0GirzAevxHqrK4doC0B3ZHePmXVinZp7f+6oNL93+1FFqkkT+JcSJQpnxR6dluhPfFtJbNErn1QNKdlYq+kwp/tmBWKOzYM0EdTpYd8qit6lXr9fHWU5C+qHIPxIdurOZBi+tRrBYF5bRusIM3C7bVgX1Lm8Dqvvbeelsdz18sgAgCFo41NiJWW1thqo3MhdLEfINhaOhkftYFuu12ajfAmMJgguJ8ADCCpGR22nlxtIsMvKXpzd/PCMhm83W1MWWRZr2RSAS0oYGD5AndEbIKwIDAQAB",
- "format": "X.509",
- "algorithm": "RSA",
- "params": null
}, - "extensions": {
- "2.5.29.17": "SAN: DNS: a.b.c, IP: 10.18.0.1, Email: test@example.com, URI: https://a.b.c",
- "2.5.29.15": "KeyUsage: Digital Signature, Key Encipherment",
- "2.5.29.37": "EKU: org.bouncycastle.asn1.x509.ExtendedKeyUsage@7a9e2c00"
}
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Update user's own personal information Write the specific part that needs to be modified, do not include any part that does not need to be changed in the body (including keys and values).
Update user profile entity
displayName required | string Display name of the user |
email required | string Email of the user |
oldPassword required | string Old password of the user |
newPassword required | string New password of the user |
{- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "oldPassword": "oldPass123",
- "newPassword": "newPass456"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Update the comment of the certificate
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 SSL certificate UUID |
Update comment
{- "comment": "New comment of the cert"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Retrieve user's own login records (paged retrieval)
status | integer <int32> Default: -1 Example: status=-1 Login status (-1: all, 0: offline, 1:online) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": 1234567890,
- "username": "gregPerlinLi",
- "ipAddress": "10.18.0.1",
- "region": "China",
- "province": "Guangdong",
- "city": "Canton",
- "browser": "Chrome",
- "os": "Windows 10",
- "platform": "Windows",
- "loginTime": "2025-04-05T20:34:00+08:00",
- "isOnline": true,
- "isCurrentSession": false
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve the SSL certificate allocated to the user
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 SSL certificate UUID |
isChain | boolean Default: false Example: isChain=true Whether to get the certificate chain |
needRootCa | boolean Default: true Example: needRootCa=true Whether to get the root CA certificate in the chain |
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve all CA information bound to your own account (paged retrieval)
keyword | string Example: keyword=3885be11-4084-4538-9fa0-70ffe4c4cbe0 Search keywords (Can be UUID, comments) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "algorithm": "RSA",
- "keySize": 2048,
- "owner": "gregPerlinLi",
- "parentCa": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "comment": "Cert Vault Default Intermediate Certificate Authority",
- "available": true,
- "notBefore": "2025-03-23T10:14:45+08:00",
- "notAfter": "2035-03-21T10:14:45+08:00",
- "createdAt": "2025-03-18T11:10:14+08:00",
- "modifiedAt": "2025-03-23T10:14:45+08:00"
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Obtain the CA certificate allocated to the user
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
isChain | boolean Default: false Example: isChain=true Whether to get the certificate chain |
needRootCa | boolean Default: true Example: needRootCa=true Whether to get the root CA certificate in the chain |
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Batch delete users
Username list of the users to be deleted
[- "string"
]
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Create multiple new users (i.e., import users)
List of create user entities
username required | string Username of the user |
displayName required | string Display name of the user |
email required | string Email address of the user |
password required | string Password of the user |
role required | integer <int32> Role of the user (1: User, 2: Admin, 3: Superadmin) |
[- {
- "username": "hello",
- "displayName": "Hello Admin",
- "email": "k8qscp.k65@yahoo.com.cn",
- "password": 1234567890,
- "role": 2
}
]
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Create a new user
Create user entity
username required | string Username of the user |
displayName required | string Display name of the user |
email required | string Email address of the user |
password required | string Password of the user |
role required | integer <int32> Role of the user (1: User, 2: Admin, 3: Superadmin) |
{- "username": "hello",
- "displayName": "Hello Admin",
- "email": "k8qscp.k65@yahoo.com.cn",
- "password": 1234567890,
- "role": 2
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Batch update user roles
List of update user role entities
username required | string Username of the user whose role information needs to be updated |
role required | integer <int32> Role of the user (1: User, 2: Admin, 3: Superadmin) |
[- {
- "username": "john.doe",
- "role": 2
}
]
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Update user information
username required | string Example: user Username of the user to be updated |
Update user entity
displayName required | string Display name of the user |
email required | string Email of the user |
oldPassword required | string Old password of the user |
newPassword required | string New password of the user |
{- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "oldPassword": "oldPass123",
- "newPassword": "newPass456"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Update user role
Update user role entity
username required | string Username of the user whose role information needs to be updated |
role required | integer <int32> Role of the user (1: User, 2: Admin, 3: Superadmin) |
{- "username": "john.doe",
- "role": 2
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Get all user's login records
keyword | string Example: keyword=gregPerlinLi Search keywords (username) |
status | integer <int32> Default: -1 Example: status=-1 Status of the login record (-1: all, 0: offline, 1: online) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Number of records per page |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": 1234567890,
- "username": "gregPerlinLi",
- "ipAddress": "10.18.0.1",
- "region": "China",
- "province": "Guangdong",
- "city": "Canton",
- "browser": "Chrome",
- "os": "Windows 10",
- "platform": "Windows",
- "loginTime": "2025-04-05T20:34:00+08:00",
- "isOnline": true,
- "isCurrentSession": false
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Get a user's login records
username required | string Example: gregPerlinLi Username |
status | integer <int32> Default: -1 Example: status=-1 Status of the login record (-1: all, 0: offline, 1: online) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Number of records per page |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": 1234567890,
- "username": "gregPerlinLi",
- "ipAddress": "10.18.0.1",
- "region": "China",
- "province": "Guangdong",
- "city": "Canton",
- "browser": "Chrome",
- "os": "Windows 10",
- "platform": "Windows",
- "loginTime": "2025-04-05T20:34:00+08:00",
- "isOnline": true,
- "isCurrentSession": false
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Renew the specified CA certificate
uuid required | string Example: bf35ecb1-9b67-4083-9476-e264ba153188 CA UUID |
New expiry
{- "expiry": 3650
}
{- "code": 200,
- "msg": "Success",
- "data": {
- "uuid": "bf35ecb1-9b67-4083-9476-e264ba153188",
- "algorithm": "RSA",
- "keySize": 2048,
- "privkey": null,
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "parentCa": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "notBefore": "2025-03-23T12:49:45.733",
- "notAfter": "2025-09-19T12:49:45.733",
- "comment": "Cert Vault Default Intermediate Certificate Authority"
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve all CA information under this username (paged)
keyword | string Example: keyword=3885be11-4084-4538-9fa0-70ffe4c4cbe0 Search keywords (Can be UUID, comments) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "uuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "algorithm": "RSA",
- "keySize": 2048,
- "owner": "gregPerlinLi",
- "parentCa": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "comment": "Cert Vault Default Intermediate Certificate Authority",
- "available": true,
- "notBefore": "2025-03-23T10:14:45+08:00",
- "notAfter": "2035-03-21T10:14:45+08:00",
- "createdAt": "2025-03-18T11:10:14+08:00",
- "modifiedAt": "2025-03-23T10:14:45+08:00"
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Request a new CA certificate
Request certificate entity
caUuid | string CA UUID |
allowSubCa | boolean Whether to allow sub-CA |
algorithm | string Algorithm (Can be RSA, EC, Ed25519) |
keySize | integer <int32> Key Size |
country required | string Country |
province required | string Province |
city required | string City |
organization required | string Organization |
organizationalUnit required | string Organizational Unit |
commonName required | string Common Name |
expiry required | integer <int32> Expiry (day) |
Array of objects (SubjectAltName) Subject Alternative Name | |
comment | string Comment |
{- "caUuid": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "country": "China",
- "province": "Guangdong",
- "city": "Canton",
- "organization": "CertVault Develop Org",
- "organizationalUnit": "CertVault Dev",
- "commonName": "CertVault Intermediate CA",
- "expiry": 180,
- "comment": "Cert Vault Default Intermediate Certificate Authority"
}
{- "code": "200",
- "msg": "Success",
- "data": {
- "uuid": "bf35ecb1-9b67-4083-9476-e264ba153188",
- "algorithm": "RSA",
- "keySize": 2048,
- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUV2QUl...",
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "parentCa": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "notBefore": "2025-03-23T12:49:45+08:00",
- "notAfter": "2025-09-19T12:49:45.733+08:00",
- "comment": "Cert Vault Default Intermediate Certificate Authority"
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Obtain the CA private key allocated to the user (Need user password verify)
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
Confirm password
{- "password": "123456"
}
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Import a CA certificate and private key allocated to the user
Import certificate entity
privkey required | string Private key of the certificate |
certificate required | string Certificate of the certificate |
comment required | string Comment of the certificate |
{- "privkey": "LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUpRd0lCQURBTkJn...",
- "certificate": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUdFekNDQ...",
- "comment": "Testing CA"
}
{- "code": 200,
- "msg": "Success",
- "data": {
- "uuid": "bf35ecb1-9b67-4083-9476-e264ba153188",
- "algorithm": "RSA",
- "keySize": 2048,
- "privkey": null,
- "cert": "LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUV2QUl...",
- "parentCa": "3885be11-4084-4538-9fa0-70ffe4c4cbe0",
- "allowSubCa": true,
- "notBefore": "2025-03-23T12:49:45.733",
- "notAfter": "2025-09-19T12:49:45.733",
- "comment": "Cert Vault Default Intermediate Certificate Authority"
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Batch unbind users from specified CA certificate
List of CA-User binding entities
caUuid required | string The UUID of the Certificate Authority (CA) |
username required | string The username of the user associated with the CA binding |
[- {
- "caUuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "username": "john.doe"
}
]
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Batch bind users to specified CA certificate
List of CA-User binding entities
caUuid required | string The UUID of the Certificate Authority (CA) |
username required | string The username of the user associated with the CA binding |
[- {
- "caUuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "username": "john.doe"
}
]
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Unbind a specified CA certificate from a user
CA-User binding entity
caUuid required | string The UUID of the Certificate Authority (CA) |
username required | string The username of the user associated with the CA binding |
{- "caUuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "username": "john.doe"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Bind a specified CA for user to sign SSL certificates
CA-User binding entity
caUuid required | string The UUID of the Certificate Authority (CA) |
username required | string The username of the user associated with the CA binding |
{- "caUuid": "2f2d63a8-b29c-4404-ae10-81f5ff023a69",
- "username": "john.doe"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Update the comment of the CA allocated to the user
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
Update comment
{- "comment": "This is a comment"
}
{- "code": 200,
- "msg": "Success",
- "data": null,
- "timestamp": "2025-04-04T16:16:02+08:00"
}
Modify the availability of the CA allocated to the user
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
{- "code": "200",
- "msg": "Success",
- "data": true,
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve all users (paged)
keyword | string Example: keyword=user Search keywords (Can be username, display name, and email) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Calculate the total number of users
role | integer <int32> Default: 0 Role of the user (0: all user, 1: user, 2: admin, 3: superadmin) |
{- "code": "200",
- "msg": "Success",
- "data": 0,
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Count the number of SSL/CA certificates signed by a CA certificate
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
caOrSsl | boolean Default: false Flag of CA or SSL (true if count ca certificates, false if count ssl certificates) |
{- "code": "200",
- "msg": "Success",
- "data": 0,
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Obtain the CA certificate allocated to the user
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
isChain | boolean Default: false Example: isChain=true Whether to get the certificate chain |
needRootCa | boolean Default: true Example: needRootCa=true Whether to get the root CA certificate in the chain |
{- "code": "200",
- "msg": "Success",
- "data": "string",
- "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve all user information bound to a ca (paged)
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
keyword | string Example: keyword=user Search keywords (Can be username, display name, and email) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Retrieve all user information not bound to a ca (paged)
uuid required | string Example: 3885be11-4084-4538-9fa0-70ffe4c4cbe0 CA UUID |
keyword | string Example: keyword=user Search keywords (Can be username, display name, and email) |
page | integer <int32> Default: 1 Example: page=1 Page number |
limit | integer <int32> Default: 10 Example: limit=10 Page limit |
orderBy | string Example: orderBy=username Order by field |
isAsc | boolean Default: true Example: isAsc=true Ascending or descending |
{- "code": "200",
- "msg": "Success",
- "data": {
- "total": "100",
- "list": [
- {
- "username": "john.doe",
- "displayName": "John Doe",
- "email": "john.doe@example.com",
- "role": 2,
- "isPasswordInitialized": true
}
]
}, - "timestamp": "2025-03-19T01:38:31+08:00"
}
Count the number of user requested CA certificates
condition | string Default: "none" Example: condition=none Condition of the CA certificate |
{- "code": "200",
- "msg": "Success",
- "data": 0,
- "timestamp": "2025-03-19T01:38:31+08:00"
}