ep_email_notifications 0.1.36 → 10.0.2
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/client.js +1 -1
- package/handleMessage.js +1 -1
- package/index.js +1 -1
- package/package.json +9 -5
- package/update.js +1 -1
- package/.github/dependabot.yml +0 -11
- package/.github/workflows/backend-tests.yml +0 -92
- package/.github/workflows/frontend-tests.yml +0 -94
- package/.github/workflows/npmpublish.yml +0 -74
- package/.github/workflows/test-and-release.yml +0 -18
package/client.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
const eejs = require('ep_etherpad-lite/node/eejs');
|
|
4
|
-
|
|
4
|
+
import settings from 'ep_etherpad-lite/node/utils/Settings'
|
|
5
5
|
|
|
6
6
|
exports.eejsBlock_mySettings = (hookName, args, cb) => {
|
|
7
7
|
args.content += eejs.require('ep_email_notifications/templates/email_notifications_settings.ejs');
|
package/handleMessage.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
const db = require('ep_etherpad-lite/node/db/DB');
|
|
4
4
|
const email = require('emailjs');
|
|
5
5
|
const randomString = require('ep_etherpad-lite/static/js/pad_utils').randomString;
|
|
6
|
-
|
|
6
|
+
import settings from 'ep_etherpad-lite/node/utils/Settings'
|
|
7
7
|
const util = require('util');
|
|
8
8
|
const validator = require('validator');
|
|
9
9
|
|
package/index.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
const db = require('ep_etherpad-lite/node/db/DB');
|
|
4
4
|
const fs = require('fs').promises;
|
|
5
|
-
|
|
5
|
+
import settings from 'ep_etherpad-lite/node/utils/Settings'
|
|
6
6
|
|
|
7
7
|
// Remove cache for this procedure
|
|
8
8
|
db.db.dbSettings.cache = 0;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ep_email_notifications",
|
|
3
3
|
"description": "Subscribe to a pad and receive an email when someone edits your pad",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "10.0.2",
|
|
5
5
|
"author": {
|
|
6
6
|
"name": "John Mclear",
|
|
7
7
|
"email": "john@mclear.co.uk",
|
|
@@ -19,11 +19,11 @@
|
|
|
19
19
|
"validator": "13.7.0"
|
|
20
20
|
},
|
|
21
21
|
"engines": {
|
|
22
|
-
"node": ">=
|
|
22
|
+
"node": ">=20.0.0"
|
|
23
23
|
},
|
|
24
24
|
"repository": {
|
|
25
25
|
"type": "git",
|
|
26
|
-
"url": "https://github.com/
|
|
26
|
+
"url": "https://github.com/ether/ether-plugins.git"
|
|
27
27
|
},
|
|
28
28
|
"readme": "# Description\nThis plugin allows users to subscribe to pads and receive email updates when a pad is being modified. You can modify the frequency. This plugin is very much in alpha stage and has a lot of things TODO (See TODO).\n\n# Installation\nMake sure an SMTP gateway is installed IE postfix\nConfigure SPF and RDNS records to ensure proper mail flow <-- Search online\nCopy/Edit the below to your settings.json\nConnect to a pad, Click on the Share/Embed link and enter in your email address.\nOpen that pad in ANOTHER BROWSER then begin modifying, you should receive an email when the pad has begun editing and once the pad has gone stale (when everyone stops editing it and a time period passes).\nNOTE: You will NOT receive an email if you(the author that registered their email) are currently on or editing that pad!\n\n```\n \"ep_email_notifications\" : {\n checkFrequency: 6000, // checkFrequency = How frequently(milliseconds) to check for pad updates -- Move me to the settings file\n staleTime: 30000, // staleTime = How stale(milliseconds) does a pad need to be before notifying subscribers? Move me to settings\n fromName: \"Etherpad SETTINGS FILE!\",\n fromEmail: \"pad@etherpad.org\",\n urlToPads: \"http://beta.etherpad.org/p/\", // urlToPads = The URL to your pads note the trailing /\n emailServer: { // See https://github.com/eleith/emailjs for settings\n host: \"127.0.0.1\"\n }\n }\n```\n\n# TODO\n* Clean up all code\n\n# FUTURE VERSIONS TODO\n* v2 - Get the modified contents from the API HTML diff and append that to the Email and make the email from the server HTML not plain text\n* v2 - a point to unsubscribe and validate/verify email https://github.com/alfredwesterveld/node-email-verification\n* v2 - Keep a record of when a user was last on a pad\n",
|
|
29
29
|
"readmeFilename": "README.md",
|
|
@@ -36,10 +36,14 @@
|
|
|
36
36
|
"url": "https://etherpad.org/"
|
|
37
37
|
},
|
|
38
38
|
"devDependencies": {
|
|
39
|
-
"eslint": "^
|
|
39
|
+
"eslint": "^9.24.0",
|
|
40
40
|
"eslint-config-etherpad": "^4.0.4",
|
|
41
|
-
"typescript": "^5.4.
|
|
41
|
+
"typescript": "^5.4.3"
|
|
42
42
|
},
|
|
43
|
+
"bugs": {
|
|
44
|
+
"url": "https://github.com/ether/ether-plugins/issues"
|
|
45
|
+
},
|
|
46
|
+
"homepage": "https://github.com/ether/ether-plugins/tree/main/ep_email_notifications#readme",
|
|
43
47
|
"scripts": {
|
|
44
48
|
"lint": "eslint .",
|
|
45
49
|
"lint:fix": "eslint --fix ."
|
package/update.js
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
const db = require('ep_etherpad-lite/node/db/DB');
|
|
6
6
|
const API = require('ep_etherpad-lite/node/db/API.js');
|
|
7
7
|
const email = require('emailjs');
|
|
8
|
-
|
|
8
|
+
import settings from 'ep_etherpad-lite/node/utils/Settings'
|
|
9
9
|
const util = require('util');
|
|
10
10
|
|
|
11
11
|
const SMTPClient = email.SMTPClient;
|
package/.github/dependabot.yml
DELETED
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
name: Backend Tests
|
|
2
|
-
|
|
3
|
-
# any branch is useful for testing before a PR is submitted
|
|
4
|
-
on:
|
|
5
|
-
workflow_call:
|
|
6
|
-
|
|
7
|
-
jobs:
|
|
8
|
-
withplugins:
|
|
9
|
-
# run on pushes to any branch
|
|
10
|
-
# run on PRs from external forks
|
|
11
|
-
if: |
|
|
12
|
-
(github.event_name != 'pull_request')
|
|
13
|
-
|| (github.event.pull_request.head.repo.id != github.event.pull_request.base.repo.id)
|
|
14
|
-
name: with Plugins
|
|
15
|
-
runs-on: ubuntu-latest
|
|
16
|
-
steps:
|
|
17
|
-
-
|
|
18
|
-
name: Install libreoffice
|
|
19
|
-
uses: awalsh128/cache-apt-pkgs-action@v1.4.2
|
|
20
|
-
with:
|
|
21
|
-
packages: libreoffice libreoffice-pdfimport
|
|
22
|
-
version: 1.0
|
|
23
|
-
-
|
|
24
|
-
name: Install etherpad core
|
|
25
|
-
uses: actions/checkout@v3
|
|
26
|
-
with:
|
|
27
|
-
repository: ether/etherpad-lite
|
|
28
|
-
path: etherpad-lite
|
|
29
|
-
- uses: pnpm/action-setup@v3
|
|
30
|
-
name: Install pnpm
|
|
31
|
-
with:
|
|
32
|
-
version: 8
|
|
33
|
-
run_install: false
|
|
34
|
-
- name: Get pnpm store directory
|
|
35
|
-
shell: bash
|
|
36
|
-
run: |
|
|
37
|
-
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
|
|
38
|
-
- uses: actions/cache@v4
|
|
39
|
-
name: Setup pnpm cache
|
|
40
|
-
with:
|
|
41
|
-
path: ${{ env.STORE_PATH }}
|
|
42
|
-
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
|
|
43
|
-
restore-keys: |
|
|
44
|
-
${{ runner.os }}-pnpm-store-
|
|
45
|
-
-
|
|
46
|
-
name: Checkout plugin repository
|
|
47
|
-
uses: actions/checkout@v3
|
|
48
|
-
with:
|
|
49
|
-
path: plugin
|
|
50
|
-
-
|
|
51
|
-
name: Determine plugin name
|
|
52
|
-
id: plugin_name
|
|
53
|
-
working-directory: ./plugin
|
|
54
|
-
run: |
|
|
55
|
-
npx -c 'printf %s\\n "::set-output name=plugin_name::${npm_package_name}"'
|
|
56
|
-
-
|
|
57
|
-
name: Link plugin directory
|
|
58
|
-
working-directory: ./plugin
|
|
59
|
-
run: |
|
|
60
|
-
pnpm link --global
|
|
61
|
-
- name: Remove tests
|
|
62
|
-
working-directory: ./etherpad-lite
|
|
63
|
-
run: rm -rf ./src/tests/backend/specs
|
|
64
|
-
-
|
|
65
|
-
name: Install Etherpad core dependencies
|
|
66
|
-
working-directory: ./etherpad-lite
|
|
67
|
-
run: bin/installDeps.sh
|
|
68
|
-
- name: Link plugin to etherpad-lite
|
|
69
|
-
working-directory: ./etherpad-lite
|
|
70
|
-
run: |
|
|
71
|
-
pnpm link --global $PLUGIN_NAME
|
|
72
|
-
pnpm run install-plugins --path ../../plugin
|
|
73
|
-
env:
|
|
74
|
-
PLUGIN_NAME: ${{ steps.plugin_name.outputs.plugin_name }}
|
|
75
|
-
- name: Link ep_etherpad-lite
|
|
76
|
-
working-directory: ./etherpad-lite/src
|
|
77
|
-
run: |
|
|
78
|
-
pnpm link --global
|
|
79
|
-
- name: Link etherpad to plugin
|
|
80
|
-
working-directory: ./plugin
|
|
81
|
-
run: |
|
|
82
|
-
pnpm link --global ep_etherpad-lite
|
|
83
|
-
-
|
|
84
|
-
name: Run the backend tests
|
|
85
|
-
working-directory: ./etherpad-lite
|
|
86
|
-
run: |
|
|
87
|
-
res=$(find .. -path "./node_modules/ep_*/static/tests/backend/specs/**" | wc -l)
|
|
88
|
-
if [ $res -eq 0 ]; then
|
|
89
|
-
echo "No backend tests found"
|
|
90
|
-
else
|
|
91
|
-
pnpm run test
|
|
92
|
-
fi
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
# Publicly credit Sauce Labs because they generously support open source
|
|
2
|
-
# projects.
|
|
3
|
-
name: Frontend Tests
|
|
4
|
-
|
|
5
|
-
on:
|
|
6
|
-
workflow_call:
|
|
7
|
-
|
|
8
|
-
jobs:
|
|
9
|
-
test-frontend:
|
|
10
|
-
runs-on: ubuntu-latest
|
|
11
|
-
|
|
12
|
-
steps:
|
|
13
|
-
-
|
|
14
|
-
name: Check out Etherpad core
|
|
15
|
-
uses: actions/checkout@v3
|
|
16
|
-
with:
|
|
17
|
-
repository: ether/etherpad-lite
|
|
18
|
-
- uses: pnpm/action-setup@v3
|
|
19
|
-
name: Install pnpm
|
|
20
|
-
with:
|
|
21
|
-
version: 8
|
|
22
|
-
run_install: false
|
|
23
|
-
- name: Get pnpm store directory
|
|
24
|
-
shell: bash
|
|
25
|
-
run: |
|
|
26
|
-
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
|
|
27
|
-
- uses: actions/cache@v4
|
|
28
|
-
name: Setup pnpm cache
|
|
29
|
-
with:
|
|
30
|
-
path: ${{ env.STORE_PATH }}
|
|
31
|
-
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
|
|
32
|
-
restore-keys: |
|
|
33
|
-
${{ runner.os }}-pnpm-store-
|
|
34
|
-
-
|
|
35
|
-
name: Check out the plugin
|
|
36
|
-
uses: actions/checkout@v3
|
|
37
|
-
with:
|
|
38
|
-
path: ./node_modules/__tmp
|
|
39
|
-
-
|
|
40
|
-
name: export GIT_HASH to env
|
|
41
|
-
id: environment
|
|
42
|
-
run: |
|
|
43
|
-
cd ./node_modules/__tmp
|
|
44
|
-
echo "::set-output name=sha_short::$(git rev-parse --short ${{ github.sha }})"
|
|
45
|
-
-
|
|
46
|
-
name: Determine plugin name
|
|
47
|
-
id: plugin_name
|
|
48
|
-
run: |
|
|
49
|
-
cd ./node_modules/__tmp
|
|
50
|
-
npx -c 'printf %s\\n "::set-output name=plugin_name::${npm_package_name}"'
|
|
51
|
-
-
|
|
52
|
-
name: Rename plugin directory
|
|
53
|
-
env:
|
|
54
|
-
PLUGIN_NAME: ${{ steps.plugin_name.outputs.plugin_name }}
|
|
55
|
-
run: |
|
|
56
|
-
mv ./node_modules/__tmp ./node_modules/"${PLUGIN_NAME}"
|
|
57
|
-
-
|
|
58
|
-
name: Install plugin dependencies
|
|
59
|
-
env:
|
|
60
|
-
PLUGIN_NAME: ${{ steps.plugin_name.outputs.plugin_name }}
|
|
61
|
-
run: |
|
|
62
|
-
cd ./node_modules/"${PLUGIN_NAME}"
|
|
63
|
-
pnpm i
|
|
64
|
-
# Etherpad core dependencies must be installed after installing the
|
|
65
|
-
# plugin's dependencies, otherwise npm will try to hoist common
|
|
66
|
-
# dependencies by removing them from src/node_modules and installing them
|
|
67
|
-
# in the top-level node_modules. As of v6.14.10, npm's hoist logic appears
|
|
68
|
-
# to be buggy, because it sometimes removes dependencies from
|
|
69
|
-
# src/node_modules but fails to add them to the top-level node_modules.
|
|
70
|
-
# Even if npm correctly hoists the dependencies, the hoisting seems to
|
|
71
|
-
# confuse tools such as `npm outdated`, `npm update`, and some ESLint
|
|
72
|
-
# rules.
|
|
73
|
-
-
|
|
74
|
-
name: Install Etherpad core dependencies
|
|
75
|
-
run: bin/installDeps.sh
|
|
76
|
-
- name: Create settings.json
|
|
77
|
-
run: cp ./src/tests/settings.json settings.json
|
|
78
|
-
- name: Run the frontend tests
|
|
79
|
-
shell: bash
|
|
80
|
-
run: |
|
|
81
|
-
pnpm run dev &
|
|
82
|
-
connected=false
|
|
83
|
-
can_connect() {
|
|
84
|
-
curl -sSfo /dev/null http://localhost:9001/ || return 1
|
|
85
|
-
connected=true
|
|
86
|
-
}
|
|
87
|
-
now() { date +%s; }
|
|
88
|
-
start=$(now)
|
|
89
|
-
while [ $(($(now) - $start)) -le 15 ] && ! can_connect; do
|
|
90
|
-
sleep 1
|
|
91
|
-
done
|
|
92
|
-
cd src
|
|
93
|
-
pnpm exec playwright install chromium --with-deps
|
|
94
|
-
pnpm run test-ui --project=chromium
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
# This workflow will run tests using node and then publish a package to the npm registry when a release is created
|
|
2
|
-
# For more information see: https://help.github.com/actions/language-and-framework-guides/publishing-nodejs-packages
|
|
3
|
-
|
|
4
|
-
name: Node.js Package
|
|
5
|
-
|
|
6
|
-
on:
|
|
7
|
-
workflow_call:
|
|
8
|
-
|
|
9
|
-
jobs:
|
|
10
|
-
publish-npm:
|
|
11
|
-
runs-on: ubuntu-latest
|
|
12
|
-
steps:
|
|
13
|
-
- uses: actions/setup-node@v4
|
|
14
|
-
with:
|
|
15
|
-
node-version: 20
|
|
16
|
-
registry-url: https://registry.npmjs.org/
|
|
17
|
-
- name: Check out Etherpad core
|
|
18
|
-
uses: actions/checkout@v3
|
|
19
|
-
with:
|
|
20
|
-
repository: ether/etherpad-lite
|
|
21
|
-
- uses: pnpm/action-setup@v3
|
|
22
|
-
name: Install pnpm
|
|
23
|
-
with:
|
|
24
|
-
version: 8
|
|
25
|
-
run_install: false
|
|
26
|
-
- name: Get pnpm store directory
|
|
27
|
-
shell: bash
|
|
28
|
-
run: |
|
|
29
|
-
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
|
|
30
|
-
- uses: actions/cache@v4
|
|
31
|
-
name: Setup pnpm cache
|
|
32
|
-
with:
|
|
33
|
-
path: ${{ env.STORE_PATH }}
|
|
34
|
-
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
|
|
35
|
-
restore-keys: |
|
|
36
|
-
${{ runner.os }}-pnpm-store-
|
|
37
|
-
-
|
|
38
|
-
uses: actions/checkout@v3
|
|
39
|
-
with:
|
|
40
|
-
fetch-depth: 0
|
|
41
|
-
-
|
|
42
|
-
name: Bump version (patch)
|
|
43
|
-
run: |
|
|
44
|
-
LATEST_TAG=$(git describe --tags --abbrev=0) || exit 1
|
|
45
|
-
NEW_COMMITS=$(git rev-list --count "${LATEST_TAG}"..) || exit 1
|
|
46
|
-
[ "${NEW_COMMITS}" -gt 0 ] || exit 0
|
|
47
|
-
git config user.name 'github-actions[bot]'
|
|
48
|
-
git config user.email '41898282+github-actions[bot]@users.noreply.github.com'
|
|
49
|
-
pnpm i
|
|
50
|
-
pnpm version patch
|
|
51
|
-
git push --follow-tags
|
|
52
|
-
# This is required if the package has a prepare script that uses something
|
|
53
|
-
# in dependencies or devDependencies.
|
|
54
|
-
-
|
|
55
|
-
run: pnpm i
|
|
56
|
-
# `npm publish` must come after `git push` otherwise there is a race
|
|
57
|
-
# condition: If two PRs are merged back-to-back then master/main will be
|
|
58
|
-
# updated with the commits from the second PR before the first PR's
|
|
59
|
-
# workflow has a chance to push the commit generated by `npm version
|
|
60
|
-
# patch`. This causes the first PR's `git push` step to fail after the
|
|
61
|
-
# package has already been published, which in turn will cause all future
|
|
62
|
-
# workflow runs to fail because they will all attempt to use the same
|
|
63
|
-
# already-used version number. By running `npm publish` after `git push`,
|
|
64
|
-
# back-to-back merges will cause the first merge's workflow to fail but
|
|
65
|
-
# the second's will succeed.
|
|
66
|
-
-
|
|
67
|
-
run: pnpm publish
|
|
68
|
-
env:
|
|
69
|
-
NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}
|
|
70
|
-
#-
|
|
71
|
-
# name: Add package to etherpad organization
|
|
72
|
-
# run: pnpm access grant read-write etherpad:developers
|
|
73
|
-
# env:
|
|
74
|
-
# NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
name: Node.js Package
|
|
2
|
-
on: [push]
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
jobs:
|
|
6
|
-
backend:
|
|
7
|
-
uses: ./.github/workflows/backend-tests.yml
|
|
8
|
-
secrets: inherit
|
|
9
|
-
frontend:
|
|
10
|
-
uses: ./.github/workflows/frontend-tests.yml
|
|
11
|
-
secrets: inherit
|
|
12
|
-
release:
|
|
13
|
-
if: ${{ github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main' }}
|
|
14
|
-
needs:
|
|
15
|
-
- backend
|
|
16
|
-
- frontend
|
|
17
|
-
uses: ./.github/workflows/npmpublish.yml
|
|
18
|
-
secrets: inherit
|