@taktikorg/dolor-modi
v2.8.101
Published
![Tests](https://github.com/taktikorg/dolor-modi/workflows/Tests/badge.svg)
Downloads
1,101
Maintainers
Keywords
Readme
Async Await Mutex Lock
Mutex locks for async functions with functionality to use keys for separate locks
Usage Instructions
Without Key
import { Lock } from "@taktikorg/dolor-modi";
let lock = new Lock();
async function serialTask() {
await lock.acquire();
try {
// Don't return a promise here as Promise may resolve after finally
// has executed
} finally {
lock.release();
}
}
With Key
All the keys will have their own separate locks and separate waiting lists. A key can have any type (eg. string, number, etc. or a custom type allowed by typescript as a Map key)
import { Lock } from "@taktikorg/dolor-modi";
let lock = new Lock<string>();
async function serialTask() {
await lock.acquire("myKey");
try {
// Don't return a promise here as Promise may resolve after finally
// has executed
}
finally {
lock.release("myKey");
}
}
async function serialTaskTwo() {
await lock.acquire("myKeyTwo");
try {
// Don't return a promise here as Promise may resolve after finally
// has executed
}
finally {
lock.release("myKeyTwo");
}
}
Checking if a lock is acquired or not
import { Lock } from "@taktikorg/dolor-modi";
let lock = new Lock();
async function serialTask() {
await lock.acquire();
console.log(lock.isAcquired()); // prints true
}
isAcquired()
with key
checks for the given key separately.
import { Lock } from "@taktikorg/dolor-modi";
let lock = new Lock<string>();
async function serialTask() {
await lock.acquire("myKey");
console.log(lock.isAcquired("myKey")) // prints true
}
Issues or Bugs
In case of any issues or bugs, please open a pull request here