
Systematic adaptation of dynamically generated source code via domain‐specific examples
Author(s) -
Song Myoungkyu,
Tilevich Eli
Publication year - 2018
Publication title -
iet software
Language(s) - English
Resource type - Journals
ISSN - 1751-8814
DOI - 10.1049/iet-sen.2016.0211
Subject(s) - computer science , javascript , scripting language , web application , source code , suite , cross site scripting , programming language , web application development , adaptation (eye) , software engineering , program transformation , java , code refactoring , world wide web , web modeling , software , web application security , web development , web service , physics , archaeology , optics , history
In modern web‐based applications, an increasing amount of source code is generated dynamically at runtime. Web applications commonly execute dynamically generated code (DGC) emitted by third‐party, black‐box generators, run at remote sites. Web developers often need to adapt DGC before it can be executed: embedded HTML can be vulnerable to cross‐site scripting attacks; an API may be incompatible with some browsers; and the program's state created by DGC may not be persisting. Lacking any systematic approaches for adapting DGC, web developers resort to ad‐hoc techniques that are unsafe and error‐prone. This study presents an approach for adapting DGC systematically that follows the program‐transformation‐by‐example paradigm. The proposed approach provides predefined, domain‐specific before/after examples that capture the variability of commonly used adaptations. By approving or rejecting these examples, web developers determine the required adaptation transformations, which are encoded in an adaptation script operating on the generated code's abstract syntax tree. The proposed approach is a suite of practical JavaScript program adaptations and their corresponding before/after examples. The authors have successfully applied the approach to real web applications to adapt third‐party generated JavaScript code for security, browser compatibility, and persistence.