Title: ABAC_Level1 Vulnerability on DELETE:/api/v1/transfers/{id}
Project: NetBanking API
Description: The ABAC exploit allows an attacker to read, modify, delete, add and perform actions on customer/un-authorized data.
Assertion Name: Attribute Based Access Control 1 (ABAC) ( 1 )
Overview: Access Control (or Authorization) is the process of granting or denying specific requests from a user, program, or process. Access control also involves the act of granting and revoking those privileges. Attribute Based Access Control (ABAC) will grant or deny user requests based on arbitrary attributes of the user and arbitrary attributes of the object, and environment conditions that may be globally recognized and more relevant to the policies at hand.
'Attribute-based-access-control 1' identifies top-level/non-dependent resource/data/record vulnerabilities. Looks for private user/account data being illegally read, written, updated, deleted or operated by other users or tenants or accounts.
This scanner requires a private-account/user to create private data/resources e.g. UserA. And it also requires other users who shouldn't have any access to UserA's data like UserB, UserC, & UserD based on your App multi-tenancy model. e.g. UserA can be a user from tenant/org-a and UserB can be a user in tenant-b and UserC can be a user in tenant-c with admin privileges.
APIs tend to expose endpoints that handle object identifiers, creating a wide attack surface Level Access Control issue. Object-level authorization checks should be considered in every function that accesses a data source using input from the user.
Severity: OWASP 2019 API Top 10 ranks ABAC vulnerabilities at Top 1 position and is named Broken Object Level Authorization. ( 2 )
Vulnerability Impact: With flawed or broken ABAC security control policy in place, The following are some of the consequences.
Unauthorized access can result in data disclosure to unauthorized parties, data loss, or data manipulation.
Unauthorized access to objects can also lead to full account takeover.
Exploitation: Attackers can exploit API endpoints that are vulnerable to broken object level authorization by manipulating the ID of an object that is sent within the request. This may lead to unauthorized access to sensitive data. This issue is extremely common in API-based applications because the server component usually does not fully track the client’s state, and instead, relies more on parameters like object IDs, that are sent from the client to decide which objects to access.
Remediation: The following techniques may be checked for ensuring RBAC is in place ( 2 ) ( 3 ) ( 4 ).
Implement a proper authorization mechanism that relies on the user policies and hierarchy.
Prefer not to use an ID that has been sent from the client, but instead use an ID that is stored in the session object when accessing a database record by the record ID.
Use an authorization mechanism to check if the logged-in user has access to perform the requested action on the record in every function that uses an client input to access a record in the database.
Prefer to use random and unpredictable values as GUIDs for records’ IDs.
Write tests to evaluate the authorization mechanism. Do not deploy vulnerable changes that break the tests.
Title: ABAC_Level1 Vulnerability on DELETE:/api/v1/transfers/{id} Project: NetBanking API Description: The ABAC exploit allows an attacker to read, modify, delete, add and perform actions on customer/un-authorized data.
Assertion Name: Attribute Based Access Control 1 (ABAC) ( 1 )Overview: Access Control (or Authorization) is the process of granting or denying specific requests from a user, program, or process. Access control also involves the act of granting and revoking those privileges. Attribute Based Access Control (ABAC) will grant or deny user requests based on arbitrary attributes of the user and arbitrary attributes of the object, and environment conditions that may be globally recognized and more relevant to the policies at hand.
'Attribute-based-access-control 1' identifies top-level/non-dependent resource/data/record vulnerabilities. Looks for private user/account data being illegally read, written, updated, deleted or operated by other users or tenants or accounts.
This scanner requires a private-account/user to create private data/resources e.g. UserA. And it also requires other users who shouldn't have any access to UserA's data like UserB, UserC, & UserD based on your App multi-tenancy model. e.g. UserA can be a user from tenant/org-a and UserB can be a user in tenant-b and UserC can be a user in tenant-c with admin privileges.
APIs tend to expose endpoints that handle object identifiers, creating a wide attack surface Level Access Control issue. Object-level authorization checks should be considered in every function that accesses a data source using input from the user.
Severity: OWASP 2019 API Top 10 ranks ABAC vulnerabilities at Top 1 position and is named Broken Object Level Authorization. ( 2 )
Vulnerability Impact: With flawed or broken ABAC security control policy in place, The following are some of the consequences.
Remediation: The following techniques may be checked for ensuring RBAC is in place ( 2 ) ( 3 ) ( 4 ).
Risk: ABAC_Level1 Severity: High API Endpoint: http://95.217.118.53:8080/api/v1/transfers/2c9280847452ae00017493da32484997 Environment: Master Playbook: ApiV1TransfersIdDeleteUseraCreateTransfersUsercDisallowAbac Researcher: [apisec Bot] QUICK TIPS Suggestion: Add access-control checks on incoming requests against all data calls. Effort Estimate: 2.0 Wire Logs: 10:19:44 [D] [ TCUAIAbac] : URL [http://95.217.118.53:8080/api/v1/transfers] 10:19:44 [D] [ TCUAIAbac] : Method [POST] 10:19:44 [D] [ TCUAIAbac] : Auth [UserA] 10:19:44 [D] [ TCUAIAbac] : Request [{ "confirmed" : false, "createdBy" : "", "createdDate" : "", "description" : "AC60yDLd", "id" : "", "inactive" : false, "location" : "AC60yDLd", "modifiedBy" : "", "modifiedDate" : "", "transactionType" : "CHECK", "version" : "" }] 10:19:44 [D] [ TCUAIAbac] : Request-Headers [{Content-Type=[application/json], Accept=[application/json], Authorization=[**********]}] 10:19:44 [D] [ TCUAIAbac] : Response [{ "requestId" : "None", "requestTime" : "2020-09-15T22:19:44.589+0000", "errors" : false, "messages" : [ ], "data" : { "id" : "2c9280847452ae00017493da32484997", "createdBy" : "2c928085730548680173054c9f720003", "createdDate" : "2020-09-15T22:19:44.584+0000", "modifiedBy" : "2c928085730548680173054c9f720003", "modifiedDate" : "2020-09-15T22:19:44.584+0000", "version" : null, "inactive" : false, "location" : "ivRcFbhB", "description" : "ivRcFbhB", "confirmed" : false, "transactionType" : "CHECK" }, "totalPages" : 0, "totalElements" : 0 }] 10:19:44 [D] [ TCUAIAbac] : Response-Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=NjZkYzA3OGUtYzE3Yy00OTcyLWJjMTEtNzdhNDRlYWUyNDc1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:44 [D] [ TCUAIAbac] : StatusCode [200] 10:19:44 [D] [ TCUAIAbac] : Time [739] 10:19:44 [D] [ TCUAIAbac] : Size [485] 10:19:44 [I] [ TCUAIAbac] : Assertion [@StatusCode == 200 AND @Response.errors == false] resolved-to [200 == 200 AND false == false] result [Passed] 10:19:45 [D] [TCUAIAHeaders] : Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=NjZkYzA3OGUtYzE3Yy00OTcyLWJjMTEtNzdhNDRlYWUyNDc1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:45 [D] [TCUAIAHeaders] : Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=NjZkYzA3OGUtYzE3Yy00OTcyLWJjMTEtNzdhNDRlYWUyNDc1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:45 [D] [ TCUAIA]] : Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=NjZkYzA3OGUtYzE3Yy00OTcyLWJjMTEtNzdhNDRlYWUyNDc1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:45 [D] [ TCUAIA]] : Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=NjZkYzA3OGUtYzE3Yy00OTcyLWJjMTEtNzdhNDRlYWUyNDc1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:45 [D] [AVTIDUCTUDAbac] : URL [http://95.217.118.53:8080/api/v1/transfers/2c9280847452ae00017493da32484997] 10:19:45 [D] [AVTIDUCTUDAbac] : Method [DELETE] 10:19:45 [D] [AVTIDUCTUDAbac] : Auth [UserC] 10:19:45 [D] [AVTIDUCTUDAbac] : Request [] 10:19:45 [D] [AVTIDUCTUDAbac] : Request-Headers [{Accept=[application/json], Content-Type=[application/json], Authorization=[**********]}] 10:19:45 [D] [AVTIDUCTUDAbac] : Response [{ "requestId" : "None", "requestTime" : "2020-09-15T22:19:45.540+0000", "errors" : false, "messages" : [ ], "data" : null, "totalPages" : 0, "totalElements" : 0 }] 10:19:45 [D] [AVTIDUCTUDAbac] : Response-Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=ZGQxN2EzYmYtZjQyOC00NzM3LTg4YTQtN2E3OThkMmQzMDM0; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:44 GMT]}] 10:19:45 [D] [AVTIDUCTUDAbac] : StatusCode [200] 10:19:45 [D] [AVTIDUCTUDAbac] : Time [581] 10:19:45 [D] [AVTIDUCTUDAbac] : Size [139] 10:19:45 [E] [AVTIDUCTUDAbac] : Assertion [@StatusCode == 401 OR @StatusCode == 404 OR @Response.errors == true] resolved-to [200 == 401 OR 200 == 404 OR false == true] result [Failed] 10:19:46 [D] [AVTIDTAAbac] : URL [http://95.217.118.53:8080/api/v1/transfers/2c9280847452ae00017493da32484997] 10:19:46 [D] [AVTIDTAAbac] : Method [DELETE] 10:19:46 [D] [AVTIDTAAbac] : Request [null] 10:19:46 [D] [AVTIDTAAbac] : Auth [UserA] 10:19:46 [D] [AVTIDTAAbac] : Request-Headers [{Content-Type=[application/json], Accept=[application/json], Authorization=[Basic dXNlcjFAbmV0YmFua2luZy5pbzphZG1pbjEyMyQ=]}] 10:19:46 [D] [AVTIDTAAbac] : Response [{ "requestId" : "None", "requestTime" : "2020-09-15T22:19:46.116+0000", "errors" : true, "messages" : [ { "type" : "ERROR", "key" : "", "value" : "No class com.fxlabs.issues.dao.entity.account.Transfers entity with id 2c9280847452ae00017493da32484997 exists!" } ], "data" : null, "totalPages" : 0, "totalElements" : 0 }] 10:19:46 [D] [AVTIDTAAbac] : Response-Headers [{X-Content-Type-Options=[nosniff], X-XSS-Protection=[1; mode=block], Cache-Control=[no-cache, no-store, max-age=0, must-revalidate], Pragma=[no-cache], Expires=[0], X-Frame-Options=[DENY], Set-Cookie=[SESSION=MzE0OGIyOTctNzM5Yi00N2RhLTkxODktNjFlOWE5ZmY2Yzk1; Path=/; HttpOnly], Content-Type=[application/json;charset=UTF-8], Transfer-Encoding=[chunked], Date=[Tue, 15 Sep 2020 22:19:45 GMT]}] 10:19:46 [D] [AVTIDTAAbac] : StatusCode [200] 10:19:46 [D] [AVTIDTAAbac] : Time [568] 10:19:46 [D] [AVTIDTAAbac] : Size [285] 10:19:46 [I] [AVTIDUCTUDAbac] : Assertion [@StatusCode == 200] resolved-to [200 == 200] result [Passed] IMPORTANT LINKS Vulnerability Details: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/recommendations/8a8084a0748c80b3017493da3b9e7f37/details Project: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/jobs Environment: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/environments/8a8081766fc3e2a1016fc421d7155a15/edit Scan Dashboard: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/jobs/8a8081766fc3e2a1016fc4230f426628/runs/8a8084a0748c80b3017493da11287f2f Playbook: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/template/ApiV1TransfersIdDeleteUseraCreateTransfersUsercDisallowAbac Coverage: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/configuration Code Sample: https://cloud.fxlabs.io/#/app/projects/8a8081766fc3e2a1016fc421d6e55a13/recommendations/8a8084a0748c80b3017493da3b9e7f37/codesamples PS: Please contact support@apisec.ai for apisec access and login issues. --- apisec Bot ---