|
@@ -1,14 +1,13 @@
|
|
import { inject, injectable, } from 'inversify';
|
|
import { inject, injectable, } from 'inversify';
|
|
import { ServiceIdentifiers } from '../../container/ServiceIdentifiers';
|
|
import { ServiceIdentifiers } from '../../container/ServiceIdentifiers';
|
|
|
|
|
|
-import format from 'string-template';
|
|
|
|
-
|
|
|
|
import { TIdentifierNamesGeneratorFactory } from '../../types/container/generators/TIdentifierNamesGeneratorFactory';
|
|
import { TIdentifierNamesGeneratorFactory } from '../../types/container/generators/TIdentifierNamesGeneratorFactory';
|
|
import { TStatement } from '../../types/node/TStatement';
|
|
import { TStatement } from '../../types/node/TStatement';
|
|
|
|
|
|
import { IEscapeSequenceEncoder } from '../../interfaces/utils/IEscapeSequenceEncoder';
|
|
import { IEscapeSequenceEncoder } from '../../interfaces/utils/IEscapeSequenceEncoder';
|
|
import { IOptions } from '../../interfaces/options/IOptions';
|
|
import { IOptions } from '../../interfaces/options/IOptions';
|
|
import { IRandomGenerator } from '../../interfaces/utils/IRandomGenerator';
|
|
import { IRandomGenerator } from '../../interfaces/utils/IRandomGenerator';
|
|
|
|
+import { ITemplateFormatter } from '../../interfaces/utils/ITemplateFormatter';
|
|
|
|
|
|
import { ObfuscationTarget } from '../../enums/ObfuscationTarget';
|
|
import { ObfuscationTarget } from '../../enums/ObfuscationTarget';
|
|
import { StringArrayEncoding } from '../../enums/StringArrayEncoding';
|
|
import { StringArrayEncoding } from '../../enums/StringArrayEncoding';
|
|
@@ -50,6 +49,7 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
|
|
|
|
/**
|
|
/**
|
|
* @param {TIdentifierNamesGeneratorFactory} identifierNamesGeneratorFactory
|
|
* @param {TIdentifierNamesGeneratorFactory} identifierNamesGeneratorFactory
|
|
|
|
+ * @param {ITemplateFormatter} templateFormatter
|
|
* @param {IRandomGenerator} randomGenerator
|
|
* @param {IRandomGenerator} randomGenerator
|
|
* @param {IEscapeSequenceEncoder} escapeSequenceEncoder
|
|
* @param {IEscapeSequenceEncoder} escapeSequenceEncoder
|
|
* @param {IOptions} options
|
|
* @param {IOptions} options
|
|
@@ -57,11 +57,12 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
constructor (
|
|
constructor (
|
|
@inject(ServiceIdentifiers.Factory__IIdentifierNamesGenerator)
|
|
@inject(ServiceIdentifiers.Factory__IIdentifierNamesGenerator)
|
|
identifierNamesGeneratorFactory: TIdentifierNamesGeneratorFactory,
|
|
identifierNamesGeneratorFactory: TIdentifierNamesGeneratorFactory,
|
|
|
|
+ @inject(ServiceIdentifiers.ITemplateFormatter) templateFormatter: ITemplateFormatter,
|
|
@inject(ServiceIdentifiers.IRandomGenerator) randomGenerator: IRandomGenerator,
|
|
@inject(ServiceIdentifiers.IRandomGenerator) randomGenerator: IRandomGenerator,
|
|
@inject(ServiceIdentifiers.IEscapeSequenceEncoder) escapeSequenceEncoder: IEscapeSequenceEncoder,
|
|
@inject(ServiceIdentifiers.IEscapeSequenceEncoder) escapeSequenceEncoder: IEscapeSequenceEncoder,
|
|
@inject(ServiceIdentifiers.IOptions) options: IOptions
|
|
@inject(ServiceIdentifiers.IOptions) options: IOptions
|
|
) {
|
|
) {
|
|
- super(identifierNamesGeneratorFactory, randomGenerator, options);
|
|
|
|
|
|
+ super(identifierNamesGeneratorFactory, templateFormatter, randomGenerator, options);
|
|
|
|
|
|
this.escapeSequenceEncoder = escapeSequenceEncoder;
|
|
this.escapeSequenceEncoder = escapeSequenceEncoder;
|
|
}
|
|
}
|
|
@@ -92,7 +93,7 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
const decodeNodeTemplate: string = this.getDecodeStringArrayTemplate();
|
|
const decodeNodeTemplate: string = this.getDecodeStringArrayTemplate();
|
|
|
|
|
|
return JavaScriptObfuscator.obfuscate(
|
|
return JavaScriptObfuscator.obfuscate(
|
|
- format(StringArrayCallsWrapperTemplate(), {
|
|
|
|
|
|
+ this.templateFormatter.format(StringArrayCallsWrapperTemplate(), {
|
|
decodeNodeTemplate,
|
|
decodeNodeTemplate,
|
|
stringArrayCallsWrapperName: this.stringArrayCallsWrapperName,
|
|
stringArrayCallsWrapperName: this.stringArrayCallsWrapperName,
|
|
stringArrayName: this.stringArrayName
|
|
stringArrayName: this.stringArrayName
|
|
@@ -113,13 +114,13 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
const globalVariableTemplate: string = this.options.target !== ObfuscationTarget.BrowserNoEval
|
|
const globalVariableTemplate: string = this.options.target !== ObfuscationTarget.BrowserNoEval
|
|
? this.getGlobalVariableTemplate()
|
|
? this.getGlobalVariableTemplate()
|
|
: GlobalVariableNoEvalTemplate();
|
|
: GlobalVariableNoEvalTemplate();
|
|
- const atobPolyfill: string = format(AtobTemplate(), { globalVariableTemplate });
|
|
|
|
|
|
+ const atobPolyfill: string = this.templateFormatter.format(AtobTemplate(), { globalVariableTemplate });
|
|
|
|
|
|
let decodeStringArrayTemplate: string = '';
|
|
let decodeStringArrayTemplate: string = '';
|
|
let selfDefendingCode: string = '';
|
|
let selfDefendingCode: string = '';
|
|
|
|
|
|
if (this.options.selfDefending) {
|
|
if (this.options.selfDefending) {
|
|
- selfDefendingCode = format(
|
|
|
|
|
|
+ selfDefendingCode = this.templateFormatter.format(
|
|
SelfDefendingTemplate(
|
|
SelfDefendingTemplate(
|
|
this.randomGenerator,
|
|
this.randomGenerator,
|
|
this.escapeSequenceEncoder
|
|
this.escapeSequenceEncoder
|
|
@@ -133,7 +134,7 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
|
|
|
|
switch (this.options.stringArrayEncoding) {
|
|
switch (this.options.stringArrayEncoding) {
|
|
case StringArrayEncoding.Rc4:
|
|
case StringArrayEncoding.Rc4:
|
|
- decodeStringArrayTemplate = format(
|
|
|
|
|
|
+ decodeStringArrayTemplate = this.templateFormatter.format(
|
|
StringArrayRc4DecodeNodeTemplate(this.randomGenerator),
|
|
StringArrayRc4DecodeNodeTemplate(this.randomGenerator),
|
|
{
|
|
{
|
|
atobPolyfill,
|
|
atobPolyfill,
|
|
@@ -146,7 +147,7 @@ export class StringArrayCallsWrapper extends AbstractCustomNode {
|
|
break;
|
|
break;
|
|
|
|
|
|
case StringArrayEncoding.Base64:
|
|
case StringArrayEncoding.Base64:
|
|
- decodeStringArrayTemplate = format(
|
|
|
|
|
|
+ decodeStringArrayTemplate = this.templateFormatter.format(
|
|
StringArrayBase64DecodeNodeTemplate(this.randomGenerator),
|
|
StringArrayBase64DecodeNodeTemplate(this.randomGenerator),
|
|
{
|
|
{
|
|
atobPolyfill,
|
|
atobPolyfill,
|