KeyValueStore
Index
Properties
readonlyconfig
readonlyid
optionalreadonlyname
Methods
drop
Removes the key-value store either from the Apify cloud storage or from the local directory, depending on the mode of operation.
Returns Promise<void>
forEachKey
Iterates over key-value store keys, yielding each in turn to an
iterateefunction. Each invocation ofiterateeis called with three arguments:(key, index, info), wherekeyis the record key,indexis a zero-based index of the key in the current iteration (regardless ofoptions.exclusiveStartKey) andinfois an object that contains a single propertysizeindicating size of the record in bytes.If the
iterateefunction returns a Promise then it is awaited before the next call. If it throws an error, the iteration is aborted and theforEachKeyfunction throws the error.Example usage
const keyValueStore = await KeyValueStore.open();
await keyValueStore.forEachKey(async (key, index, info) => {
console.log(`Key at ${index}: ${key} has size ${info.size}`);
});Parameters
iteratee: KeyConsumer
A function that is called for every key in the key-value store.
options: KeyValueStoreIteratorOptions = {}
Returns Promise<void>
getAutoSavedValue
Type parameters
- T: Dictionary<any> = Dictionary<any>
Parameters
key: string
defaultValue: T = ...
Returns Promise<T>
getValue
Gets a value from the key-value store.
The function returns a
Promisethat resolves to the record value, whose JavaScript type depends on the MIME content type of the record. Records with theapplication/jsoncontent type are automatically parsed and returned as a JavaScript object. Similarly, records withtext/plaincontent types are returned as a string. For all other content types, the value is returned as a rawBufferinstance.If the record does not exist, the function resolves to
null.To save or delete a value in the key-value store, use the KeyValueStore.setValue function.
Example usage:
const store = await KeyValueStore.open();
const buffer = await store.getValue('screenshot1.png');Type parameters
- T = unknown
Parameters
key: string
Unique key of the record. It can be at most 256 characters long and only consist of the following characters:
a-z,A-Z,0-9and!-_.'()optionaldefaultValue: T
Fallback that will be returned if no value if present in the storage.
Returns Promise<null | T>
Returns a promise that resolves to an object, string or
Buffer, depending on the MIME content type of the record.
setValue
Saves or deletes a record in the key-value store. The function returns a promise that resolves once the record has been saved or deleted.
Example usage:
const store = await KeyValueStore.open();
await store.setValue('OUTPUT', { foo: 'bar' });Beware that the key can be at most 256 characters long and only contain the following characters:
a-zA-Z0-9!-_.'()By default,
valueis converted to JSON and stored with theapplication/json; charset=utf-8MIME content type. To store the value with another content type, pass it in the options as follows:const store = await KeyValueStore.open('my-text-store');
await store.setValue('RESULTS', 'my text data', { contentType: 'text/plain' });If you set custom content type,
valuemust be either a string orBuffer, otherwise an error will be thrown.If
valueisnull, the record is deleted instead. Note that thesetValue()function succeeds regardless whether the record existed or not.To retrieve a value from the key-value store, use the KeyValueStore.getValue function.
IMPORTANT: Always make sure to use the
awaitkeyword when callingsetValue(), otherwise the crawler process might finish before the value is stored!Type parameters
- T
Parameters
key: string
Unique key of the record. It can be at most 256 characters long and only consist of the following characters:
a-z,A-Z,0-9and!-_.'()value: null | T
Record data, which can be one of the following values:
- If
null, the record in the key-value store is deleted. - If no
options.contentTypeis specified,valuecan be any JavaScript object and it will be stringified to JSON. - If
options.contentTypeis set,valueis taken as is and it must be aStringorBuffer. For any other value an error will be thrown.
- If
options: RecordOptions = {}
Returns Promise<void>
staticgetAutoSavedValue
Type parameters
- T: Dictionary<any> = Dictionary<any>
Parameters
key: string
defaultValue: T = ...
Returns Promise<T>
staticopen
Opens a key-value store and returns a promise resolving to an instance of the KeyValueStore class.
Key-value stores are used to store records or files, along with their MIME content type. The records are stored and retrieved using a unique key. The actual data is stored either on a local filesystem or in the Apify cloud.
For more details and code examples, see the KeyValueStore class.
Parameters
optionalstoreIdOrName: null | string
options: StorageManagerOptions = {}
Returns Promise<KeyValueStore>
The
KeyValueStoreclass represents a key-value store, a simple data storage that is used for saving and reading data records or files. Each data record is represented by a unique key and associated with a MIME content type. Key-value stores are ideal for saving screenshots, crawler inputs and outputs, web pages, PDFs or to persist the state of crawlers.Do not instantiate this class directly, use the KeyValueStore.open function instead.
Each crawler run is associated with a default key-value store, which is created exclusively for the run. By convention, the crawler input and output are stored into the default key-value store under the
INPUTandOUTPUTkey, respectively. Typically, input and output are JSON files, although it can be any other format. To access the default key-value store directly, you can use the KeyValueStore.getValue and KeyValueStore.setValue convenience functions.To access the input, you can also use the KeyValueStore.getInput convenience function.
KeyValueStorestores its data either on local disk or in the Apify cloud, depending on whether theAPIFY_IS_AT_HOMEenvironment variable is set.If the
APIFY_LOCAL_STORAGE_DIRenvironment variable is set, the data is stored in the local directory in the following files:Note that
{STORE_ID}is the name or ID of the key-value store. The default key-value store has ID:default, unless you override it by setting theAPIFY_DEFAULT_KEY_VALUE_STORE_IDenvironment variable. The{KEY}is the key of the record and{EXT}corresponds to the MIME content type of the data value.If the
APIFY_TOKENenvironment variable is set butAPIFY_LOCAL_STORAGE_DIRnot, the data is stored in the Apify Key-value store cloud storage. Note that you can force usage of the cloud storage also by passing theforceCloudoption to KeyValueStore.open function, even if theAPIFY_LOCAL_STORAGE_DIRvariable is set.Example usage: