ep_images_extended 1.0.62 → 1.1.0

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.
Files changed (3) hide show
  1. package/index.js +6 -1
  2. package/package.json +1 -1
  3. package/settings.js +15 -3
package/index.js CHANGED
@@ -1,7 +1,9 @@
1
1
  'use strict';
2
2
  // Modified from ep_image_insert 1.0.7
3
3
  const eejs = require('ep_etherpad-lite/node/eejs/');
4
- const settings = require('ep_etherpad-lite/node/utils/Settings');
4
+ // Compat: Etherpad 2.4 uses ESM for Settings. Support both CJS and ESM.
5
+ const settingsModule = require('ep_etherpad-lite/node/utils/Settings');
6
+ const settings = settingsModule.default || settingsModule;
5
7
  const { randomUUID } = require('crypto');
6
8
  const path = require('path');
7
9
  const url = require('url');
@@ -184,6 +186,9 @@ exports.expressConfigure = (hookName, context) => {
184
186
 
185
187
  // ADD LOCAL DISK STORAGE UPLOAD ENDPOINT ------------------------------
186
188
  // Register the route only if storage.type === 'local'
189
+ logger.info('[ep_images_extended] storageType at startup:',
190
+ settings.ep_images_extended?.storage?.type);
191
+
187
192
  if (settings.ep_images_extended && settings.ep_images_extended.storage && settings.ep_images_extended.storage.type === 'local') {
188
193
  // Route: POST /p/:padId/pluginfw/ep_images_extended/upload
189
194
  // Accepts multipart/form-data with field "file" and saves it to the
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "ep_images_extended",
3
3
  "description": "Insert images inline with text, float them, resize them, and more.",
4
- "version": "1.0.62",
4
+ "version": "1.1.0",
5
5
  "author": {
6
6
  "name": "DCastelone",
7
7
  "url": "https://github.com/dcastelone"
package/settings.js CHANGED
@@ -2,12 +2,24 @@
2
2
 
3
3
  'use strict';
4
4
 
5
- exports.loadSettings = (hookName, settings, cb) => {
6
- if (!settings.settings.socketIo) {
5
+ exports.loadSettings = (hookName, args, cb) => {
6
+ // Sync ep_images_extended config into the runtime Settings singleton that other
7
+ // parts of this plugin import, to avoid workspace/symlink doubletons.
8
+ try {
9
+ const settingsModule = require('ep_etherpad-lite/node/utils/Settings');
10
+ const runtimeSettings = settingsModule.default || settingsModule;
11
+ if (args && args.settings && args.settings.ep_images_extended) {
12
+ runtimeSettings.ep_images_extended = args.settings.ep_images_extended;
13
+ }
14
+ } catch (e) {
15
+ console.warn('[ep_images_extended] Failed to sync settings:', e);
16
+ }
17
+
18
+ if (!args.settings || !args.settings.socketIo) {
7
19
  console.warn('Please update Etherpad to >=1.8.8');
8
20
  } else {
9
21
  // Setting maxHttpBufferSize to 10 MiB :)
10
- settings.settings.socketIo.maxHttpBufferSize = 100000000;
22
+ args.settings.socketIo.maxHttpBufferSize = 100000000;
11
23
  }
12
24
  cb();
13
25
  };