scim2-cli¶
An utility command line to help you perform requests against a SCIM server, while validating input and response payloads. It also uses scim2-tester to perform a SCIM server compliance test.
What’s SCIM anyway?¶
SCIM stands for System for Cross-domain Identity Management, and it is a provisioning protocol. Provisioning is the action of managing a set of resources across different services, usually users and groups. SCIM is often used between Identity Providers and applications in completion of standards like OAuth2 and OpenID Connect. It allows users and groups creations, modifications and deletions to be synchronized between applications.
Features¶
CRUD Commands:
create,query,replaceanddeleteresources from the command lineSearch Command: Query resources using SCIM filters, sorting and pagination
Compliance Testing: Built-in
testcommand using scim2-tester to validate server RFC complianceServer Discovery: Automatic retrieval of server schemas and resource types
Dynamic CLI Options: Command options generated from server schemas
Flexible Input: Pass attributes as CLI options or pipe JSON payloads via stdin
JSON Output: Formatted JSON responses with optional indentation control
Authentication: Custom HTTP headers support for Bearer tokens and other auth methods
Installation¶
$ curl -LsSf uvx.sh/scim2-cli/install.sh | sh
Check the installation documentation for other methods.
Usage¶
Check the reference for more details.
Here is an example of resource creation:
$ scim2 --url https://auth.example --header "Authorization: Bearer 12345" create user --user-name "bjensen@example.com"
{
"schemas": ["urn:ietf:params:scim:schemas:core:2.0:User"],
"id": "2819c223-7f76-453a-919d-413861904646",
"userName": "bjensen@example.com",
"meta": {
"resourceType": "User",
"created": "2010-01-23T04:56:22Z",
"lastModified": "2011-05-13T04:42:34Z",
"version": 'W\\/"3694e05e9dff590"',
"location": "https://example.com/v2/Users/2819c223-7f76-453a-919d-413861904646",
},
}
Here is an example of resource query:
$ scim2 --url https://auth.example --header "Authorization: Bearer 12345" query user 2819c223-7f76-453a-919d-413861904646
{
"schemas": ["urn:ietf:params:scim:schemas:core:2.0:User"],
"id": "2819c223-7f76-453a-919d-413861904646",
"userName": "bjensen@example.com",
"meta": {
"resourceType": "User",
"created": "2010-01-23T04:56:22Z",
"lastModified": "2011-05-13T04:42:34Z",
"version": 'W\\/"3694e05e9dff590"',
"location": "https://example.com/v2/Users/2819c223-7f76-453a-919d-413861904646",
}
}
scim2-cli belongs in a collection of SCIM tools developed by Yaal Coop, with scim2-models, scim2-client and scim2-tester