mirror of
https://github.com/strapi/strapi.git
synced 2025-07-23 09:00:19 +00:00

* feat: use document service in content manager * feat: update contracts with meta information * chore: group metadata types into a single type * feat: metadata information in single types * chore: change meta contract to return documents instead of strings * fix: remove unused type * fix: ignore doc id if entry is null * fix: update contract metadata * feat: document metadata service * feat: locale and status filtering * chore: add comment * chore: refactor metadata service * chore: refactor entity manager exists to handle single types * feat: refactor single type controllers to use documents * feat: get locale param from in cm endpoints * Revert "feat: get locale param from in cm endpoints" This reverts commit 856c38588b8f8521cadd85c8c933f42a36a2178a. * feat: get locale param from cm endpoints * Update packages/plugins/i18n/server/src/controllers/validate-locale-creation.ts Co-authored-by: Ben Irvin <ben@innerdvations.com> * fix: entity manager unit tests * chore: unit test document metadata * feat: prevent empty string locale filtering * feat(core): document unique field validation per content type and locale * feat(e2e): test document unique fields * fix(admin): ts build * fix: cm contract import * chore: test new d&p cm features * feat(core): validate document unique fields within one publication state chore: remove build:ts * fix: search content manager api test * fix: cm tests * fix: cm tests * fix: cm tests * fix(content-manager): access to non default locale documents (#19190) * fix(content-manager): access to non default locale documents * chore(content-manager): revert route construction * fix(content-manager): api tests for number of draft relations * test(content-manager): counting number of draft relations for non default locales * chore(content-manager): remove default locale from entity manager countDraftRelations * test(document-service): api tests for unique document fields per publication state * test(i18n): api tests for unique document fields per locale * chore(api-tests): adjust author schema * chore(e2e): disable edit view tests (#19235) * fix(core): unique validation on publish * fix(api-tests): un-localise author * fix(e2e): incorrect path * fix(admin): tidy up * fix(admin): pass correct locale query params fix(core): pass locale outside of filters * chore(api-tests): wip comment for relatedEntityId logic * fix(core): entity validator tests * chore(api-tests): wip skip failing relations i18n test * chore(e2e): clean up editview spec * fix(content-manager): pass locale to publish and unpublish * fix(content-manager): fix test:ts:back * fix(e2e): update edit view expected path * fix(entity-validator): default to null locale fix(api-tests): wip i18n test changes * fix(e2e): wip UID fields * chore(content-type-builder): temporarily disable component unique field checkboxes (#19253) * fix(admin): wip correctly pass params feat(e2e): reintroduce uniqueness e2e tests * Refactor UID validation for V5 (#19285) * fix(database): wip remove UID unique DB constraint * feat(content-manager): update uid checking endpoints to look at locale * chore(admin): clean up * fix(content-manager): single type unit tests * fix(content-manager): send all params to uid endpoints * feat(e2e): update tar backup to support unique CT * fix(e2e): uniqueness spec * chore(e2e): remove only * fix(content-manager): only check UID availability against drafts feat(api-tests): test case for UID validation across locales * fix(content-manager): uid unit tests * chore(api-tests): clean up * chore(content-manager): clean up * chore(i18n): remove relatedEntityId reference --------- Co-authored-by: Marc-Roig <marc12info@gmail.com> Co-authored-by: Ben Irvin <ben@innerdvations.com> Co-authored-by: Josh <37798644+joshuaellis@users.noreply.github.com>
84 lines
2.4 KiB
JavaScript
84 lines
2.4 KiB
JavaScript
import { resolve } from 'path';
|
|
import { ALLOWED_CONTENT_TYPES, CUSTOM_TRANSFER_TOKEN_ACCESS_KEY } from '../constants';
|
|
|
|
const {
|
|
file: {
|
|
providers: { createLocalFileSourceProvider },
|
|
},
|
|
strapi: {
|
|
providers: { createRemoteStrapiDestinationProvider },
|
|
},
|
|
engine: { createTransferEngine },
|
|
} = require('@strapi/data-transfer');
|
|
|
|
/**
|
|
* Reset the DB and import data from a DTS backup
|
|
* This function ensures we keep all admin user's and roles in the DB
|
|
* see: https://docs.strapi.io/developer-docs/latest/developer-resources/data-management.html
|
|
* @param {String} filePath the path to a DTS backup
|
|
* @param {Array<String>} contentTypesToWipe remove all entries of these content types before importing
|
|
*/
|
|
export const resetDatabaseAndImportDataFromPath = async (filePath, contentTypesToWipe = []) => {
|
|
const source = createSourceProvider(filePath);
|
|
const destination = createDestinationProvider(contentTypesToWipe);
|
|
|
|
const engine = createTransferEngine(source, destination, {
|
|
versionStrategy: 'ignore',
|
|
schemaStrategy: 'ignore',
|
|
only: ['content', 'files'],
|
|
transforms: {
|
|
links: [
|
|
{
|
|
filter(link) {
|
|
return (
|
|
ALLOWED_CONTENT_TYPES.includes(link.left.type) &&
|
|
(ALLOWED_CONTENT_TYPES.includes(link.right.type) || link.right.type === undefined)
|
|
);
|
|
},
|
|
},
|
|
],
|
|
entities: [
|
|
{
|
|
filter(entity) {
|
|
return ALLOWED_CONTENT_TYPES.includes(entity.type);
|
|
},
|
|
},
|
|
],
|
|
},
|
|
});
|
|
|
|
engine.diagnostics.onDiagnostic(console.log);
|
|
|
|
try {
|
|
await engine.transfer();
|
|
} catch {
|
|
console.error('Import process failed.');
|
|
process.exit(1);
|
|
}
|
|
};
|
|
|
|
const createSourceProvider = (filePath) =>
|
|
createLocalFileSourceProvider({
|
|
file: { path: resolve(filePath) },
|
|
encryption: { enabled: false },
|
|
compression: { enabled: false },
|
|
});
|
|
|
|
const createDestinationProvider = (contentTypesToWipe = []) => {
|
|
return createRemoteStrapiDestinationProvider({
|
|
url: new URL(`http://127.0.0.1:${process.env.PORT ?? 1337}/admin`),
|
|
auth: { type: 'token', token: CUSTOM_TRANSFER_TOKEN_ACCESS_KEY },
|
|
strategy: 'restore',
|
|
restore: {
|
|
assets: true,
|
|
entities: {
|
|
include: [...ALLOWED_CONTENT_TYPES, ...contentTypesToWipe],
|
|
},
|
|
configuration: {
|
|
coreStore: false,
|
|
webhook: false,
|
|
},
|
|
},
|
|
});
|
|
};
|