Mayall: A Framework for Desktop JavaScript Auditing and Post-Exploitation Analysis
Abstract
:1. Introduction
- An Exploit able to take full advantage of popular Electron-based applications and providing command and control to a malicious user. Applications include Slack, Discord, etc.
- Inherent issues to Electron are highlighted and described.
- The Mayall framework, an open source and extensible security framework able to analyse and identify vulnerabilities in Node.js applications.
2. Background and Related Work
2.1. Web-Based JavaScript
2.2. Node.js and Electron
2.2.1. Node.js
2.2.2. Electron
2.3. Node Security
2.4. The npm Registry and Module Security
2.4.1. Typosquatting
2.4.2. Trojan Modules
2.5. Developer Attitudes
3. Design and Implementation
3.1. Application Auditing
3.2. appScanner.js Algorithm
3.3. nspCheck.js Algorithm
3.4. Malicious Update Process
3.4.1. Update Electron Packages
3.4.2. Enumerating Update Endpoints
3.4.3. Building Malicious Updates
3.5. Malicious Exploit Design
3.5.1. Malicious Exploit Design—A Dropper Module
Listing 1: Mayall Interaction Pseudocode—Target Code. |
Listing 2: Mayall Interaction Pseudocode—C2 code. |
3.5.2. Covertly Embedding Modules
3.5.3. Executing JavaScript Natively on a Target Machine
3.6. A Framework for Post-Exploitation
4. Results
4.1. Scanning Module
4.2. Update Injection and Malicious Modules
5. Discussion
5.1. Strengths and Limitations of the Mayall Framework
5.1.1. The Implementation of the Mayall framework
5.1.2. Git Commit Divergence
5.1.3. Update Process
5.1.4. Application Signing Against Runtime
5.1.5. Secure TLS Connections
5.2. Repackaging Binaries
5.3. Developer Involvement with the Node Security Platform
5.4. Current Remediations
6. Conclusions
Future Work
Author Contributions
Funding
Conflicts of Interest
References
- Tilkov, S.; Vinoski, S. Node.js: Using JavaScript to Build High-Performance Network Programs. IEEE Internet Comput. 2010, 14, 80–83. [Google Scholar] [CrossRef]
- Meyerovich, L.A.; Zhu, D.; Livshits, B. Secure cooperative sharing of JavaScript, browser, and physical resources. In Proceedings of the Workshop on Web 2.0 Security and Privacy, Oakland, CA, USA, 20 May 2010. [Google Scholar]
- Carter, B. HTML Educational Node. js System (HENS): An Applied System for Web Development. In Proceedings of the 2014 Annual Global Online Conference on Information and Computer Technology (GOCICT), Louisville, KY, USA, 3–5 December 2014; pp. 27–31. [Google Scholar]
- Freingruber, R. Abusing NVIDIA’s node.js to Bypass Application Whitelisting. 2017. Available online: http://blog.sec-consult.com/2017/04/application-whitelisting-application.html (accessed on 23 April 2017).
- GitHub. Apps Built on Electron. 2017. Available online: https://electron.atom.io/apps/ (accessed on 6 April 2017).
- Schlueter, I.Z. kik, left-pad, and npm. 2016. Available online: http://blog.npmjs.org/post/141577284765/kik-left-pad-and-npm (accessed on 15 February 2017).
- Stack Overflow. Developer Survey Results. 2016. Available online: http://stackoverflow.com/insights/survey/2016 (accessed on 9 April 2017).
- Richards, G.; Hammer, C.; Burg, B.; Vitek, J. The Eval That Men Do; Springer: Berlin/Heidelberg, Germany, 2011. [Google Scholar]
- Jensen, S.H.; Jonsson, P.A.; Møller, A. Remedying the eval that men do. In Proceedings of the 2012 International Symposium on Software Testing and Analysis, Minneapolis, MN, USA, 15–20 July 2012; pp. 34–44. [Google Scholar]
- The OWASP Foundation. OWASP Top 10—2013. 2013. Available online: https://www.owasp.org/images/f/f8/OWASP_Top_10_-_2013.pdf (accessed on 7 April 2017).
- Binnie, R.; McLean, C.; Seeam, A.; Bellekens, X. X-Secure: Protecting users from big bad wolves. In Proceedings of the 2016 IEEE International Conference on Emerging Technologies and Innovative Business Practices for the Transformation of Societies (EmergiTech), Balaclava, Mauritius, 3–6 August 2016; pp. 158–161. [Google Scholar]
- Shepherd, L.A.; Archibald, J.; Ferguson, R.I. Reducing Risky Security Behaviours: Utilising Affective Feedback to Educate Users. Future Internet 2014, 6, 760–772. [Google Scholar] [CrossRef] [Green Version]
- Joyent. About Node.js. 2017. Available online: https://nodejs.org/en/about/ (accessed on 6 March 2017).
- Eloff, E.; Torstensson, D. An Investigation into the Applicability of Node.js as a Platform for Web Services. Ph.D. Thesis, Department of Computer and Information Science, Linköpings Universitet, Linköping, Sweden, 2012. [Google Scholar]
- Node.js. How Uber Uses Node.js to Scale Their Business, No Date. Available online: https://nodejs.org/static/documents/casestudies/Nodejs-at-Uber.pdf (accessed on 10 April 2017).
- Trott, K. Node.js Interactive Conference—Node.js at Netflix. 2015. Available online: https://www.youtube.com/watch?v=p74282nDMX8&feature=youtu.be&t=12m11s (accessed on 10 April 2017).
- Ojamaa, A.; Düüna, K. Security assessment of Node. js platform. In Proceedings of the 2012 International Conference for Internet Technology and Secured Transactions, London, UK, 10–12 December 2012; pp. 35–43. [Google Scholar]
- Staicu, C.A.; Pradel, M.; Livshits, B. Understanding and Automatically Preventing Injection Attacks on NODE. JS. In Proceedings of the Network and Distributed Systems Security (NDSS) Symposium 2018, San Diego, CA, USA, 18–21 February 2018. [Google Scholar]
- GitHub. Electron Documentation—About Electron. 2017. Available online: https://electron.atom.io/docs/tutorial/about/ (accessed on 9 April 2017).
- Andrew Goode. Dealing with Problematic Dependencies in a Restricted Network Environment. 2016. Available online: https://blog.npmjs.org/post/145724408060/dealing-with-problematic-dependencies-in-a (accessed on 17 November 2018).
- Kerr, D. As It Stands—Electron Security. 2016. Available online: http://blog.scottlogic.com/2016/03/09/As-It-Stands-Electron-Security.html (accessed on 10 March 2017).
- Nikiforakis, N.; Invernizzi, L.; Kapravelos, A.; Van Acker, S.; Joosen, W.; Kruegel, C.; Piessens, F.; Vigna, G. You Are What You Include: Large-scale Evaluation of Remote Javascript Inclusions. In Proceedings of the 2012 ACM Conference on Computer and Communications Security, CCS ’12, Raleigh, NC, USA, 16–18 October 2012; pp. 736–747. [Google Scholar]
- npm. npm-scripts—How npm Handles the “Scripts” Field. 2017. Available online: https://docs.npmjs.com/misc/scripts (accessed on 10 April 2017).
- Tschacher, N.P. Typosquatting in Programming Language Package Managers. Bachelor Thesis, Department of Informatics, University of Hamburg, Hamburg, Germany, 2016. Available online: http://incolumitas.com/data/thesis.pdf (accessed on 9 April 2017).
- Baldwin, A. A Malicious Module on npm. 2015. Available online: https://blog.liftsecurity.io/2015/01/27/a-malicious-module-on-npm/ (accessed on 10 April 2017).
- Jeronimo, J. rimrafall—npm Install Could Be Dangerous. 2015. Available online: https://github.com/joaojeronimo/rimrafall (accessed on 10 April 2017).
- Pfretzschner, B.; ben Othmane, L. Identification of Dependency-based Attacks on Node. js. In Proceedings of the 12th International Conference on Availability, Reliability and Security, Reggio Calabria, Italy, 29 August–2 September 2017; p. 68. [Google Scholar]
- Nigro, D.L. Pulling Apart a WordPress Hack, Unobfuscating Its Code. 2011. Available online: https://dan.cx/2011/11/pulling-apart-wordpress-hack (accessed on 10 April 2017).
- Williams, C. How One Developer Just Broke Node, Babel and Thousands of Projects in 11 Lines of JavaScript. 2015. Available online: https://www.theregister.co.uk/2016/03/23/npm_left_pad_chaos/ (accessed on 12 April 2017).
- GitHub. Electron Documentation—Electron Versioning. 2017. Available online: https://electron.atom.io/docs/tutorial/electron-versioning/ (accessed on 12 April 2017).
- Node Security. Advisories. 2017. Available online: https://nodesecurity.io/advisories (accessed on 24 April 2017).
- Schechter, E. Moving Towards a More Secure Web. 2016. Available online: https://security.googleblog.com/2016/09/moving-towards-more-secure-web.html (accessed on 26 April 2017).
- Electronic Frontier Foundation. Certbot. 2017. Available online: https://certbot.eff.org/ (accessed on 26 April 2017).
- Kirda, E.; Kruegel, C.; Vigna, G.; Jovanovic, N. Noxes: A client-side solution for mitigating cross-site scripting attacks. In Proceedings of the 2006 ACM Symposium on Applied Computing, Dijon, France, 23–27 April 2006; pp. 330–337. [Google Scholar]
- Prokhorenko, V.; Choo, K.K.R.; Ashman, H. Context-oriented web application protection model. Appl. Math. Comput. 2016, 285, 59–78. [Google Scholar] [CrossRef]
- lostfictions. [Security] Investigate Switching to Brave’s Fork of Electron-Prebuilt? 2016. Available online: https://github.com/jiahaog/nativefier/issues/288 (accessed on 12 April 2017).
- de Arruda, T. Allow Electron Renderers to Be Run Inside Chromium Sandbox. 2016. Available online: https://github.com/electron/electron/issues/6712 (accessed on 6 April 2017).
- Catuogno, L.; Galdi, C. Ensuring Application Integrity: A Survey on Techniques and Tools. In Proceedings of the 2015 9th International Conference on Innovative Mobile and Internet Services in Ubiquitous Computing, Santa Catarina, Brazil, 8–10 July 2015; pp. 192–199. [Google Scholar]
- De Groef, W.; Massacci, F.; Piessens, F. NodeSentry: Least-privilege Library Integration for Server-side JavaScript. In Proceedings of the 30th Annual Computer Security Applications Conference, ACSAC ’14, New Orleans, LA, USA, 8–12 December 2014; pp. 446–455. [Google Scholar]
Application | Total No. Advisories | Highest CVSS Score |
---|---|---|
1Clipboard | 25 | 7.5 |
Atom | 25 | 7.5 |
Caret | 2 | 7.5 |
Discord | 3 | 7.5 |
Ghost | 0 | — |
Hyper | 0 | — |
Mattermost | 0 | — |
MongoDBCompass | 17 | 7.5 |
NVIDIA | 11 | 7.5 |
Popcorn Time | 39 | 7.5 |
Popkey | 7 | 7.5 |
Slack | 0 | — |
Tofino Browser | 0 | — |
SteelSeries | 1 | 7.5 |
Wire Messenger | 5 | 7.5 |
Application | No. Inc. | No. Deps. | Commits | Avg. Comm. |
---|---|---|---|---|
1Clipboard | 24 | 374 | 48,724 | 157.23 |
Atom | 56 | 578 | 34,181 | 82.36 |
Caret | 29 | 89 | 2615 | 46.70 |
Discord | 10 | 130 | 9805 | 89.14 |
Ghost | 10 | 45 | 1014 | 25.35 |
Hyper | 17 | 69 | 2039 | 29.99 |
Mattermost | 11 | 85 | 7652 | 99.38 |
MongoDBCompass | 86 | 841 | 132,281 | 269.96 |
NVIDIA | N/A | 116 | 6425 | 69.84 |
Popkey | 12 | 84 | 11,523 | 177.28 |
Tidal | 13 | 115 | 5339 | 58.03 |
Slack | 97 | 257 | 38,411 | 185.56 |
Tofino Browser | 4 | 277 | 7365 | 31.21 |
SteelSeries | 1 | 4 | 364 | 182 |
Wire Messenger | 11 | 336 | 19,306 | 70.20 |
Average | 27 | 227 | 21,803 | 104.95 |
© 2018 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).
Share and Cite
Rapley, A.; Bellekens, X.; Shepherd, L.A.; McLean, C. Mayall: A Framework for Desktop JavaScript Auditing and Post-Exploitation Analysis. Informatics 2018, 5, 46. https://doi.org/10.3390/informatics5040046
Rapley A, Bellekens X, Shepherd LA, McLean C. Mayall: A Framework for Desktop JavaScript Auditing and Post-Exploitation Analysis. Informatics. 2018; 5(4):46. https://doi.org/10.3390/informatics5040046
Chicago/Turabian StyleRapley, Adam, Xavier Bellekens, Lynsay A. Shepherd, and Colin McLean. 2018. "Mayall: A Framework for Desktop JavaScript Auditing and Post-Exploitation Analysis" Informatics 5, no. 4: 46. https://doi.org/10.3390/informatics5040046
APA StyleRapley, A., Bellekens, X., Shepherd, L. A., & McLean, C. (2018). Mayall: A Framework for Desktop JavaScript Auditing and Post-Exploitation Analysis. Informatics, 5(4), 46. https://doi.org/10.3390/informatics5040046