4.1.0 • Published 5 years ago

cache-loader v4.1.0

Weekly downloads
1,729,461
License
MIT
Repository
github
Last release
5 years ago

npm node deps tests coverage chat size

cache-loader

The cache-loader allow to Caches the result of following loaders on disk (default) or in the database.

Getting Started

To begin, you'll need to install cache-loader:

npm install --save-dev cache-loader

Add this loader in front of other (expensive) loaders to cache the result on disk.

webpack.config.js

module.exports = {
  module: {
    rules: [
      {
        test: /\.ext$/,
        use: ['cache-loader', ...loaders],
        include: path.resolve('src'),
      },
    ],
  },
};

⚠️ Note that there is an overhead for saving the reading and saving the cache file, so only use this loader to cache expensive loaders.

Options

NameTypen DefaultDescription
cacheContext{String}undefinedAllows you to override the default cache context in order to generate the cache relatively to a path. By default it will use absolute paths
cacheKey{Function(options, request) -> {String}}undefinedAllows you to override default cache key generator
cacheDirectory{String}findCacheDir({ name: 'cache-loader' }) or os.tmpdir()Provide a cache directory where cache items should be stored (used for default read/write implementation)
cacheIdentifier{String}cache-loader:{version} {process.env.NODE_ENV}Provide an invalidation identifier which is used to generate the hashes. You can use it for extra dependencies of loaders (used for default read/write implementation)
compare{Function(stats, dep) -> {Boolean}}undefinedAllows you to override default comparison function between the cached dependency and the one is being read. Return true to use the cached resource
precision{Number}0Round mtime by this number of milliseconds both for stats and dep before passing those params to the comparing function
read{Function(cacheKey, callback) -> {void}}undefinedAllows you to override default read cache data from file
readOnly{Boolean}falseAllows you to override default value and make the cache read only (useful for some environments where you don't want the cache to be updated, only read from it)
write{Function(cacheKey, data, callback) -> {void}}undefinedAllows you to override default write cache data to file (e.g. Redis, memcached)

Examples

Basic

webpack.config.js

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        use: ['cache-loader', 'babel-loader'],
        include: path.resolve('src'),
      },
    ],
  },
};

Database Integration

webpack.config.js

// Or different database client - memcached, mongodb, ...
const redis = require('redis');
const crypto = require('crypto');

// ...
// connect to client
// ...

const BUILD_CACHE_TIMEOUT = 24 * 3600; // 1 day

function digest(str) {
  return crypto
    .createHash('md5')
    .update(str)
    .digest('hex');
}

// Generate own cache key
function cacheKey(options, request) {
  return `build:cache:${digest(request)}`;
}

// Read data from database and parse them
function read(key, callback) {
  client.get(key, (err, result) => {
    if (err) {
      return callback(err);
    }

    if (!result) {
      return callback(new Error(`Key ${key} not found`));
    }

    try {
      let data = JSON.parse(result);
      callback(null, data);
    } catch (e) {
      callback(e);
    }
  });
}

// Write data to database under cacheKey
function write(key, data, callback) {
  client.set(key, JSON.stringify(data), 'EX', BUILD_CACHE_TIMEOUT, callback);
}

module.exports = {
  module: {
    rules: [
      {
        test: /\.js$/,
        use: [
          {
            loader: 'cache-loader',
            options: {
              cacheKey,
              read,
              write,
            },
          },
          'babel-loader',
        ],
        include: path.resolve('src'),
      },
    ],
  },
};

Contributing

Please take a moment to read our contributing guidelines if you haven't yet done so.

CONTRIBUTING

License

MIT

chemu-test-componentswacker@saasxx/vue@ishopee/cli-servicevuedragdropuploadimages@jerryhorak/docusaurus-coremattia-uijautohandywebpackmio-cli-servicewandering-cli-serviceaerolito-nextmylicensemagnoabsass-sdfddabc-jdjdjjd@nhatle/react-build-toolspg-cli-service@guomio/cli-servicezjlab-clinuxt-compactnuxt2bb-chat@willhayes/want-cli@nghiepuit/sdk-builderbase-sdk-buildernghiepuit-build-tools@nghiepuit/react-build-toolawlethlj-scripts-testcgdemouikbc-ui-cli-v2webpack-boxzgf-cliloankeeper-scripts@artel/arca-widget-cli@startdt/cli-service@startdt/cli-plugin-babel@startdt/cli-plugin-typescript@joseirrazabal/kitcommon_platformmagic-home-scaffoldbpmn-process-designer-xys@startdt/plugin-babel@startdt/plugin-typescript@startdt/next-serviceluban-formhzero-front-runtimehzero-react-scriptshzero-webpack-scriptsfe-blessfragrans-clifrag-cligwm-workflow-platformhao-base@electron.land/electron-scripts@ez-fe/ez@zelz/crankng-compilertestmagnowebpack-kit@everything-registry/sub-chunk-1283snbc-paas-webpacksnbc-paas-webpack-scriptscpaas-webpack-scriptsvue-cli-service-wc-native-slotssf-ui-buildsf-im99-build@stellar-apps/webpack@stonehiy/cli-service@steroidsjs/webpack@phila/phila-gridsome@phenixs/cli-service@phaser-r/cli-service@therebel/docz-core@titanium-sdk/webpack-plugin-babel@titanium-sdk/webpack-plugin-typescript@svel/cli-service@symeny/easywebpack@symph/joy@syman/ark-mobile-cli@talend/scripts-config-ng-webpack@talend/scripts@thc/webpack-quark-babel@thc/webpack-react@the-goat/task-js-bundler@tfdf/vue@testxcx/cli-service@soyjak/utils@shopify/loom-plugin-webpack@shopgate/sdk-devserver@shopgate/cloud-sdk-webpack@tuax/plugin-vue@visual-interface/page-base@vjcli/cli-service@vfusion/cli@vicli/cli-plugin-babel@vicli/cli-plugin-typescript@vicli/cli-service@vin_coder/pg-cli-service
4.1.0

5 years ago

4.0.1

5 years ago

4.0.0

5 years ago

3.0.1

5 years ago

3.0.0

5 years ago

2.0.1

6 years ago

2.0.0

6 years ago

1.2.5

6 years ago

1.2.4

6 years ago

1.2.3

6 years ago

1.2.2

7 years ago

1.2.1

7 years ago

1.2.0

7 years ago

1.1.0

7 years ago

1.0.3

7 years ago

1.0.2

7 years ago

1.0.1

7 years ago