Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

jscrambler

Package Overview
Dependencies
Maintainers
9
Versions
185
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

jscrambler

Jscrambler API client.

  • 5.2.16
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
2.9K
decreased by-33.36%
Maintainers
9
Weekly downloads
 
Created
Source

jscrambler

Jscrambler Client for Browser and Node.js

Installation

On your project:

npm i jscrambler --save-dev

Or globally:

npm i -g jscrambler

RC configuration

You may put your access and secret keys into a config file if found in these directories. Besides simplifying the command entry, this has the added benefit of not logging your Jscrambler credentials.

Here's an example of what your .jscramblerrc file should look like:

{
  "keys": {
    "accessKey": "AAAA",
    "secretKey": "SSSS"
  },
  "applicationId": "XXXXX",
  "filesSrc": [
    "/path/to/src.html",
    "/path/to/src.js"
  ],
  "filesDest": "/path/to/destDir/",
  "params": [
    {
      "name": "stringSplitting"
    }
  ],
  "areSubscribersOrdered": false,
  "jscramblerVersion": "5.1"
}

Please, replace the AAAA, SSSS and XXXXX placeholders with your API credentials and Application ID.

You can also download this file through Jscrambler's application builder. More information can be found here.

CLI

npm install -g jscrambler
  Usage: jscrambler [options] <file ...>

  Options:

    -h, --help                       output usage information
    -V, --version                    output the version number
    -a, --access-key <accessKey>     Access key
    -c, --config <config>            JScrambler configuration options
    -H, --host <host>                Hostname
    -i, --application-id <id>        Application ID
    -o, --output-dir <dir>           Output directory
    -p, --port <port>                Port
    --protocol <protocol>            Protocol (http or https)
    --cafile <path>                  Internal certificate authority
    -C, --cwd <dir>                  Current Working Directory
    -m, --source-maps <id>           Download source maps
    -R, --randomization-seed <seed>  Set randomization seed
    -s, --secret-key <secretKey>     Secret key
    -R, --randomization-seed <seed>  Set randomization seed
    --recommended-order <bool>       Use recommended order
    -W --werror                      Cancel protection if any file contains errors
    --jscramblerVersion <version>    Use a specific Jscrambler version

Required Fields

When making API requests you must pass valid secret and access keys, through the command line or by having a .jscramblerrc file. These keys are each 40 characters long, alpha numeric strings, and uppercase. You can find them in your jscramber web dashboard under My Profile > API Credentials. In the examples these are shortened to AAAA and SSSS for the sake of readability.

Using a proxy to make requests

If your requests need to go through a proxy, there is an option where you can specify the ip address, port and authentication credentials.

{
  proxy: {
    host: '',
    port: 1234,
    auth: {
      username: '',
      password: ''
    }
  }
}

WARNING: currently we only support HTTP proxies. In order to make it use your proxy, you just need to add the proxy details to the Jscrambler config file as above and use the port 80 of our service (this is the HTTP port of the Jscrambler API).

{
  port: 80,
  proxy: {
      host: '',
      port: 1234,
      auth: {
        username: '',
        password: ''
      }
  }
}

Flag -W / --werror

Jscrambler by default will protect your application even if errors occurred in some of your files. For example: if your app have 5 files and 1 of them has syntax errors, Jscrambler will protect the files with no errors and keep the original content in the other one.

With this flag, any error/warning will make the protection fail. There are two possible types of errors:

  • Syntax errors

    Code

    function a[] {
      return
    }
    

    Output

    Error: "Unexpected token [" in test.js:1
    Protection failed
    
  • Errors parsing jscrambler code annotations

    Code

     //@jscrambler define __something
    function test() {
      return true;
    }
    
    test();
    
    //@jscrambler [define xxxxx]
    function test1() {
      return false;
    }
    
    test1();
    

    Output

    Error: "[Annotation Error] Expected " " or [a-z]i but "_" found." in test.js:1
    Error: "[Annotation Error] Expected " ", "define", "disable", "enable", "global", "order" or "target" but "[" found." in test.js:8
    Error: "Parsing errors on annotations" in test.js
    Protection failed
    

Output to a single file

jscrambler -a AAAA -s SSSS -i APP_ID -o output.js input.js

Output multiple files to a directory

jscrambler -a AAAA -s SSSS -i APP_ID -o output/ input1.js input2.js

Using minimatch

jscrambler -a AAAA -s SSSS -i APP_ID -o output/ "lib/**/*.js"

Using configuration file

jscrambler -c config.json

where config.json is an object optionally containing any of the JScrambler options listed here, using the structure described in the RC configuration.

jscrambler --recommended-order false input1.js -o output/

To enable:

jscrambler --recommended-order true input1.js -o output/

API

npm install jscrambler

Quick example

var jscrambler = require('jscrambler').default;

jscrambler.protectAndDownload({
  keys: {
    accessKey: 'YOUR_JSCRAMBLER_ACCESS_KEY',
    secretKey: 'YOUR_JSCRAMBLER_SECRET_KEY'
  },
  host: 'api4.jscrambler.com',
  port: 443,
  applicationId: 'YOUR_APPLICATION_ID',
  filesSrc: [
    '/path/to/src/*.html',
    '/path/to/src/*.js'
  ],
  filesDest: '/path/to/destDir/',
  params: [
    {
      'name': 'whitespaceRemoval'
    },
    {
      'name': 'duplicateLiteralsRemoval'
    }
  ]
})
.then(function () {
  console.log('All done!');
})
.catch(function (err) {
  console.error(err);
});

More detailed informations can be found here.

Jscrambler Parameters

Please refer to docs for more information.

FAQs

Package last updated on 12 Sep 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc