import { injectable, inject } from 'inversify'; import { ServiceIdentifiers } from '../../container/ServiceIdentifiers'; import * as ESTree from 'estree'; import { IOptions } from '../../interfaces/options/IOptions'; import { IObfuscationReplacer } from '../../interfaces/node-transformers/IObfuscationReplacer'; import { NodeObfuscatorsReplacers } from '../../enums/container/NodeObfuscationReplacers'; import { NodeType } from '../../enums/NodeType'; import { AbstractNodeTransformer } from '../AbstractNodeTransformer'; import { Node } from '../../node/Node'; @injectable() export class MemberExpressionTransformer extends AbstractNodeTransformer { /** * @type {IObfuscationReplacer} */ private readonly stringLiteralReplacer: IObfuscationReplacer; /** * @param replacersFactory * @param options */ constructor( @inject(ServiceIdentifiers.Factory__IObfuscatorReplacer) replacersFactory: (replacer: NodeObfuscatorsReplacers) => IObfuscationReplacer, @inject(ServiceIdentifiers.IOptions) options: IOptions ) { super(options); this.stringLiteralReplacer = replacersFactory(NodeObfuscatorsReplacers.StringLiteralReplacer); } /** * replaces: * object.identifier = 1; * * on: * object['identifier'] = 1; * * and skip: * object[identifier] = 1; * * Literal node will be obfuscated by LiteralTransformer * * @param memberExpressionNode * @returns {ESTree.Node} */ public transformNode (memberExpressionNode: ESTree.MemberExpression): ESTree.Node { if (Node.isIdentifierNode(memberExpressionNode.property)) { if (memberExpressionNode.computed) { return memberExpressionNode; } memberExpressionNode.computed = true; memberExpressionNode.property = { type: NodeType.Literal, value: memberExpressionNode.property.name, raw: `'${memberExpressionNode.property.name}'` }; } return memberExpressionNode; } }