p-lock
Simple promise lock
Last updated 4 years ago by bconnorwhite .
MIT · Repository · Original npm · Tarball · package.json
$ gnpm install p-lock 
SYNC missed versions from official npm registry.

p-lock

NPM TypeScript Coverage Status

Simple promise lock.

If I should maintain this repo, please ⭐️ GitHub stars

DM me on Twitter if you have questions or suggestions. Twitter


About

This package provides a simple promise lock, which is useful for preventing race conditions between multiple promises.

Installation

yarn add p-lock
npm install p-lock
pnpm install p-lock

Overview

First, we get a lock function:

import { getLock } from "p-lock";

const lock = getLock();

Calling the lock function returns a promise that resolves when the lock is acquired.

The promise resolves with a release function, which must be called to release the lock:

lock("example-key").then((release) => {
  // Now I have the lock for "example-key"
  // do something...
  release();
});

Full Example

In this example, we have two promises writing to the same file. However, we want to ensure that the first one finishes before the second one starts.

import { writeFile } from "fs";
import { getLock } from "p-lock";

const lock = getLock();

lock("file").then((release) => {
  setTimeout(() => {
    writeFile("test.txt", "hello", () => {
      release();
    });
  }, 1000);
});

lock("file").then((release) => {
  writeFile("test.txt", "world", () => {
    release();
  });
});

// Contents of test.txt will be "world"

Replace

In some cases, we may want to replace an existing promise waiting for a lock, rather than waiting for it to finish.

The replace option allows us to do this:

import { writeFile } from "fs";
import { getLock } from "p-lock";

const lock = getLock({ replace: true });

let writeCounter = 0;

lock("file").then((release) => {
  setTimeout(() => {
    writeCounter += 1;
    writeFile("test.txt", `update #${writeCounter}`, () => {
      release();
    });
  }, 1000);
});

lock("file").then((release) => {
  writeCounter += 1;
  writeFile("test.txt", `update #${writeCounter}`, () => {
    release();
  });
}).catch(() => {
  // This promise will reject, since the next one replaces.
});

lock("file").then((release) => {
  writeCounter += 1;
  writeFile("test.txt", `update #${writeCounter}`, () => {
    release();
  });
});

// Contents of test.txt will be "update #2"

Dev Dependencies

  • autorepo: Autorepo abstracts away your dev dependencies, providing a single command to run all of your scripts.

License license

MIT - MIT License

Current Tags

  • 3.0.0                                ...           latest (2 years ago)

4 Versions

  • 3.0.0                                ...           2 years ago
  • 2.1.0                                ...           4 years ago
  • 2.0.0                                ...           4 years ago
  • 1.0.0                                ...           4 years ago
Downloads
Today 0
This Week 0
This Month 0
Last Day 0
Last Week 0
Last Month 0
Dependencies (0)
None
Dev Dependencies (1)

Copyright 2013 - present © cnpmjs.org | Home |