{ "ownerApp" : "Orchestrator", "name" : "group_created", "createBy" : "Marco Lettere", "description": "Handle workflow related to Portal event group_created", "version" : 1, "ownerEmail" : "marco.lettere@nubisware.com", "inputParameters" : ["user", "group"], "tasks" : [ { "name": "LAMBDA_TASK", "taskReferenceName": "init", "type": "LAMBDA", "inputParameters": { "root_vo": "{{ root_vo }}", "keycloak": "{{ keycloak }}/{{ keycloak_realm }}", "keycloak_admin" : "{{ keycloak_admin }}/{{ keycloak_realm }}", "clientId" : "${workflow.input.group}", "scriptExpression": "var tree = $.clientId.split('%2F'); return { 'tree' : tree, 'child': tree[tree.length-1], 'append' : tree.slice(0,-1).join('/'), 'name' : tree.join('/'), encoded_root_vo : encodeURI($.root_vo)}" } }, { "name" : "pyrest", "taskReferenceName" : "authorize", "type" : "SIMPLE", "inputParameters" : { "url" : "{{ keycloak }}/master/protocol/openid-connect/token", "method" : "POST", "headers" : { "Accept" : "application/json" }, "body" : { "client_id" : "orchestrator", "client_secret" : "{{ keycloak_auth_master }}", "grant_type" : "client_credentials" } } }, { "name" : "fork_join", "taskReferenceName" : "preliminary_fork", "type" : "FORK_JOIN", "forkTasks" : [ [ { "name" : "pyrest", "taskReferenceName" : "create_client", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients", "body" : { "clientId": "${init.input.clientId}", "name": "${init.output.result.name}", "description": "Client representation for ${init.output.result.name} context", "rootUrl": "http://localhost${init.output.result.name}", "enabled": true, "serviceAccountsEnabled": true, "standardFlowEnabled": true, "authorizationServicesEnabled": true, "publicClient": false, "fullScopeAllowed" : false, "protocol": "openid-connect" }, "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json" } } }, { "name": "LAMBDA_TASK", "taskReferenceName": "extract_client_id", "type": "LAMBDA", "inputParameters": { "client_location" : "${create_client.output.headers.location}", "scriptExpression": "var client_id = $.client_location.split('/').pop(); return {'client_id' : client_id}" } }, { "name" : "pyrest", "taskReferenceName" : "get_default_policies", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/policy", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "get_default_resource", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/resource", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "delete_default_policy1", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/policy/${get_default_policies.output.body[0].id}", "method" : "DELETE", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "delete_default_policy2", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/policy/${get_default_policies.output.body[1].id}", "method" : "DELETE", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "create_permission", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/permission/resource", "body" : { "name": "Default Permission", "description": "", "type" : "resource", "logic": "POSITIVE", "decisionStrategy": "AFFIRMATIVE", "resources" : ["${get_default_resource.output.body[0]._id}"] }, "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json", "Accept" : "application/json" } } } ], [ { "name" : "pyrest", "taskReferenceName" : "get_rootvo", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients?clientId=${init.output.result.encoded_root_vo}", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "get_rootvo_roles", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${get_rootvo.output.body[0].id}/roles", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } } ] ] }, { "name" : "join", "type" : "JOIN", "taskReferenceName" : "preliminary_fork_join", "joinOn": [ "create_permission", "get_rootvo_roles"] }, { "name" : "fork_join", "taskReferenceName" : "fork_role_creation", "type" : "FORK_JOIN", "forkTasks" : [ [{ "name" : "pyrest", "taskReferenceName" : "create_role_member", "type" : "SIMPLE", "inputParameters" : { "url" : "${create_client.output.headers.location}/roles", "body" : { "clientRole" : true, "name" : "Member", "description" : "Simple membership for ${init.output.result.name}" }, "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "get_back_role_member", "type" : "SIMPLE", "inputParameters" : { "url" : "${create_role_member.output.headers.location}", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name": "jq_1", "taskReferenceName": "to_array", "type": "JSON_JQ_TRANSFORM", "inputParameters": { "role": "${get_back_role_member.output.body}", "queryExpression" : ".role" } }, { "name" : "pyrest", "taskReferenceName" : "add_role_member_as_component_of_infrastructure_member", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/roles/Infrastructure-Member/composites", "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json" }, "body" : "${to_array.output.resultList}" } }, { "name" : "pyrest", "taskReferenceName" : "create_role_policy_member", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/clients/${extract_client_id.output.result.client_id}/authz/resource-server/policy/role", "body" : { "name": "Member_policy", "description": "", "type" : "role", "logic": "POSITIVE", "decisionStrategy": "UNANIMOUS", "roles" : [ { "id" : "${get_back_role_member.output.body.id}", "required" : true } ] }, "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json", "Accept" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "create_kc_group", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/groups", "body" : { "name" : "${init.output.result.child}" }, "method" : "POST", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Content-Type" : "application/json" } } }, { "name" : "pyrest", "taskReferenceName" : "list_kc_groups", "type" : "SIMPLE", "inputParameters" : { "url" : "${init.input.keycloak_admin}/groups", "method" : "GET", "headers" : { "Authorization" : "Bearer ${authorize.output.body.access_token}", "Accept" : "application/json" } } }, { "name": "LAMBDA_TASK", "taskReferenceName": "prepare", "type": "LAMBDA", "inputParameters": { "append" : "${init.output.result.append}", "location" : "${create_kc_group.output.headers.location}", "client_location" : "${create_client.output.headers.location}", "groups" : "${list_kc_groups.output.body}", "scriptExpression": "var newid=$.location.split('/').pop(); var client_id = $.client_location.split('/').pop(); function recurse(inp){for(var i=0;i