This content applies to WaaS 1.0 only. We highly recommend that you upgrade to WaaS 2.0.
Cobo Argus is a smart contract-based on-chain digital asset management solution. Using Cobo Safe as its functionality layer, Cobo Argus implements role-based access controls to help you improve workflow efficiency and enhance internal risk management. The deployment structure of Cobo Safe in Cobo Argus is as follows:

Cobo Argus, Cobo Safe Account is used to manage the access control policies of the Safe Wallet. Cobo Safe Account uses ArgusRootAuthorizer as its Root Authorizer. Users can then configure Roles and Sub-Authorizers based on their business needs:
- Each Sub-Authorizerindicates one type ofPermission.
- If a Roleis associated with multipleSub-Authorizers, it indicates that thisRoleis associated with a set ofPermissions.
- Different types of Rolescan be combined to form anAuthorization Strategy. This allows theDelegateto complete a set of pre-configured investment operations in a DeFi protocol.Cobo Argushas integrated a number ofAuthorization Strategiesby default.
Workflow
When aSafe Owner delegates Roles to a Delegate, the workflow is as follows:  
- Safe Ownercreates a- Cobo Safe Accountand enables a- Moduleon Safe.
- Safe Ownerconfigures the- Root Authorizerand- Role Manager.
- Safe Owneradds the address of the- Delegateto the whitelist under the- Cobo Safe Account.
- Safe Owneradds- Sub-Authorizersand- Rolesto the- Root Authorizer.
- Safe Ownerassigns- Rolesto the- Delegate.
Delegate executes a transaction, the workflow is as follows: 
- Delegatesends a transaction via the- Cobo Safe Account.
- Cobo Safe Accountvalidates whether the address of the- Delegatehas been whitelisted. If no, the transaction will be rejected. If yes, the transaction will be sent to the- Root Authorizer.
- Root Authorizerqueries the- Rolesassociated with the- Delegatewith the help of a- Role Manager.
- Root Authorizerlocates one or multiple- Sub-Authorizersassociated with each- Role.
- If the transaction passes validation from any of these Sub-Authorizers, it will be approved. Otherwise, the transaction will be rejected.
- Once the transaction is approved, Cobo Safe Accountwill callSafeto initiate the transaction.
- After the transaction is executed, Root Authorizerwill validate the transaction viapostExecCheck.
- The transaction sent by the Delegateis completed.
Feel free to share your feedback to improve our documentation!
