@ui5/server 2.3.1 → 2.4.1

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/CHANGELOG.md CHANGED
@@ -2,7 +2,19 @@
2
2
  All notable changes to this project will be documented in this file.
3
3
  This project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
4
4
 
5
- A list of unreleased changes can be found [here](https://github.com/SAP/ui5-server/compare/v2.3.1...HEAD).
5
+ A list of unreleased changes can be found [here](https://github.com/SAP/ui5-server/compare/v2.4.1...HEAD).
6
+
7
+ <a name="v2.4.1"></a>
8
+ ## [v2.4.1] - 2022-11-30
9
+ ### Dependency Updates
10
+ - Bump connect-openui5 from 0.10.2 to 0.10.3 [`20b6fc8`](https://github.com/SAP/ui5-server/commit/20b6fc8fbad69265bae3e8f7efd320f6297ac4c4)
11
+
12
+
13
+ <a name="v2.4.0"></a>
14
+ ## [v2.4.0] - 2021-10-19
15
+ ### Features
16
+ - Enhance versionInfo middleware to serve sap-ui-version.json ([#420](https://github.com/SAP/ui5-server/issues/420)) [`c6f83f5`](https://github.com/SAP/ui5-server/commit/c6f83f5472eb2fe6a8d4eca10ecdc5f4b522bc3c)
17
+
6
18
 
7
19
  <a name="v2.3.1"></a>
8
20
  ## [v2.3.1] - 2021-07-23
@@ -240,6 +252,8 @@ Only Node.js v10 or higher is supported.
240
252
  <a name="v0.0.1"></a>
241
253
  ## v0.0.1 - 2018-06-06
242
254
 
255
+ [v2.4.1]: https://github.com/SAP/ui5-server/compare/v2.4.0...v2.4.1
256
+ [v2.4.0]: https://github.com/SAP/ui5-server/compare/v2.3.1...v2.4.0
243
257
  [v2.3.1]: https://github.com/SAP/ui5-server/compare/v2.3.0...v2.3.1
244
258
  [v2.3.0]: https://github.com/SAP/ui5-server/compare/v2.2.10...v2.3.0
245
259
  [v2.2.10]: https://github.com/SAP/ui5-server/compare/v2.2.9...v2.2.10
@@ -244,7 +244,8 @@ class MiddlewareManager {
244
244
  if (
245
245
  specVersion === "2.0" || specVersion === "2.1" ||
246
246
  specVersion === "2.2" || specVersion === "2.3" ||
247
- specVersion === "2.4" || specVersion === "2.5"
247
+ specVersion === "2.4" || specVersion === "2.5" ||
248
+ specVersion === "2.6"
248
249
  ) {
249
250
  // Supply interface to MiddlewareUtil instance starting with specVersion 2.0
250
251
  params.middlewareUtil = middlewareUtil.getInterface(specVersion);
@@ -34,6 +34,7 @@ class MiddlewareUtil {
34
34
  case "2.3":
35
35
  case "2.4":
36
36
  case "2.5":
37
+ case "2.6":
37
38
  return baseInterface;
38
39
  default:
39
40
  throw new Error(`MiddlewareUtil: Unknown or unsupported Specification Version ${specVersion}`);
@@ -1,4 +1,7 @@
1
1
  const createVersionInfoProcessor = require("@ui5/builder").processors.versionInfoGenerator;
2
+ const createManifestProcessor = require("@ui5/builder").processors.manifestCreator;
3
+
4
+ const MANIFEST_JSON = "manifest.json";
2
5
 
3
6
  /**
4
7
  * Creates and returns the middleware to create the version info as json object.
@@ -10,37 +13,61 @@ const createVersionInfoProcessor = require("@ui5/builder").processors.versionInf
10
13
  * @returns {Function} Returns a server middleware closure.
11
14
  */
12
15
  function createMiddleware({resources, tree: project}) {
13
- return function versionInfo(req, res, next) {
14
- resources.dependencies.byGlob("/resources/**/.library")
15
- .then((resources) => {
16
- resources.sort((a, b) => {
17
- return a._project.metadata.name.localeCompare(b._project.metadata.name);
18
- });
19
- return createVersionInfoProcessor({
20
- options: {
21
- rootProjectName: project.metadata.name,
22
- rootProjectVersion: project.version,
23
- libraryInfos: resources.map((dotLibResource) => {
24
- return {
25
- name: dotLibResource._project.metadata.name,
26
- version: dotLibResource._project.version
27
- };
28
- })
29
- }
30
- });
31
- })
32
- .then(([versionInfoResource]) => {
33
- return versionInfoResource.getBuffer();
34
- })
35
- .then((versionInfoContent) => {
36
- res.writeHead(200, {
37
- "Content-Type": "application/json"
16
+ return async function versionInfo(req, res, next) {
17
+ try {
18
+ const dependencies = resources.dependencies;
19
+ const dotLibResources = await dependencies.byGlob("/resources/**/.library");
20
+
21
+ dotLibResources.sort((a, b) => {
22
+ return a._project.metadata.name.localeCompare(b._project.metadata.name);
23
+ });
24
+
25
+ const libraryInfosPromises = dotLibResources.map(async (dotLibResource) => {
26
+ const namespace = dotLibResource._project.metadata.namespace;
27
+ const manifestResources = await dependencies.byGlob(`/resources/${namespace}/**/${MANIFEST_JSON}`);
28
+ let libraryManifest = manifestResources.find((manifestResource) => {
29
+ return manifestResource.getPath() === `/resources/${namespace}/${MANIFEST_JSON}`;
38
30
  });
39
- res.end(versionInfoContent.toString());
40
- })
41
- .catch((err) => {
42
- next(err);
31
+ const embeddedManifests =
32
+ manifestResources.filter((manifestResource) => manifestResource !== libraryManifest);
33
+ if (!libraryManifest) {
34
+ const extensions = "js,json,library,less,css,theming,theme,properties";
35
+ const libResources = await dependencies.byGlob(`/resources/${namespace}/**/*.{${extensions}}`);
36
+
37
+ libraryManifest = await createManifestProcessor({
38
+ libraryResource: dotLibResource,
39
+ namespace,
40
+ resources: libResources,
41
+ options: {
42
+ omitMinVersions: true
43
+ }
44
+ });
45
+ }
46
+ return {
47
+ libraryManifest,
48
+ embeddedManifests,
49
+ name: dotLibResource._project.metadata.name,
50
+ version: dotLibResource._project.version
51
+ };
52
+ });
53
+ const libraryInfos = await Promise.all(libraryInfosPromises);
54
+
55
+ const [versionInfoResource] = await createVersionInfoProcessor({
56
+ options: {
57
+ rootProjectName: project.metadata.name,
58
+ rootProjectVersion: project.version,
59
+ libraryInfos
60
+ }
61
+ });
62
+ const versionInfoContent = await versionInfoResource.getBuffer();
63
+
64
+ res.writeHead(200, {
65
+ "Content-Type": "application/json"
43
66
  });
67
+ res.end(versionInfoContent.toString());
68
+ } catch (err) {
69
+ next(err);
70
+ }
44
71
  };
45
72
  }
46
73
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ui5/server",
3
- "version": "2.3.1",
3
+ "version": "2.4.1",
4
4
  "description": "UI5 Tooling - Server",
5
5
  "author": {
6
6
  "name": "SAP SE",
@@ -104,46 +104,46 @@
104
104
  "url": "git@github.com:SAP/ui5-server.git"
105
105
  },
106
106
  "dependencies": {
107
- "@ui5/builder": "^2.9.4",
107
+ "@ui5/builder": "^2.11.9",
108
108
  "@ui5/fs": "^2.0.6",
109
109
  "@ui5/logger": "^2.0.1",
110
- "body-parser": "^1.19.0",
110
+ "body-parser": "^1.20.1",
111
111
  "compression": "^1.7.4",
112
- "connect-openui5": "^0.10.2",
112
+ "connect-openui5": "^0.10.3",
113
113
  "cors": "^2.8.5",
114
114
  "devcert-sanscache": "^0.4.8",
115
115
  "escape-html": "^1.0.3",
116
116
  "etag": "^1.8.1",
117
- "express": "^4.17.1",
117
+ "express": "^4.18.2",
118
118
  "fresh": "^0.5.2",
119
- "graceful-fs": "^4.2.6",
119
+ "graceful-fs": "^4.2.10",
120
120
  "make-dir": "^3.1.0",
121
- "mime-types": "^2.1.31",
121
+ "mime-types": "^2.1.35",
122
122
  "parseurl": "^1.3.3",
123
123
  "portscanner": "^2.1.1",
124
124
  "replacestream": "^4.0.3",
125
- "router": "^1.3.5",
125
+ "router": "^1.3.7",
126
126
  "spdy": "^4.0.2",
127
127
  "treeify": "^1.0.1",
128
128
  "yesno": "^0.3.1"
129
129
  },
130
130
  "devDependencies": {
131
- "@ui5/project": "^2.4.0",
131
+ "@ui5/project": "^2.6.0",
132
132
  "ava": "^3.15.0",
133
- "chokidar-cli": "^2.1.0",
133
+ "chokidar-cli": "^3.0.0",
134
134
  "cross-env": "^7.0.3",
135
- "depcheck": "^1.4.2",
135
+ "depcheck": "^1.4.3",
136
136
  "docdash": "^1.2.0",
137
- "eslint": "^7.31.0",
137
+ "eslint": "^7.32.0",
138
138
  "eslint-config-google": "^0.14.0",
139
- "eslint-plugin-jsdoc": "^35.4.5",
140
- "jsdoc": "^3.6.7",
139
+ "eslint-plugin-jsdoc": "^37.9.7",
140
+ "jsdoc": "^3.6.11",
141
141
  "mock-require": "^3.0.3",
142
142
  "nyc": "^15.1.0",
143
143
  "open-cli": "^6.0.1",
144
144
  "rimraf": "^3.0.2",
145
- "sinon": "^11.1.1",
146
- "supertest": "^6.1.3",
145
+ "sinon": "^11.1.2",
146
+ "supertest": "^6.3.1",
147
147
  "tap-nyan": "^1.1.0",
148
148
  "tap-xunit": "^2.4.1"
149
149
  }