doc.yeswiki.pro/node_modules/@algolia/client-account/dist/client-account.esm.js
2023-05-20 19:38:02 +03:00

63 lines
2.6 KiB
JavaScript

import { createWaitablePromise } from '@algolia/client-common';
import { exists, getSettings, setSettings, browseRules, saveRules, browseSynonyms, saveSynonyms, browseObjects, saveObjects } from '@algolia/client-search';
function createDestinationIndiceExistsError() {
return {
name: 'DestinationIndiceAlreadyExistsError',
message: 'Destination indice already exists.',
};
}
function createIndicesInSameAppError(appId) {
return {
name: 'IndicesInTheSameAppError',
message: 'Indices are in the same application. Use SearchClient.copyIndex instead.',
appId,
};
}
const accountCopyIndex = (source, destination, requestOptions) => {
// eslint-disable-next-line functional/prefer-readonly-type
const responses = [];
const promise = exists(destination)()
.then(res => {
if (source.appId === destination.appId) {
throw createIndicesInSameAppError(source.appId);
}
if (res) {
throw createDestinationIndiceExistsError();
}
})
.then(() => getSettings(source)())
.then(settings =>
// eslint-disable-next-line functional/immutable-data
responses.push(setSettings(destination)(settings, requestOptions)))
.then(() => browseRules(source)({
// eslint-disable-next-line functional/immutable-data
batch: rules => responses.push(saveRules(destination)(rules, requestOptions)),
}))
.then(() => browseSynonyms(source)({
// eslint-disable-next-line functional/immutable-data
batch: synonyms => responses.push(saveSynonyms(destination)(synonyms, requestOptions)),
}))
.then(() => browseObjects(source)({
// eslint-disable-next-line functional/immutable-data
batch: objects => responses.push(saveObjects(destination)(objects, requestOptions)),
}));
return createWaitablePromise(
/**
* The original promise will return an array of async responses, now
* we need to resolve that array of async responses using a
* `Promise.all`, and then resolve `void` for the end-user.
*/
promise.then(() => Promise.all(responses)).then(() => undefined),
/**
* Next, if the end-user calls the `wait` method, we need to also call
* the `wait` method on each element of of async responses.
*/
(_response, waitRequestOptions) => {
return Promise.all(responses.map(response => response.wait(waitRequestOptions)));
});
};
export { accountCopyIndex, createDestinationIndiceExistsError, createIndicesInSameAppError };