@strapi/content-releases 5.0.0-rc.2 → 5.0.0-rc.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_chunks/{App-CKoteEu-.js → App-BFo3ibui.js} +156 -101
- package/dist/_chunks/App-BFo3ibui.js.map +1 -0
- package/dist/_chunks/{App-CwBi9wFK.mjs → App-JwN_xBnA.mjs} +161 -106
- package/dist/_chunks/App-JwN_xBnA.mjs.map +1 -0
- package/dist/_chunks/{ReleasesSettingsPage-U9Ud3HzH.js → ReleasesSettingsPage-BanjZwEc.js} +4 -4
- package/dist/_chunks/ReleasesSettingsPage-BanjZwEc.js.map +1 -0
- package/dist/_chunks/{ReleasesSettingsPage-Be1qEgcA.mjs → ReleasesSettingsPage-CNMXGcZC.mjs} +4 -4
- package/dist/_chunks/ReleasesSettingsPage-CNMXGcZC.mjs.map +1 -0
- package/dist/_chunks/{en-1_1re1mc.js → en-CmYoEnA7.js} +3 -1
- package/dist/_chunks/en-CmYoEnA7.js.map +1 -0
- package/dist/_chunks/{en-C3sq5KNP.mjs → en-D0yVZFqf.mjs} +3 -1
- package/dist/_chunks/en-D0yVZFqf.mjs.map +1 -0
- package/dist/_chunks/{index-VB3t7pBK.mjs → index-C_e6DQb0.mjs} +254 -11
- package/dist/_chunks/index-C_e6DQb0.mjs.map +1 -0
- package/dist/_chunks/{index-JLkDg3pp.js → index-Em3KctMx.js} +251 -8
- package/dist/_chunks/index-Em3KctMx.js.map +1 -0
- package/dist/_chunks/schemas-63pFihNF.mjs +44 -0
- package/dist/_chunks/schemas-63pFihNF.mjs.map +1 -0
- package/dist/_chunks/{schemas-3o-6hwUE.js → schemas-z5zp-_Gd.js} +20 -18
- package/dist/_chunks/schemas-z5zp-_Gd.js.map +1 -0
- package/dist/admin/index.js +1 -1
- package/dist/admin/index.mjs +1 -1
- package/dist/admin/src/components/ReleaseListCell.d.ts +28 -0
- package/dist/admin/src/services/release.d.ts +6 -4
- package/dist/admin/src/validation/schemas.d.ts +4 -0
- package/dist/server/index.js +84 -76
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +84 -76
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/controllers/index.d.ts +2 -0
- package/dist/server/src/controllers/index.d.ts.map +1 -1
- package/dist/server/src/controllers/release-action.d.ts +1 -0
- package/dist/server/src/controllers/release-action.d.ts.map +1 -1
- package/dist/server/src/controllers/release.d.ts +1 -0
- package/dist/server/src/controllers/release.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +4 -0
- package/dist/server/src/index.d.ts.map +1 -1
- package/dist/server/src/routes/release-action.d.ts.map +1 -1
- package/dist/server/src/routes/release.d.ts.map +1 -1
- package/dist/server/src/services/index.d.ts +2 -0
- package/dist/server/src/services/index.d.ts.map +1 -1
- package/dist/server/src/services/release-action.d.ts +3 -1
- package/dist/server/src/services/release-action.d.ts.map +1 -1
- package/dist/shared/contracts/release-actions.d.ts +3 -5
- package/dist/shared/contracts/release-actions.d.ts.map +1 -1
- package/dist/shared/contracts/releases.d.ts +3 -2
- package/dist/shared/contracts/releases.d.ts.map +1 -1
- package/package.json +12 -11
- package/dist/_chunks/App-CKoteEu-.js.map +0 -1
- package/dist/_chunks/App-CwBi9wFK.mjs.map +0 -1
- package/dist/_chunks/ReleasesSettingsPage-Be1qEgcA.mjs.map +0 -1
- package/dist/_chunks/ReleasesSettingsPage-U9Ud3HzH.js.map +0 -1
- package/dist/_chunks/en-1_1re1mc.js.map +0 -1
- package/dist/_chunks/en-C3sq5KNP.mjs.map +0 -1
- package/dist/_chunks/index-JLkDg3pp.js.map +0 -1
- package/dist/_chunks/index-VB3t7pBK.mjs.map +0 -1
- package/dist/_chunks/schemas-3o-6hwUE.js.map +0 -1
- package/dist/_chunks/schemas-CBVqXur2.mjs +0 -42
- package/dist/_chunks/schemas-CBVqXur2.mjs.map +0 -1
- package/strapi-server.js +0 -3
package/dist/server/index.js
CHANGED
|
@@ -929,7 +929,7 @@ const createReleaseActionService = ({ strapi: strapi2 }) => {
|
|
|
929
929
|
return contentTypesData;
|
|
930
930
|
};
|
|
931
931
|
return {
|
|
932
|
-
async create(releaseId, action) {
|
|
932
|
+
async create(releaseId, action, { disableUpdateReleaseStatus = false } = {}) {
|
|
933
933
|
const { validateEntryData, validateUniqueEntry } = getService("release-validation", {
|
|
934
934
|
strapi: strapi2
|
|
935
935
|
});
|
|
@@ -962,7 +962,9 @@ const createReleaseActionService = ({ strapi: strapi2 }) => {
|
|
|
962
962
|
},
|
|
963
963
|
populate: { release: { select: ["id"] } }
|
|
964
964
|
});
|
|
965
|
-
|
|
965
|
+
if (!disableUpdateReleaseStatus) {
|
|
966
|
+
getService("release", { strapi: strapi2 }).updateReleaseStatus(release2.id);
|
|
967
|
+
}
|
|
966
968
|
return releaseAction2;
|
|
967
969
|
},
|
|
968
970
|
async findPage(releaseId, query) {
|
|
@@ -1135,11 +1137,11 @@ const createReleaseValidationService = ({ strapi: strapi2 }) => ({
|
|
|
1135
1137
|
throw new utils.errors.NotFoundError(`No release found for id ${releaseId}`);
|
|
1136
1138
|
}
|
|
1137
1139
|
const isEntryInRelease = release2.actions.some(
|
|
1138
|
-
(action) =>
|
|
1140
|
+
(action) => action.entryDocumentId === releaseActionArgs.entryDocumentId && action.contentType === releaseActionArgs.contentType && (releaseActionArgs.locale ? action.locale === releaseActionArgs.locale : true)
|
|
1139
1141
|
);
|
|
1140
1142
|
if (isEntryInRelease) {
|
|
1141
1143
|
throw new AlreadyOnReleaseError(
|
|
1142
|
-
`Entry with documentId ${releaseActionArgs.entryDocumentId}
|
|
1144
|
+
`Entry with documentId ${releaseActionArgs.entryDocumentId}${releaseActionArgs.locale ? `( ${releaseActionArgs.locale})` : ""} and contentType ${releaseActionArgs.contentType} already exists in release with id ${releaseId}`
|
|
1143
1145
|
);
|
|
1144
1146
|
}
|
|
1145
1147
|
},
|
|
@@ -1408,43 +1410,50 @@ const releaseController = {
|
|
|
1408
1410
|
};
|
|
1409
1411
|
ctx.body = { data };
|
|
1410
1412
|
},
|
|
1411
|
-
|
|
1412
|
-
|
|
1413
|
-
|
|
1414
|
-
|
|
1415
|
-
|
|
1416
|
-
|
|
1413
|
+
async mapEntriesToReleases(ctx) {
|
|
1414
|
+
const { contentTypeUid, documentIds, locale } = ctx.query;
|
|
1415
|
+
if (!contentTypeUid || !documentIds) {
|
|
1416
|
+
throw new utils.errors.ValidationError("Missing required query parameters");
|
|
1417
|
+
}
|
|
1418
|
+
const releaseService = getService("release", { strapi });
|
|
1419
|
+
const releasesWithActions = await releaseService.findMany({
|
|
1420
|
+
where: {
|
|
1421
|
+
releasedAt: null,
|
|
1422
|
+
actions: {
|
|
1423
|
+
contentType: contentTypeUid,
|
|
1424
|
+
entryDocumentId: {
|
|
1425
|
+
$in: documentIds
|
|
1426
|
+
},
|
|
1427
|
+
locale
|
|
1428
|
+
}
|
|
1429
|
+
},
|
|
1430
|
+
populate: {
|
|
1431
|
+
actions: true
|
|
1417
1432
|
}
|
|
1418
|
-
|
|
1419
|
-
|
|
1420
|
-
|
|
1421
|
-
|
|
1422
|
-
|
|
1423
|
-
|
|
1424
|
-
|
|
1425
|
-
|
|
1426
|
-
|
|
1427
|
-
|
|
1428
|
-
|
|
1429
|
-
|
|
1430
|
-
|
|
1431
|
-
|
|
1432
|
-
|
|
1433
|
-
|
|
1434
|
-
|
|
1435
|
-
|
|
1436
|
-
|
|
1437
|
-
|
|
1438
|
-
|
|
1439
|
-
|
|
1440
|
-
|
|
1441
|
-
|
|
1442
|
-
|
|
1443
|
-
ctx.body = {
|
|
1444
|
-
data: mappedEntriesInReleases,
|
|
1445
|
-
};
|
|
1446
|
-
},
|
|
1447
|
-
*/
|
|
1433
|
+
});
|
|
1434
|
+
const mappedEntriesInReleases = releasesWithActions.reduce(
|
|
1435
|
+
(acc, release2) => {
|
|
1436
|
+
release2.actions.forEach((action) => {
|
|
1437
|
+
if (action.contentType !== contentTypeUid) {
|
|
1438
|
+
return;
|
|
1439
|
+
}
|
|
1440
|
+
if (locale && action.locale !== locale) {
|
|
1441
|
+
return;
|
|
1442
|
+
}
|
|
1443
|
+
if (!acc[action.entryDocumentId]) {
|
|
1444
|
+
acc[action.entryDocumentId] = [{ id: release2.id, name: release2.name }];
|
|
1445
|
+
} else {
|
|
1446
|
+
acc[action.entryDocumentId].push({ id: release2.id, name: release2.name });
|
|
1447
|
+
}
|
|
1448
|
+
});
|
|
1449
|
+
return acc;
|
|
1450
|
+
},
|
|
1451
|
+
{}
|
|
1452
|
+
);
|
|
1453
|
+
ctx.body = {
|
|
1454
|
+
data: mappedEntriesInReleases
|
|
1455
|
+
};
|
|
1456
|
+
},
|
|
1448
1457
|
async create(ctx) {
|
|
1449
1458
|
const user = ctx.state.user;
|
|
1450
1459
|
const releaseArgs = ctx.request.body;
|
|
@@ -1537,22 +1546,23 @@ const releaseActionController = {
|
|
|
1537
1546
|
data: releaseAction2
|
|
1538
1547
|
});
|
|
1539
1548
|
},
|
|
1540
|
-
|
|
1541
|
-
|
|
1542
|
-
const
|
|
1543
|
-
const releaseActionsArgs = ctx.request.body as CreateManyReleaseActions.Request['body'];
|
|
1549
|
+
async createMany(ctx) {
|
|
1550
|
+
const releaseId = ctx.params.releaseId;
|
|
1551
|
+
const releaseActionsArgs = ctx.request.body;
|
|
1544
1552
|
await Promise.all(
|
|
1545
1553
|
releaseActionsArgs.map((releaseActionArgs) => validateReleaseAction(releaseActionArgs))
|
|
1546
1554
|
);
|
|
1547
|
-
const releaseActionService = getService(
|
|
1555
|
+
const releaseActionService = getService("release-action", { strapi });
|
|
1556
|
+
const releaseService = getService("release", { strapi });
|
|
1548
1557
|
const releaseActions = await strapi.db.transaction(async () => {
|
|
1549
|
-
const
|
|
1558
|
+
const releaseActions2 = await Promise.all(
|
|
1550
1559
|
releaseActionsArgs.map(async (releaseActionArgs) => {
|
|
1551
1560
|
try {
|
|
1552
|
-
const action = await releaseActionService.create(releaseId, releaseActionArgs
|
|
1561
|
+
const action = await releaseActionService.create(releaseId, releaseActionArgs, {
|
|
1562
|
+
disableUpdateReleaseStatus: true
|
|
1563
|
+
});
|
|
1553
1564
|
return action;
|
|
1554
1565
|
} catch (error) {
|
|
1555
|
-
// If the entry is already in the release, we don't want to throw an error, so we catch and ignore it
|
|
1556
1566
|
if (error instanceof AlreadyOnReleaseError) {
|
|
1557
1567
|
return null;
|
|
1558
1568
|
}
|
|
@@ -1560,18 +1570,20 @@ const releaseActionController = {
|
|
|
1560
1570
|
}
|
|
1561
1571
|
})
|
|
1562
1572
|
);
|
|
1563
|
-
return
|
|
1573
|
+
return releaseActions2;
|
|
1564
1574
|
});
|
|
1565
1575
|
const newReleaseActions = releaseActions.filter((action) => action !== null);
|
|
1576
|
+
if (newReleaseActions.length > 0) {
|
|
1577
|
+
releaseService.updateReleaseStatus(releaseId);
|
|
1578
|
+
}
|
|
1566
1579
|
ctx.created({
|
|
1567
1580
|
data: newReleaseActions,
|
|
1568
1581
|
meta: {
|
|
1569
1582
|
entriesAlreadyInRelease: releaseActions.length - newReleaseActions.length,
|
|
1570
|
-
totalEntries: releaseActions.length
|
|
1571
|
-
}
|
|
1583
|
+
totalEntries: releaseActions.length
|
|
1584
|
+
}
|
|
1572
1585
|
});
|
|
1573
1586
|
},
|
|
1574
|
-
*/
|
|
1575
1587
|
async findMany(ctx) {
|
|
1576
1588
|
const releaseId = ctx.params.releaseId;
|
|
1577
1589
|
const permissionsManager = strapi.service("admin::permission").createPermissionsManager({
|
|
@@ -1670,24 +1682,22 @@ const controllers = {
|
|
|
1670
1682
|
const release = {
|
|
1671
1683
|
type: "admin",
|
|
1672
1684
|
routes: [
|
|
1673
|
-
/*
|
|
1674
1685
|
{
|
|
1675
|
-
method:
|
|
1676
|
-
path:
|
|
1677
|
-
handler:
|
|
1686
|
+
method: "GET",
|
|
1687
|
+
path: "/mapEntriesToReleases",
|
|
1688
|
+
handler: "release.mapEntriesToReleases",
|
|
1678
1689
|
config: {
|
|
1679
1690
|
policies: [
|
|
1680
|
-
|
|
1691
|
+
"admin::isAuthenticatedAdmin",
|
|
1681
1692
|
{
|
|
1682
|
-
name:
|
|
1693
|
+
name: "admin::hasPermissions",
|
|
1683
1694
|
config: {
|
|
1684
|
-
actions: [
|
|
1685
|
-
}
|
|
1686
|
-
}
|
|
1687
|
-
]
|
|
1688
|
-
}
|
|
1695
|
+
actions: ["plugin::content-releases.read"]
|
|
1696
|
+
}
|
|
1697
|
+
}
|
|
1698
|
+
]
|
|
1699
|
+
}
|
|
1689
1700
|
},
|
|
1690
|
-
*/
|
|
1691
1701
|
{
|
|
1692
1702
|
method: "GET",
|
|
1693
1703
|
path: "/getByDocumentAttached",
|
|
@@ -1821,24 +1831,22 @@ const releaseAction = {
|
|
|
1821
1831
|
]
|
|
1822
1832
|
}
|
|
1823
1833
|
},
|
|
1824
|
-
/*
|
|
1825
1834
|
{
|
|
1826
|
-
method:
|
|
1827
|
-
path:
|
|
1828
|
-
handler:
|
|
1835
|
+
method: "POST",
|
|
1836
|
+
path: "/:releaseId/actions/bulk",
|
|
1837
|
+
handler: "release-action.createMany",
|
|
1829
1838
|
config: {
|
|
1830
1839
|
policies: [
|
|
1831
|
-
|
|
1840
|
+
"admin::isAuthenticatedAdmin",
|
|
1832
1841
|
{
|
|
1833
|
-
name:
|
|
1842
|
+
name: "admin::hasPermissions",
|
|
1834
1843
|
config: {
|
|
1835
|
-
actions: [
|
|
1836
|
-
}
|
|
1837
|
-
}
|
|
1838
|
-
]
|
|
1839
|
-
}
|
|
1844
|
+
actions: ["plugin::content-releases.create-action"]
|
|
1845
|
+
}
|
|
1846
|
+
}
|
|
1847
|
+
]
|
|
1848
|
+
}
|
|
1840
1849
|
},
|
|
1841
|
-
*/
|
|
1842
1850
|
{
|
|
1843
1851
|
method: "GET",
|
|
1844
1852
|
path: "/:releaseId/actions",
|