[<prev] [next>] [day] [month] [year] [list]
Message-ID: <54639FD1.7050005@vulnerability-lab.com>
Date: Wed, 12 Nov 2014 18:58:41 +0100
From: Vulnerability Lab <research@...nerability-lab.com>
To: fulldisclosure@...lists.org
Subject: [FD] PayPal Inc Bug Bounty #88 - Filter Bypass & Arbitrary Code
Execution Vulnerability
Document Title:
===============
PayPal Inc Bug Bounty- Filter Bypass & Arbitrary Code Execution Vulnerability
References (Source):
====================
http://www.vulnerability-lab.com/get_content.php?id=936
Video: http://www.vulnerability-lab.com/get_content.php?id=1275
Vulnerability Magazine: http://magazine.vulnerability-db.com/?q=articles/2014/11/05/paypal-inc-fixed-filter-bypass-profile-code-execution-during-infrastructure
Release Date:
=============
2014-11-05
Vulnerability Laboratory ID (VL-ID):
====================================
936
Common Vulnerability Scoring System:
====================================
9.1
Product & Service Introduction:
===============================
PayPal is a global e-commerce business allowing payments and money transfers to be made through the Internet. Online money
transfers serve as electronic alternatives to paying with traditional paper methods, such as checks and money orders. Originally,
a PayPal account could be funded with an electronic debit from a bank account or by a credit card at the payer s choice. But some
time in 2010 or early 2011, PayPal began to require a verified bank account after the account holder exceeded a predetermined
spending limit. After that point, PayPal will attempt to take funds for a purchase from funding sources according to a specified
funding hierarchy. If you set one of the funding sources as Primary, it will default to that, within that level of the hierarchy
(for example, if your credit card ending in 4567 is set as the Primary over 1234, it will still attempt to pay money out of your
PayPal balance, before it attempts to charge your credit card). The funding hierarchy is a balance in the PayPal account; a
PayPal credit account, PayPal Extras, PayPal SmartConnect, PayPal Extras Master Card or Bill Me Later (if selected as primary
funding source) (It can bypass the Balance); a verified bank account; other funding sources, such as non-PayPal credit cards.
The recipient of a PayPal transfer can either request a check from PayPal, establish their own PayPal deposit account or request
a transfer to their bank account.
PayPal is an acquirer, performing payment processing for online vendors, auction sites, and other commercial users, for which it
charges a fee. It may also charge a fee for receiving money, proportional to the amount received. The fees depend on the currency
used, the payment option used, the country of the sender, the country of the recipient, the amount sent and the recipient s account
type. In addition, eBay purchases made by credit card through PayPal may incur extra fees if the buyer and seller use different currencies.
On October 3, 2002, PayPal became a wholly owned subsidiary of eBay. Its corporate headquarters are in San Jose, California, United
States at eBay s North First Street satellite office campus. The company also has significant operations in Omaha, Nebraska, Scottsdale,
Arizona, and Austin, Texas, in the United States, Chennai, Dublin, Kleinmachnow (near Berlin) and Tel Aviv. As of July 2007, across
Europe, PayPal also operates as a Luxembourg-based bank.
On March 17, 2010, PayPal entered into an agreement with China UnionPay (CUP), China s bankcard association, to allow Chinese consumers
to use PayPal to shop online.PayPal is planning to expand its workforce in Asia to 2,000 by the end of the year 2010.
(Copy of the Homepage: www.paypal.com) [http://en.wikipedia.org/wiki/PayPal]
Abstract Advisory Information:
==============================
The Vulnerability Laboratory Research Team discovered a persistent script code injection web vulnerability in the official PayPal Inc core application.
Vulnerability Disclosure Timeline:
==================================
2013-04-25: Researcher Notification & Coordination (PayPal Inc - Bug Bounty Program)
2013-04-26: Vendor Notification (PayPal Inc - Bug Bounty Program)
2013-05-01: Vendor Response/Feedback (PayPal Inc - Bug Bounty Program)
2013-09-12: Vendor Response/Feedback (Ebay Inc - Bug Bounty Program)
2014-10-01: Vendor Response/Feedback (Ebay Inc - Bug Bounty Program)
2014-10-12: Vendor Fix/Patch (PayPal Inc - Developer Team)
2014-11-04: Public Disclosure (Vulnerability Laboratory)
Discovery Status:
=================
Published
Affected Product(s):
====================
PayPal Inc
Product: Core Application 2013 Q1
Exploitation Technique:
=======================
Remote
Severity Level:
===============
Critical
Technical Details & Description:
================================
A system specific arbitrary code execution vulnerability has been discovered in the official in the official PayPal Inc Web-Application & API.
A filter bypass and persistent bug has also been revealed during the tests in the same vulnerable parameter location.
The system specific arbitrary code execution vulnerability is located in the developer api portal with connection and account access to the
paypal portal api. First the attacker registers an user account and includes to the `cardholder confidential` and `accountSelName` value own
malicious persistent script codes or local web-server files. To attack, the help center data of the malicious profile requires a second
registration to the developer api portal with same credentials (connected). The accountSelName and the confidential values are not limited
on input. The attacker is able to load script codes but can also remotly execute arbitrary codes to access local web-server files or configs.
The filter bypass occurs during the execution onclick by opening the profile. The trusted context of the dev api user account will be streamed
through the help center link on GET method requests. The regular filter of paypal prevents the external inject of frames to other websites but
in case of this issue the trusted context is directly executed on top of the profile. The execution and inject can occur remotly by attackers
and the attack typus is pending from persistent xss to arbitrary code execution and local web-server file request through the profile. The web-server
and misconfiguration allows the attacker to for example include a frame with a local request through the trusted context to capture unauthorized data
of the system. A webshell inject could also be possible during the execution point of the paypal users profile.
The attack vector is on the application-side of the paypal service and the injection request method is POST (dev api & help center). The security risk
of the local command/path inject vulnerability is estimated as medium with a cvss (common vulnerability scoring system) count of 9.1.
Exploitation of the system specific code execution vulnerability requires a low privileged paypal inc account with restricted access and no user interaction.
Successful exploitation of the vulnerability results in unauthorized execution of system specific codes, webshell injects via POST method, unauthorized path/file
value requests to compromise the application or the connected module components.
Request Method(s):
[+] POST
Vulnerable Module(s):
[+] helpcenter/home/ ( https://www.paypal.com/webapps/helpcenter/home/ )
[+] developer.paypal.com ( https://developer.paypal.com/webapps/developer/support )
Vulnerable Parameter(s):
[+] accountSelName confidential
[+] confidential
Affected Module(s):
[+] PayPal Inc – Profile User Index (Main) – Execution through >
https://developer.paypal.com/webapps/developer/support )
Proof of Concept (PoC):
=======================
The system specific code execution and persistent issue (filter bypass) can be exploited by remote attackers with low privileged application user account.
For security demonstration or to reproduce the security vulnerability follow the provided information and steps below to continue.
Manual Steps to reproduce the vulnerability ...
1. First register and account to the developer portal api
2. Second connect the paypal account to the help center by registration (2. to 1. also possible)
Note: On registration it`s required to include own payloads (code execution [path|file|config]or script code[html|php|js]) to the AccountSelName & cardholder confidential input.
3. Save the payload to your profile
4. Open the dev webportal & include the same data (payload) to your dev api profile values.
Note: On our tests we did but we are not if this is a requirement for a successful test.
5. Now surf to the following internal dev websitehttps://developer.paypal.com/webapps/developer/support )
Note: On bottom of the page is now the paypal support link with the malicious injected code
6. Click the "Visit PayPal Support" link
7. The website redirect to the local paypal profile with the new api template theme. The system specific code execution occurs directly in the middle were the streamed data
of the helpcenter through dev api portal will become visible. The vulnerable executable values are `AccountSelName` and cardholder `confidential` account data.
Note: If you injected script code the script code execution on the main profile request throught the dev api service or a local config/file of the web-server will be loaded.
8. Successful reproduce of the remote vulnerability in the paypal infrastructure!
Note: DETAILS $ PAYPAL TO AUTHORIZED USAGE
Reference(s):
From < https://developer.paypal.com/webapps/developer/support
Through API > https://www.paypal.com/webapps/helpcenter/home/
To < https://www.paypal.com/webapps/helpcenter/home/a [ARBITRARY CODE EXEUCTION!]
PoC: Help Center Index - confidential & accountSelName confidential
<div class="nav product merchant">
<div class="wrapper">
<div class="column_8_16" style="clear:both">
<div class="one column">
<div class="accountSelName confidential">
<div class="confidential" tabindex="0">%20>>"<<x>%20%20%20%20"><i... #[SYSTEM
SPECIFIC CODE EXECUTION OR PERSISTENT SCRIPT CODE!]
</div>
</div>
Note: Code snippet poc shows the execution of the code after the inject of the test payloads
--- PoC-Session Logs [GET] (Vulnerable Service) ---
22:28:56.757[1073ms][total 1933ms] Status: 200[OK]
GET https://developer.paypal.com/webapps/developer/support Load
Flags[LOAD_DOCUMENT_URI LOAD_INITIAL_DOCUMENT_URI ] Content Size[2841]
Mime Type[text/html]
Request Headers:
Host[developer.paypal.com]
User-Agent[Mozilla/5.0 (Windows NT 6.1; WOW64; rv:20.0) Gecko/20100101 Firefox/20.0]
Accept[text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8]
Accept-Language[en-US,en;q=0.5]
Accept-Encoding[gzip, deflate] DNT[1]
Referer[https://developer.paypal.com/webapps/developer/dashboard/test]
Cookie[cookie_check=yes; analytics=npXj01hCUWhDymxVPXy6hvRAO8mp6Vab7grsAxepOdYMdbZuOAokBTznGTV664Cfp6JTxQWQSk;
s_sess=%20c_m%3DNatural
%2520Searchpaypal%2520bug%2520bountywww.google.de%3B%20s_cc%3Dtrue%3B%20s_ppv
%3D0%3B%20tr_p1%3Ddeveloperspartaweb%252Fweb-inf%252Ftmpl%252Fdust
%252Fdashboard%252Ftest.dust%3B%20v31%3Ddeveloperspartaweb%252Fweb-inf%252Ftmpl
%252Fdust%252Fdashboard%252Ftest.dust%3B%20lt%3DSupport%255Edeveloperspartaweb
%252Fweb-inf%252Ftmpl%252Fdust%252Fdashboard%252Ftest.dust%3B%20s_sq
%3Dpaypalglobal%253D%252526pid%25253Ddeveloperspartaweb%2525252Fweb-inf
%2525252Ftmpl%2525252Fdust%2525252Fdashboard%2525252Ftest.dust%252526pidt
%25253D1%252526oid%25253Dhttps%2525253A%2525252F%2525252Fdeveloper.paypal.com
%2525252Fwebapps%2525252Fdeveloper%2525252Fsupport%252526ot%25253DA%3B; s_pers=
%20gpv_p23%3Dmain%253Amktg%253Afinancing%253A%253Aunauthhome
%7C1367009015468%3B%20s_fid%3D1C1953F2CF9A8631-0C78EF476327828D
%7C1430080136714%3B%20gpv_c43%3Ddeveloperspartaweb%252Fweb-inf%252Ftmpl
%252Fdust%252Fdashboard%252Ftest.dust%7C1367009936721%3B%20gpv_events%3Dno
%2520value%7C1367009936725%3B; ts=vreXpYrS%3D1461678158%26vteXpYrS
%3D1367009181%26vr%3D47e0e1a413e0abe0d4d0d4d0ff0230cd%26vt
%3D47e0e1a413e0abe0d4d0d4d0ff0230cc;
cwrClyrK4LoCV1fydGbAxiNL6iG=m_WedegyrDKHFdAAufD7kF5ZU6s7aO3eJRms9TW1Aqb
MaEGDtkxeY34Bm2p_Hdeq87Nxhr5c1NNBdvfBaH9eMflpanT_YGvgX2nIWI1r5A6hgqXnwf1V
sas9ZF4%7cZzbBc9qDQDohlW04oVtWtiOWLr9U0WKE6S2A0PnGDPPGjZse1c2PabDnan_fh5z
WNuEDFW%7cW-RHDrQRl1Z61RvfQtyKpy9zn2aU_q7vM0hMlqljwNAfggMISaWNpeW46G8lM5Cj0urp0%
7c1367007376; KHcl0EuY7AKSMgfvHl7J5E7hPtK=SaayQldii2iWrbaXFREEUkHzBgkDKOXS4yTeJTgI6fzQphzAG805W5l2oPSNYVPXDKaZsIUSCGQp_3;
consumer_display=USER_HOMEPAGE%3d0%26USER_TARGETPAGE
%3d0%26USER_FILTER_CHOICE%3d0%26BALANCE_MODULE_STATE
%3d1%26GIFT_BALANCE_MODULE_STATE%3d1%26LAST_SELECTED_ALIAS_ID
%3d0%26SELLING_GROUP%3d1%26PAYMENT_AND_RISK_GROUP
%3d1%26SHIPPING_GROUP%3d1%26HOME_VERSION%3d1%26USER_GROUP
%3d4294967295%26FORGOT_BUTTON_ROLE%3d56;
Apache=10.74.8.156.1367005659167493;
__utma=263370009.199482976.1367005657.1367005657.1367005657.1;
__utmb=263370009.14.10.1367005657; __utmc=263370009;
__utmz=263370009.1367005657.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none);
agzvbiaTG7XC5VaEwLQYUwrb15G=r_szrtUuBwYD4NqoIw8h2WUjW3vVbgmkVo4nfph5BOD
dMpHqO7lRZspuKjGAkR9z7t5bcKMLzkdtsatoh2iXm7MHYjLBOvx1rt8VVCMfVPPtg6_InRirel
fXNFERKV_Igy_kOgIqyiR4oRcZLDSiIvaS8gle7qLylyTdX5v4aOgK_sAq9E24anwk7d_myT6CX
UbQb-R7NqyzMw8VUepjHqSlwNyPKJghSDFGaCHdD3QjksqJQv0q9htdG0JWAQv2oHLs7G;g2bQrGu--
VIan06DHlaPDvMaBlO=E1iMJrsOOEL1cS_wHh1vvEmVHLFgVwqSZqUhJUuCJE4oazlBhxlB_
LpJ58GLANkKI5mfJmWwTdSARHKKlkoLbta2DzCBbSfQrwMrghrYzYq_
EuJAqV7lFBbj_KP8osHKEfkaCVs34_XfppcGWgfledkmJwyk
M7mKxcPYdUTJlvDcNy2sbQiMWhHTh2dhEe_
6re9gZQFjXSy6i979Lbe2UWIPZZnBCXVoMsHD0xbkgEnJqh4Bi11zJc4tS1FChXzd
niWkLTx17WhTjbpyVNE7O-wtjO9-5StitWI3azzMJTlAkA3eBtfw0yhaB70fFCpba_
yENriXQtKsJGcXAm71RAiJwiJEWBkq6iZpqkleEK69-
Q6YP1NY0Dp0B1531BjYZBrZbOAUh8m0X3_Z1-
_RddBXIrU4vnShqZgZworf2okBA7IvMfzWfyv0OfB3aLkd8xtrLCFDgdNBVERHwWHYb7_Mf
EUNJ-6JqM4koqIvLZvDDo9_DCdpfKdwTRu9vQtiB3GaRx7DgVqkOMEtxSJljmPz1HDDtC15cW;
HaC80bwXscjqZ7KM6VOxULOB534=JfvaMWVy2cPSO5bSwbHiwUc2SJBueQbZ9CDRM3vWz
xlwWnFYuoFw1sPOG8KCzk6wz61BNsMVTXCMIQZe2XogMzyRdMIjfgwT6uFt_
hD9krQVnGZvKKxHBuZd
hDMHGcgesSeWG; login_email=x01445%40gmail.com; LANG=en_US%3bDE; Gws4LBnVhSMuyYhD0wXzh01SEK=
jy0DcLqW37pTQNCEhLbqhA3QX00BcwiDqqaD7U13i0aMo
BtISTVSGbl4WlJ-_eEVAsOLl501In5N_1HJBq88q1hBV5S;
SEGM=bRdV1vB0ebq9RKdAb3xSHowCi6QnnlCiDOLNk8i1mAuLl1vTbzHQwWajSsMe8mvoW
iJtY1GnpzN4Y-sixGy7BQ; navcmd=xpt%2fCustomer_Profile%2faccount%2fprofile
%2fSellerPreference;
pNTcMTtQfrJuaJiwEnWXQ6yNxfq=GXKuXCGNvT1bsc_jz_Rx9E7VwmZZ8o3dbnxOVVVp9A
axiyWkodDxxKi4R67QRG1M5Y9fj-Wu7wfuRhtJ7-4rEJoEX8JKpG40P-
26PMeKw49jPMtad4WGiZRQSoayGXMsc582PVSkcKSwR6h6qIuMqseWjoOmQyUcBhGpGD
MpZCtdFnUeh7VG8LcUYDbLPeIrziGR7A8uFYcl2UoCzOmLGW9tjXHo849pblqKbUdA9GfnC6mXONIJL7SrRz7cZV2DeIRAUlytDT3bwKroKutZtMwkh9QxWAqJPu
Y2l18_FhlA9bLZKcbu7Hwv7-CKt4s9rk2RAfVkMUxcdUC6BxHn-5nAixQTO8fJ1Sxvm;
navlns=0.0; INSIDE_SEARCH_PARAMS=2%3bDE%3ben_US%3bEurope%2fBerlin;
SPARTAJSESSIONID=b469ade995520]
Connection[keep-alive]
Response Headers:
Date[Fri, 26 Apr 2013 20:29:00 GMT]
Server[Apache-Coyote/1.1]
X-Frame-Options[SAMEORIGIN]
Cache-Control[must-revalidate, proxy-revalidate, no-cache]
Content-Type[text/html;charset=utf-8]
Content-Language[en-US] Set-Cookie[SPARTAJSESSIONID=b469ade995520;
Domain=.paypal.com; Path=/; Secure; HttpOnly
HaC80bwXscjqZ7KM6VOxULOB534=NeCv0LpChVSb1LUO7ACci9QljSszvP1vnFucjnzDEhQA
aIJwnTGse_O1jK-v1Ix3xMf37CJzCo7mhHFiUqc_jGQ3TZCkyKw7bqsFSXjVmp1At-
QfPpYWWvNBLJ-jwrRCxbkqbW; Domain=.paypal.com; Path=/; Secure; HttpOnly
analytics=WlpqNFIvc5KQfH.5mTE.EHaym1WQXGmbYji.0XQm-
CqpTh.7j5T5WuK2VeQdeoFYVDMJ0N41Q6M; Max-Age=631138519; Expires=Tue, 26-Apr-
2033 16:44:19 GMT; Domain=.paypal.com; Path=/; Secure; HttpOnly
SPARTAJSESSIONIDV2=vsEpz8V5yOevktiKlA9Pf7Y6Dqji8U9YEYTL.
2fIuBwSPPV1H3jNv3FOduHGSyqmykhcIaPtx0;
Max-Age=0; Expires=Thu, 01-Jan-1970 00:00:10 GMT; Domain=.paypal.com; Path=/; Secure;
HttpOnly]
Vary[Accept-Encoding]
Content-Encoding[gzip]
Content-Length[2841]
Keep-Alive[timeout=5, max=100]
Connection[Keep-Alive]
Note: The session log above with the GET method request shows the request which leads to the
execution in the next session-log. The server accepts the malicious and manipulated request and
redirects via referer and non expired session to the paypal.com portals were the execution occurs.
--- PoC Session Logs [GET] (Execution) ---
22:29:06.862[3380ms][total 3380ms] Status: 200[OK]
GET https://www.paypal.com/webapps/helpcenter/home/a Load
Flags[LOAD_DOCUMENT_URI ] Content Size[5225] Mime Type[text/html]
Request Headers:
Host[www.paypal.com]
User-Agent[Mozilla/5.0 (Windows NT 6.1; WOW64; rv:20.0) Gecko/20100101 Firefox/20.0]
Accept[text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8]
Accept-Language[en-US,en;q=0.5]Accept-Encoding[gzip, deflate] DNT[1]
Referer[https://www.paypal.com/webapps/helpcenter/home/]
Cookie[Apache=10.73.8.62.1367005517929267; cookie_check=yes;
analytics=YOCH0Lef0Klib5IKj7VGth-
ESn2IJ5J4WqpvQFrb.if8hr8yIVWtwi260cfUTcb8QcddZn.uTdE; s_sess=%20c_m%3DNatural
%2520Searchpaypal%2520bug%2520bountywww.google.de%3B%20s_cc%3Dtrue%3B
%20tr_p1%3Ddeveloperspartaweb%252Fweb-inf%252Ftmpl%252Fdust%252Fsupport
%252Foverview.dust%3B%20lt%3D%3B%20s_ppv%3D93%3B%20v31%3Ddeveloperspartaweb
%252Fweb-inf%252Ftmpl%252Fdust%252Fsupport%252Foverview.dust%3B%20s_sq%3D%3B;
s_pers=%20gpv_p23%3Dmain%253Amktg%253Afinancing%253A%253Aunauthhome
%7C1367009015468%3B%20s_fid%3D1C1953F2CF9A8631-0C78EF476327828D
%7C1430080143210%3B%20gpv_c43%3Ddeveloperspartaweb%252Fweb-inf%252Ftmpl
%252Fdust%252Fsupport%252Foverview.dust%7C1367009943217%3B%20gpv_events%3Dno
%2520value%7C1367009943221%3B; bn_u=1332619451692973419; ts=vreXpYrS
%3D1461678158%26vteXpYrS%3D1367009181%26vr%3D47e0e1a413e0abe0d4d0d4d0ff0230cd
%26vt%3D47e0e1a413e0abe0d4d0d4d0ff0230cc;
cwrClyrK4LoCV1fydGbAxiNL6iG=m_WedegyrDKHFdAAufD7kF5ZU6s7aO3eJRms9TW1Aqb
MaEGDtkxeY34Bm2p_Hdeq87Nxhr5c1NNBdvfBaH9eMflpanT_YGvgX2nIWI1r5A6hgqXnwf1V
sas9ZF4%7cZzbBc9qDQDohlW04oVtWtiOWLr9U0WKE6S2A0PnGDPPGjZse1c2PabDnan_fh5z
WNuEDFW%7cW-RHDrQRl1Z61RvfQtyKpy9zn2aU_q7vM0hMlqljwNAfggMISaWNpeW46G8lM5Cj0urp0%
7c1367007376; KHcl0EuY7AKSMgfvHl7J5E7hPtK=SaayQldii2iWrbaXFREEUkHzBgkDKOXS4yTeJTgI6fzQphzAG805W5l2oPSNYVPXDKaZsIUSCGQp_3;
consumer_display=USER_HOMEPAGE%3d0%26USER_TARGETPAGE
%3d0%26USER_FILTER_CHOICE%3d0%26BALANCE_MODULE_STATE
%3d1%26GIFT_BALANCE_MODULE_STATE%3d1%26LAST_SELECTED_ALIAS_ID
%3d0%26SELLING_GROUP%3d1%26PAYMENT_AND_RISK_GROUP
%3d1%26SHIPPING_GROUP%3d1%26HOME_VERSION%3d1%26USER_GROUP
%3d4294967295%26FORGOT_BUTTON_ROLE%3d56;
agzvbiaTG7XC5VaEwLQYUwrb15G=r_szrtUuBwYD4NqoIw8h2WUjW3vVbgmkVo4nfph5BOD
dMpHqO7lRZspuKjGAkR9z7t5bcKMLzkdtsatoh2iXm7MHYjLBOvx1rt8VVCMfVPPtg6_InRirel
fXNFERKV_Igy_kOgIqyiR4oRcZLDSiIvaS8gle7qLylyTdX5v4aOgK_sAq9E24anwk7d_myT6CX
UbQb-R7NqyzMw8VUepjHqSlwNyPKJghSDFGaCHdD3QjksqJQv0q9htdG0JWAQv2oHLs7G;
g2bQrGu--
VIan06DHlaPDvMaBlO=E1iMJrsOOEL1cS_wHh1vvEmVHLFgVwqSZqUhJUuCJE4oazlBhxlB_
LpJ58GLANkKI5mfJmWwTdSARHKKlkoLbta2DzCBbSfQrwMrghrYzYq_
EuJAqV7lFBbj_KP8osHKEfkaCVs34_XfppcGWgfledkmJwyk
M7mKxcPYdUTJlvDcNy2sbQiMWhHTh2dhEe_
6re9gZQFjXSy6i979Lbe2UWIPZZnBCXVoMsHD0xbkgEnJqh4Bi11zJc4tS1FChXzd
niWkLTx17WhTjbpyVNE7O-wtjO9-5StitWI3azzMJTlAkA3eBtfw0yhaB70fFCpba_
yENriXQtKsJGcXAm71RAiJwiJEWBkq6iZpqkleEK69-
Q6YP1NY0Dp0B1531BjYZBrZbOAUh8m0X3_Z1-
_RddBXIrU4vnShqZgZworf2okBA7IvMfzWfyv0OfB3aLkd8xtrLCFDgdNBVERHwWHYb7_Mf
EUNJ-6JqM4koqIvLZvDDo9_DCdpfKdwTRu9vQtiB3GaRx7DgVqkOMEtxSJljmPz1HDDtC15cW;
HaC80bwXscjqZ7KM6VOxULOB534=HP6WwQ0eXaRr2anoOsYKF7CGBw6-
5KhwiYVS1vwLn1Dh9NqoyWEOUWyUHVFtxavpSES_UYk7occE4X3uNtyj7nWnajz1VULGuV06AmM3jy13bLcpDK959inyPjrla7w1z-
Ehm; login_email=x01445%40gmail.com;
LANG=en_US%3bDE; Gws4LBnVhSMuyYhD0wXzh01SEK=
jy0DcLqW37pTQNCEhLbqhA3QX00BcwiDqqaD7U13i0aMo
BtISTVSGbl4WlJ-_eEVAsOLl501In5N_1HJBq88q1hBV5S;
SEGM=bRdV1vB0ebq9RKdAb3xSHowCi6QnnlCiDOLNk8i1mAuLl1vTbzHQwWajSsMe8mvoW
iJtY1GnpzN4Y-sixGy7BQ; X-PP-SILOVER=name%3DLIVE6.WEB.1%26silo_version
%3D880%26app%3Dslingshot%26TIME%3D2430368337; navcmd=xpt%2fCustomer_Profile
%2faccount%2fprofile%2fSellerPreference;
pNTcMTtQfrJuaJiwEnWXQ6yNxfq=GXKuXCGNvT1bsc_jz_Rx9E7VwmZZ8o3dbnxOVVVp9A
axiyWkodDxxKi4R67QRG1M5Y9fj-Wu7wfuRhtJ7-4rEJoEX8JKpG40P-
26PMeKw49jPMtad4WGiZRQSoayGXMsc582PVSkcKSwR6h6qIuMqseWjoOmQyUcBhGpGD
MpZCtdFnUeh7VG8LcUYDbLPeIrziGR7A8uFYcl2UoCzOmLGW9tjXHo849pblqKbUdA9GfnC6mXONIJL7SrRz7cZV2DeIRAUlytDT3bwKroKutZtMwkh9QxWAqJPu
Y2l18_FhlA9bLZKcbu7Hwv7-CKt4s9rk2RAfVkMUxcdUC6BxHn-5nAixQTO8fJ1Sxvm;
navlns=0.0; INSIDE_SEARCH_PARAMS=2%3bDE%3ben_US%3bEurope%2fBerlin;
tcs=main:identity:::newsso|_eventId_submit; SPARTAJSESSIONID=4381770a8d243;
SPARTAJSESSIONIDV2=mFJuF3Td8YChLS8hsTBEDYCDlaan6SxOcEV8wCFmUQ37xGuQDc
I25.tBKhyY-IJNPQ0A8Vw-GVXFZfQAHzqpFA;
aksession=1367008449~id=cookievC+wdkyRC0UzSZWXkhBPD6dcl2wC6MkrXhAyCF24bXEAq
a0oGE8xfvt3ph8bjykqTbPzZj330+q7qNHyIj42OcCxIikuXUl0QW1dPeeycH75828YbSSh5/VWmI
MknMhGOK1SQUIF9uQ=] Connection[keep-alive]
Response Headers:
Server[Apache-Coyote/1.1]
X-Frame-Options[SAMEORIGIN]
Cache-Control[must-revalidate, proxy-revalidate, no-cache]
Content-Type[text/html;charset=UTF-8]
Content-Language[en-US]
Content-Encoding[gzip]
Content-Length[5225]
Date[Fri, 26 Apr 2013 20:29:12 GMT]
Connection[keep-alive]
Vary[Accept-Encoding]
Set-Cookie[SPARTAJSESSIONID=4381770a8d243; Domain=.paypal.com; Path=/; Secure;
HttpOnlySPARTAJSESSIONID=4381770a8d243; Domain=.paypal.com; Path=/; Secure; HttpOnly
HaC80bwXscjqZ7KM6VOxULOB534=67pQ_SbY9KcYXIZwvXf41F1UDHSPOlpuWZWBr5Syc
RDYDMkpDjL9wnHZibXjZxPWxipETeT9OLSEDymNqzEsfdBbL_pDE1cnTJ2yiEUV1isdJqbcfq_
FgpHVutAELsNqqk7uG; Domain=.paypal.com; Path=/; Secure; HttpOnly
analytics=0-AAbZ6STFaFViK65yobUytJf35vDfg1mxCQbONr6nxMY3v8tY97GBmh.
rm.LWF9zJC4dJEEJs; Max-Age=631138519; Expires=Tue, 26-Apr-2033
16:44:31 GMT; Domain=.paypal.com; Path=/; Secure; HttpOnly
SPARTAJSESSIONIDV2=wVm2OLjyw5F9VbwqocGR0TgDSghsfPAZXvCq1e1Aaap7fuaNiRX
WFyBQE14Y1Em66vpfwGMDIo5ncV1LCDFYow; Domain=.paypal.com; Path=/; Secure;
HttpOnly]
Note: The session logs above shows that the server accepted (200OK) the request and answers with the malicious code execution (GET) as response to me as user.
The service runs under the same origin policy which returns in the result of the dev through the help center. The execution can also be watched in the recorded
research video for the paypal bug bounty issue #88.
--- [ACCESS FOR PAYPAL]
Sandbox to Live Help Center Service > Account: ***********@...il.com password: merlin23
1.png
The first image explains were the vulnerable location link has been placed after the inject for the
further execution of the code during the exploitation-phase. The system specific code execution or
persistent issue can be exploited by clicking the "Visit PayPal Support" link.
2.png
The second images shows were the code execution occurs inside of the paypal inc webapps core
and api. The code execution can be triggered by two vulnerable values via POST inject. To test we
injected two payloads own frame and one local request of a web-server config file. The execution of
the code occurs obviously next to the main user profile on index after the redirect to the referer.
3.png
The third picture shows were the code execution and persistent issue with filter bypass is located.
The vulnerable values are `confidential` and `accountSelName confidential`. Both values will be
taken through the filter via referer on a redirect request with the same origin policy setup. The
execution does not only allows to inject scipt codes for xss, the issue also allows an attacker to
request local web-server files by the trusted same origin policy context request.
4.png
The 4th image shows the session tamper details next to processing to clicking the link of the
developer portal (api) to paypal.com (paypal). The tampered session through moziall shows that the
server accepted the GET request with the further visible trusted context. The server responds with
200OK and directly executes the code through the paypal.com domain in the profile user top
section.
5.png
The 5th image shows were the code execution appears to become visible in the live session tamper.
The domain https://www.paypal.com/webapps/helpcenter/home/a shows that the malicious inject
was successfully because after the path ./helpcenter/home/[x] the code execution occurs after the
filter bypass through the other services.
6.png
The 6th images only shows that the attack vector of the issue in located on the application-side of the
paypal inc online service. Proof for check was multiple GET requests during the test from the
paypal database as user.
Solution - Fix & Patch:
=======================
A solution to fix the issue could be to parse all incoming values through the same origin policy configuration of the connected
portal with the same api. The vulnerable accountselname confidential and confidential values needs to be encoded even if transfered
through andother service location. Restrict the input for registration and disallow specialchars to prevent script code injects
and code execution payloads with unauthorized file requests through the trusted paypal home webapps context.
Note: The issue should be checked by the dev team to review also the backend effect of the issues. Issue is already marked as patched 2014Q4.
Security Risk:
==============
The security risk of the of the arbitrary code execution in the confidential account value GET method request is estimated as critical. (CVSS 9.1)
Attacker can request local path values by implementation of privileged context reuqest in the referer which results in a system compromise because of
attackers are able to access unauthorized server local files.
Credits & Authors:
==================
Vulnerability Laboratory [Research Team] - Benjamin Kunz Mejri (bkm@...nerability-lab.com)
Disclaimer & Information:
=========================
The information provided in this advisory is provided as it is without any warranty. Vulnerability Lab disclaims all warranties, either expressed
or implied, including the warranties of merchantability and capability for a particular purpose. Vulnerability-Lab or its suppliers are not liable
in any case of damage, including direct, indirect, incidental, consequential loss of business profits or special damages, even if Vulnerability-Lab
or its suppliers have been advised of the possibility of such damages. Some states do not allow the exclusion or limitation of liability for
consequential or incidental damages so the foregoing limitation may not apply. We do not approve or encourage anybody to break any vendor licenses,
policies, deface websites, hack into databases or trade with fraud/stolen material.
Domains: www.vulnerability-lab.com - www.vuln-lab.com - www.evolution-sec.com
Contact: admin@...nerability-lab.com - research@...nerability-lab.com - admin@...lution-sec.com
Section: magazine.vulnerability-db.com - vulnerability-lab.com/contact.php - evolution-sec.com/contact
Social: twitter.com/#!/vuln_lab - facebook.com/VulnerabilityLab - youtube.com/user/vulnerability0lab
Feeds: vulnerability-lab.com/rss/rss.php - vulnerability-lab.com/rss/rss_upcoming.php - vulnerability-lab.com/rss/rss_news.php
Programs: vulnerability-lab.com/submit.php - vulnerability-lab.com/list-of-bug-bounty-programs.php - vulnerability-lab.com/register/
Any modified copy or reproduction, including partially usages, of this file requires authorization from Vulnerability Laboratory. Permission to
electronically redistribute this alert in its unmodified form is granted. All other rights, including the use of other media, are reserved by
Vulnerability-Lab Research Team or its suppliers. All pictures, texts, advisories, source code, videos and other information on this website
is trademark of vulnerability-lab team & the specific authors or managers. To record, list (feed), modify, use or edit our material contact
(admin@...nerability-lab.com or research@...nerability-lab.com) to get a permission.
Copyright © 2014 | Vulnerability Laboratory - Evolution Security GmbH ™
--
VULNERABILITY LABORATORY - RESEARCH TEAM
SERVICE: www.vulnerability-lab.com
CONTACT: research@...nerability-lab.com
COMPANY: Evolution Security GmbH
BUSINESS: www.evolution-sec.com
_______________________________________________
Sent through the Full Disclosure mailing list
http://nmap.org/mailman/listinfo/fulldisclosure
Web Archives & RSS: http://seclists.org/fulldisclosure/
Powered by blists - more mailing lists