import { inject, injectable, } from 'inversify'; import { ServiceIdentifiers } from '../../container/ServiceIdentifiers'; import * as ESTree from 'estree'; import jsStringEscape = require('js-string-escape'); import { IOptions } from '../../interfaces/options/IOptions'; import { IRandomGenerator } from '../../interfaces/utils/IRandomGenerator'; import { IVisitor } from '../../interfaces/node-transformers/IVisitor'; import { AbstractNodeTransformer } from '../AbstractNodeTransformer'; import { Nodes } from '../../node/Nodes'; import { NodeUtils } from '../../node/NodeUtils'; @injectable() export class AstToEvalCallExpressionTransformer extends AbstractNodeTransformer { /** * @param {IRandomGenerator} randomGenerator * @param {IOptions} options */ constructor ( @inject(ServiceIdentifiers.IRandomGenerator) randomGenerator: IRandomGenerator, @inject(ServiceIdentifiers.IOptions) options: IOptions ) { super(randomGenerator, options); } /** * @return {IVisitor} */ public getVisitor (): IVisitor { return { enter: (node: ESTree.Node, parentNode: ESTree.Node | null) => { if (parentNode && node.isEvalRoot) { return this.transformNode(node, parentNode); } } }; } /** * @param {ExpressionStatement} node * @param {Node} parentNode * @returns {Node} */ public transformNode (node: ESTree.Node, parentNode: ESTree.Node): ESTree.Node { const code: string = NodeUtils.convertStructureToCode([node]); return Nodes.getCallExpressionNode( Nodes.getIdentifierNode('eval'), [ Nodes.getLiteralNode(jsStringEscape(code)) ] ); } }