.pnpmfile.cjs
pnpm を使用すると、特別な関数 (フック) を介してインストールプロセスを直接フックできます。 Hooks can be declared in a file called .pnpmfile.cjs.
By default, .pnpmfile.cjs should be located in the same directory as the
lockfile. For instance, in a workspace with a shared lockfile,
.pnpmfile.cjs should be in the root of the monorepo.
フック
TL;DR
| フック関数 | タイミング | 使い方 | 
|---|---|---|
| hooks.readPackage(pkg, context): pkg | pnpm が依存パッケージのマニフェストを解析した後に呼び出されます | Allows you to mutate a dependency's package.json | 
| hooks.afterAllResolved(lockfile, context): lockfile | 依存関係が解決された後に呼び出されます | ロックファイルを変更できます | 
hooks.readPackage(pkg, context): pkg | Promise<pkg>
Allows you to mutate a dependency's package.json after parsing and prior to
resolution. これらの変更はファイルシステムに保存されませんが、ロックファイルで解決される内容、したがってインストールされる内容に影響を与えます。
Note that you will need to delete the pnpm-lock.yaml if you have already
resolved the dependency you want to modify.
If you need changes to package.json saved to the filesystem, you need to use the pnpm patch command and patch the package.json file.
This might be useful if you want to remove the bin field of a dependency for instance.
引数
- pkg- The manifest of the package. Either the response from the registry or the- package.jsoncontent.
- context- Context object for the step. Method- #log(msg)allows you to use a debug log for the step.
使い方
Example .pnpmfile.cjs (changes the dependencies of a dependency):
function readPackage(pkg, context) {
  // Override the manifest of foo@1.x after downloading it from the registry
  if (pkg.name === 'foo' && pkg.version.startsWith('1.')) {
    // Replace bar@x.x.x with bar@2.0.0
    pkg.dependencies = {
      ...pkg.dependencies,
      bar: '^2.0.0'
    }
    context.log('bar@1 => bar@2 in dependencies of foo')
  }
  
  // This will change any packages using baz@x.x.x to use baz@1.2.3
  if (pkg.dependencies.baz) {
    pkg.dependencies.baz = '1.2.3';
  }
  
  return pkg
}
module.exports = {
  hooks: {
    readPackage
  }
}
既知の制限事項
Removing the scripts field from a dependency's manifest via readPackage will
not prevent pnpm from building the dependency. When building a dependency, pnpm
reads the package.json of the package from the package's archive, which is not
affected by the hook. In order to ignore a package's build, use the
neverBuiltDependencies field.
hooks.updateConfig(config): config | Promise<config>
Added in: v10.8.0
Allows you to modify the configuration settings used by pnpm. This hook is most useful when paired with configDependencies, allowing you to share and reuse settings across different Git repositories.
For example, @pnpm/plugin-better-defaults uses the updateConfig hook to apply a curated set of recommended settings.
使用例
module.exports = {
  hooks: {
    updateConfig (config) {
      return Object.assign(config, {
        enablePrePostScripts: false,
        optimisticRepeatInstall: true,
        resolutionMode: 'lowest-direct',
        verifyDepsBeforeRun: 'install',
      })
    }
  }
}
hooks.afterAllResolved(lockfile, context): lockfile | Promise<lockfile>
シリアライズされる前にロックファイルの出力を変更できます。
引数
- lockfile- The lockfile resolutions object that is serialized to- pnpm-lock.yaml.
- context- Context object for the step. Method- #log(msg)allows you to use a debug log for the step.
使用例
function afterAllResolved(lockfile, context) {
  // ...
  return lockfile
}
module.exports = {
  hooks: {
    afterAllResolved
  }
}
既知の制限事項
何もありません - ロックファイルでできることは、この関数を介して変更することができます。 ロックファイルの機能を拡張することもできます。
hooks.preResolution(options): Promise<void>
This hook is executed after reading and parsing the lockfiles of the project, but before resolving dependencies. It allows modifications to the lockfile objects.
引数
- options.existsCurrentLockfile- A boolean that is true if the lockfile at- node_modules/.pnpm/lock.yamlexists.
- options.currentLockfile- The lockfile object from- node_modules/.pnpm/lock.yaml.
- options.existsNonEmptyWantedLockfile- A boolean that is true if the lockfile at- pnpm-lock.yamlexists.
- options.wantedLockfile- The lockfile object from- pnpm-lock.yaml.
- options.lockfileDir- The directory where the wanted lockfile is found.
- options.storeDir- The location of the store directory.
- options.registries- A map of scopes to registry URLs.
hooks.importPackage(destinationDir, options): Promise<string | undefined>
This hook allows to change how packages are written to node_modules. The return value is optional and states what method was used for importing the dependency, e.g.: clone, hardlink.
引数
- destinationDir- The destination directory where the package should be written.
- options.disableRelinkLocalDirDeps
- options.filesMap
- options.force
- options.resolvedFrom
- options.keepModulesDir
hooks.fetchers
This hook allows to override the fetchers that are used for different types of dependencies. It is an object that may have the following fields:
- localTarball
- remoteTarball
- gitHostedTarball
- directory
- git
Finders
Added in: v10.16.0
Finder functions are used with pnpm list and pnpm why via the --find-by flag.
例:
module.exports = {
  finders: {
    react17: (ctx) => {
      return ctx.readManifest().peerDependencies?.react === "^17.0.0"
    }
  }
}
使い方
pnpm why --find-by=react17
See Finders for more details.
関連する設定
ignorePnpmfile
- Default: false
- Type: Boolean
.pnpmfile.cjs will be ignored. Useful together with --ignore-scripts when you
want to make sure that no script gets executed during install.
pnpmfile
- Default: ['.pnpmfile.cjs']
- Type: path[]
- Example: ['.pnpm/.pnpmfile.cjs']
The location of the local pnpmfile(s).
globalPnpmfile
- Default: null
- Type: path
- Example: ~/.pnpm/global_pnpmfile.cjs
グローバルの pnpmfileの場所。 グローバルの pnpmfile は、インストール時にすべてのプロジェクトで使用されます。
ローカルの pnpmfiles を使用することをお勧めします。 pnpm をパッケージマネージャとして採用しないプロジェクトで pnpm を使用する場合にのみ、グローバル pnpmfile を使用してください。