Commit Graph

12667 Commits (bac0b7b228269e24792e7f400727c52f954e0315)

Author SHA1 Message Date
Julian Lam 69806662e6
Session Timeout if "Remember Me" is not checked ()
* fix: convert loginDays and loginSeconds to number inputs

* feat: configurable session timeout for when "Remember Me" is not checked

closes 

* test: addition tests to check loginDays and sessionDuration settings

* test: also test loginSeconds override
Julian Lam a344e6ec0c
Fix for , restore password reset rate limiting ()
* chore: incrementing version number - v2.8.1

* chore: update changelog for v2.8.1

* fix: accidental clearing of reset rate limiting on reset send

* test: move user reset tests to its own file, add failing test for user reset locks

* fix: , counter attempted flooding of user reset route

* test: fix password reset socket test to check for error now

* test: same user sending multiple reset emails

should work after waiting the correct amount of time

* lint: fixes

* chore: rename outdated `cleanTokensAndUids` method

* test: no need to create user for new test

Co-authored-by: Misty Release Bot <deploy@nodebb.org>
Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Barış Soner Uşaklı b81fd81af6 feat: fire filter:topics.getUnreadTids even if there are no urnead topics
Barış Soner Uşaklı 586eed1407
fix: vulnerability in socket.io nested namespaces ()
Barış Soner Uşaklı 1ea9481af6 fix: lock post/reply similar to user.create
Opliko de31cb1a4f feat: add force flag to plugin install in cli ()
Julian Lam 9f531f957e refactor: flag states so that they are not hardcoded, allow plugins to add additional states, deprecated filter:flags.getFilters hook, closes
Julian Lam 896493dbd6 fix: change hsts-maxage back to numeric input type, change API token uid input to numeric text type
Julian Lam 4314b8e201 Revert "fix: replace input type number with text/pattern"
This reverts commit cde4c6ac7e.

The changeset was naive in the sense that a lot of the changes inputs actually work better as type="number".
Julian Lam 2bc23a9526 fix: replace input type number with text/pattern
Julian Lam 33af2d9c18 feat: integrating basic client-side form validity checking in settings v1 and v2
Julian Lam db8d3a94eb fix: change hsts-maxage back to numeric input type, change API token uid input to numeric text type
Julian Lam d9852c3245 Revert "fix: replace input type number with text/pattern"
This reverts commit cde4c6ac7e.

The changeset was naive in the sense that a lot of the changes inputs actually work better as type="number".
Julian Lam 45ae31f816 fix: replace input type number with text/pattern
Julian Lam dadbcd731c feat: integrating basic client-side form validity checking in settings v1 and v2
Manuel Valle 8c4d6bbebb
Fix: categories.js not showing custom privileges ()
No shows correctly custom privileges in the Other section for a category.
Barış Soner Uşaklı 07a0212571 fix: , add admin uploads paths to priv mapping
closes 
Barış Soner Uşaklı 4efc19d5f1 feat: add ./nodebb install <plugin_name>
will install the suggested version for current nodebb closes 
Barış Soner Uşaklı 48d1439217 fix: prototype vulnerability in socket.io onMessage
Barış Soner Uşaklı 0e495f9ea4 fix: , fix custom privilege/path in routePrefixMap
will find most specific path
Barış Soner Uşaklı c7aa4ebf47 Merge branch 'master' into develop
Barış Soner Uşaklı 864fe0f971 feat: add permissions-policy header
Barış Soner Uşaklı 110311b25e fix: https://github.com/NodeBB-Community/nodebb-plugin-custom-pages/issues/68
don't crash if template doesn't have any widgets set before
Barış Soner Uşaklı fc49665fe5 fix: https://github.com/NodeBB-Community/nodebb-plugin-custom-pages/issues/68
don't crash if template doesn't have any widgets set before
Barış Soner Uşaklı bb82eb71e2 fix: , add missing await
Julian Lam 10ba7b9ced Merge branch 'master' into develop
Barış Soner Uşaklı abcfb63126 fix: , allow banned users to post
if given privileges
Barış Soner Uşaklı 3c85b944e3 feat: allow groups to be exempt from maintenance mode
closes 
Barış Soner Uşaklı 6109061501 fix: check schedule privilege, closes
Barış Soner Uşaklı b34e859c1b refactor: don't prevent startup if staticDir is undefined
https://community.nodebb.org/topic/16790/problems-with-upgrading-to-2-xx
Julian Lam 97d8b53fd3 Merge branch 'master' into develop
Julian Lam 55a197a7d7 fix: check for csrf token on /register/abort, + theme changes for v2.x branches of themes
Barış Soner Uşaklı a31ba824ea fix: upgrade script to work from 0.x to 2.x
Barış Soner Uşaklı 06d1539137 test: fix tests again
Barış Soner Uşaklı b5d38bc696 feat: new search hooks
filter:search.isAllowed, allow plugins to check if searching is allowed
filter:search.searchIn, allow searching in custom items
Julian Lam a2fafc2b15 Merge remote-tracking branch 'origin/master' into develop
Barış Soner Uşaklı 673261ff98 fix: , image height in emails
Barış Soner Uşaklı 6f673f806f fix: , apply autoLocale middleware to guests only
Barış Soner Uşaklı be92be4eee feat: add search data to filter:search.inContent
Barış Soner Uşaklı e3f2156202
feat: add search data to filter:search.inContent
Julian Lam 96b46411b1 Merge branch 'master' into develop
Julian Lam 9ee30fe7d2 fix: revert breaking change, add back SocketUser.emailConfirm
Julian Lam 9c576a0758
Email confirmation QOL updates ()
* breaking: remove `SocketUser.emailConfirm`, re: 

* chore: move email confirmation related configs to own section in Settings > Email

* feat: new user email method `getValidationExpiry`, returns expiration in ms.. probably.

* fix: bug where `user.email.isValidationPending` returned an u nexpected non-boolean value if there was no confirmation pending (only when checking email as well)

* fix: update getValidationExpiry to return ms

* test: use emailConfirmInterval for tests, for now

* fix: throw friendly error when attempting an email change within email confirmation window

* feat: new config option `emailConfirmExpiry` in days, governs how long the confirm link is good for

* test: additional tests for user email methods

* fix: add back missing handling of  option

* test: fix tests
Julian Lam 09f3ac6574 fix: in appropriately named language key `email-confirm-email2`
Julian Lam 7672194c7c fix: correctly pass dev flag to package installer
Julian Lam 09cfd0bd57 fix: use `--omit=dev` flag for npm instead of `--production`
Barış Soner Uşaklı dd4e9cce09 perf: speed up build
run webpack as soon as js targets are done
this allows building js/css in parallel
Barış Soner Uşaklı 3a70530c8e fix active plugins ()
Barış Soner Uşaklı 67efaeb4b8
fix active plugins ()
Barış Soner Uşaklı b879b6a0c2
fix: use admin:groups priv for groups ()
Barış Soner Uşaklı e35b0a869f fix: https://github.com/NodeBB/NodeBB/issues/10525
Barış Soner Uşaklı ebd5dcc6d6 fix: EEXISTS error on linux if plugin/theme overrides core js file
Julian Lam 1e4846435a fix: mixing of old and new bch syntax
Julian Lam 1e864a7518 Merge remote-tracking branch 'origin/master' into develop
Barış Soner Uşaklı 61d32bdebb fix: category ordering add test
Barış Soner Uşaklı 177d904812 fix: category ordering add test
Barış Soner Uşaklı c0b1ded363 fix more categories button not moving with parent
fix order issue
Barış Soner Uşaklı a584dae650 feat: add relevant topic events to post objects
see c9604f216a
Julian Lam 14515f6004 fix: add lru-cache to checked packages, to fix upgrade issue with lru-cache
Julian Lam 53d47a58f6 fix: use `--omit=dev` flag for npm instead of `--production`
Julian Lam 6391f77b01 Merge remote-tracking branch 'origin/master' into develop
Julian Lam cf4f5447bb fix: , allow `middleware.checkAccountPermissions` to be called with either uid or userslug in params
Previously, the middleware only worked with userslug params
Barış Soner Uşaklı b5dd89e1c0
feat: store topic title and tags in diffs ()
* feat: store topic title and tags in diffs

allow restoring post diff if tags didn't change

* test: fix tests, fast computer problems
Julian Lam fe249fa577 fix: listen to -d flag on cli upgrade
Barış Soner Uşaklı ebd7c05c4c feat: paginate recentposts.rss and
category/1/recentposts.rss
Julian Lam 6061d611ea Merge remote-tracking branch 'origin/master' into develop
Barış Soner Uşaklı 8aa1596d23 chore: bring back treding plugins
Barış Soner Uşaklı 3d5a6b39d6 lint: fix lint
Barış Soner Uşaklı b392450c36 perf: disable trending plugins, too slow due to nbbpm
Opliko 665f36b707 feat: add quiet to action:settings.set
Makes it possible to ignore quiet updates without abusing the `filter` hook
Julian Lam 67cb70352f fix: missing escape on ACP category backgroundImage property
Julian Lam 15b1561fd3 feat: introduce ACP defined option to rescind notif or do nothing on flag resolve/reject
/cc 
Julian Lam d05705183f refactor: move export generation logic to v3 controller, GET/HEAD routes for exports
re: 
Julian Lam 0cda5aa3e3 feat: allow v3 api to handle 202 and 204 response codes as well.
Julian Lam 8b7cf48ade Merge remote-tracking branch 'origin/master' into develop
Julian Lam 9b96c33d5d fix: wrap passport.authenticate to pass in keepSessionInfo if not already set
Julian Lam 65b3996ac6 fix: removing duplicate session rerolling code (as it is in passport@^0.6 now)
Julian Lam 20ebf0a1e0 Merge remote-tracking branch 'origin/master' into develop
Barış Soner Uşaklı bc37a5c516 fix: parseInt caller.uid closes
Barış Soner Uşaklı fc9b436f3e Merge branch 'master' of https://github.com/NodeBB/NodeBB
Barış Soner Uşaklı 489fb3a36f fix: missing req, closes
Julian Lam 4dc7fa050f fix: , disallow inline viewing of uploaded html files
Julian Lam 990ad6a11a Merge remote-tracking branch 'origin/master' into develop
Julian Lam ec048a01ba fix: , incorrect conditional in email interstitial partial
Barış Soner Uşaklı aba420a3f3 feat: setting to show signatures only once in topics, closes
Barış Soner Uşaklı 14c79763dd refactor: use group.slug on acp group urls closes
Barış Soner Uşaklı e06e526e54 fix: don't crash if post is undefined
Barış Soner Uşaklı 33458701c1 test: passport0.6 ()
* test: passport0.6

* test: make logout async, fix lint

* test: keepSessionInfo flag

* revert: csrf load
Opliko 3975fa2e45 fix: return at least one in sizeCalculation ()
if post content is empty post cache should still consider its size to be at least one. fixes 
Barış Soner Uşaklı 4a3e36a766 fix: don't crash if post is undefined
Opliko a9bbb586fc
feat: allow plugins to add to admin cache list ()
* feat: allow plugins to add to admin cache list

resolves  

plugins will have to use `filter:admin.cache.get` hook and just add their own cache to the object there.

* feat: add dump to ttlCache and expose properties

* feat: also expose properties under their current names

* feat: display TTL if set
Barış Soner Uşaklı 6b2a6f9006
test: passport0.6 ()
* test: passport0.6

* test: make logout async, fix lint

* test: keepSessionInfo flag

* revert: csrf load
Opliko 15ca460c8f
fix: return at least one in sizeCalculation ()
if post content is empty post cache should still consider its size to be at least one. fixes 
Julian Lam 9b753d6d57
TTL Cache ()
* refactor: move src/cacheCreate.js to src/cache/lru.js

* fix: call new library location for lru cache creator

* feat: add ttl cache

* fix: update upload throttler to use ttl cache instead of lru cache

* chore: add missing dependency

* fix: avoid pubsub conflicts

* fix: use get instead of peek, which is not available in ttl-cache
Julian Lam c07d595662
Update to lru-cache@^7 ()
* chore(deps): bump lru-cache from 6.0.0 to 7.13.1 in /install

Bumps [lru-cache](https://github.com/isaacs/node-lru-cache) from 6.0.0 to 7.13.1.
- [Release notes](https://github.com/isaacs/node-lru-cache/releases)
- [Changelog](https://github.com/isaacs/node-lru-cache/blob/main/CHANGELOG.md)
- [Commits](https://github.com/isaacs/node-lru-cache/compare/v6.0.0...v7.13.1)

---
updated-dependencies:
- dependency-name: lru-cache
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>

* fix(lru-cache): remove unneeded `length` params for cache creation, as `maxSize` was not used in those init calls, also renamed some methods to match new method names in lru-cache [breaking]

Added deprecation notices for old params

* fix: replace three direct calls to lru-cache with call to cacheCreate, moved cache creation call in uploads to run on first init as config is not populated at lib init

* test: move configs init above cache reset calls in databasemock

* move some more code above cache clear

* refactor: remove unused

* test: lru

* test: more debug

* test: on more test

* use await helpers.uploadFile

* fix: tests remove logs

* fix: acp cache page

* fix: add in one more guard again cache instantiation with `length` prop but no `maxSize` prop

* fix(deps): bump markdown

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Opliko b3a37a7f35 feat: support packageManager property in package.json
resolves 
Julian Lam 38bf30c8ca fix: adapt to breaking change in commander
Julian Lam d0255fc6a5 fix: move panel-offset setting code back to theme header
Julian Lam c6782a2173 Merge remote-tracking branch 'origin/master' into develop
Julian Lam 9d27e90740 fix: don't require password challenge if no password is set in user account
Julian Lam 287f4c2c41 fix: do not throw if password passed into `isPasswordCorrect` is invalid, just return false
Julian Lam 7fcee42be9 feat: present a password challenge on email update flow
Barış Soner Uşaklı 7e8ad785f4 fix: don't crash if req.body.username is not string
Error: req.body.username.trim is not a function
File: authenticationController.login (/usr/src/app/src/controllers/authentication.js:247:40)
Barış Soner Uşaklı 55c5588a4b fix: don't crash if target/user is undefined
Error: TypeError: Cannot read properties of undefined (reading 'displayname')
File: Flags.notify (/usr/src/app/src/flags.js:812:89)
Julian Lam 9ee1afbb0f Merge branch 'master' into develop
Julian Lam 06f089afda test: fix user email tests
Barış Soner Uşaklı d73f0f9ccb perf: make single db call
Julian Lam e092bfeb46 Merge remote-tracking branch 'origin/master' into develop
Julian Lam cba9047f67 fix: , hide unconfirmed emails from user data retrieval methods
Julian Lam 3e062a7f29 fix: use different emoji on NodeBB Ready — again because procrastination
Barış Soner Uşaklı cd438b328a fix: unnecessary escape
Barış Soner Uşaklı f64a69132a Merge branch 'develop' of https://github.com/NodeBB/NodeBB into develop
Julian Lam dc3a6a29bc fix: , do not purge files without a timestamp prefix
Julian Lam 89173f17ca fix: , logic error in COEP header; helmet config
Julian Lam 5176fb1544 feat: add emoji to startup logs, because procrastination.
Julian Lam dcacd815a9 refactor: invert helmet configuration
Julian Lam 820bc994d8
feat: UI changes for ACP > Manage > Categories ()
* Revert "Revert "feat: cross origin opener policy options ()""

This reverts commit 46050ace1a.

* Revert "Revert "chore(i18n): fallback strings for new resources: nodebb.admin-settings-advanced""

This reverts commit 9f291c07d3.

* feat: closes , don't trim children if category is marked section

* feat: fire hook to allow plugins to filter the pids returned in a user profile

/cc 

* fix: use `user.hidePrivateData();` more consistently across user retrieval endpoints

* fix: better looking placeholder text for ACP search

* fix: bug where fallback to forum search was not working due to client-side error

* feat: allow plugins to toggle whether IPs are shown in the users CSV export

* feat: Allow defining active plugins in config ()

* Revert "Revert "feat: cross origin opener policy options ()""

This reverts commit 46050ace1a.

* Revert "Revert "chore(i18n): fallback strings for new resources: nodebb.admin-settings-advanced""

This reverts commit 9f291c07d3.

* feat: closes , don't trim children if category is marked section

* feat: fire hook to allow plugins to filter the pids returned in a user profile

/cc 

* fix: use `user.hidePrivateData();` more consistently across user retrieval endpoints

* feat: Allow defining active plugins in config

resolves 

* fix: assign the db result to files properly

* test: add tests with plugins in config

* feat: better theme change handling

* feat: add visual indication that plugins can't be activated

* test: correct hooks

* test: fix test definitions

* test: remove instead of resetting nconf to avoid affecting other tests

* test: ... I forgot how nconf worked

* fix: remove negation

* docs: improve wording of error message

* feat: reduce code duplication

* style: remove a redundant space

* fix: remove unused imports

* fix: use nconf instead of requiring config.json

* fix: await...

* fix: second missed await

* fix: move back from getActiveIds to getActive

* fix: use paths again?

* fix: typo

* fix: move require into the function

* fix: forgot to change back to getActive

* test: getActive returns only id

* test: accedently commented out some stuff

* feat: added note to top of plugins page if \!canChangeState

Co-authored-by: Julian Lam <julian@nodebb.org>
Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>

* feat: show an informative message when no plugins are found after filtering

fixes 

* Latest translations and fallbacks

* Latest translations and fallbacks

* chore(deps): bump ace-builds from 1.7.1 to 1.8.1 in /install

Bumps [ace-builds](https://github.com/ajaxorg/ace-builds) from 1.7.1 to 1.8.1.
- [Release notes](https://github.com/ajaxorg/ace-builds/releases)
- [Changelog](https://github.com/ajaxorg/ace-builds/blob/master/CHANGELOG.md)
- [Commits](https://github.com/ajaxorg/ace-builds/compare/v1.7.1...v1.8.1)

---
updated-dependencies:
- dependency-name: ace-builds
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

* fix: swap out icons in ACP > Manage > Categories to more intuitive ones, remove extra placeholder div

* fix: hide expando button if no subcategories; remove attempt at establishing common vars, increased spacing between categories in list

* fix: buggy expando state on category drag/drop

Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Co-authored-by: Opliko <opliko.reg@protonmail.com>
Co-authored-by: Misty Release Bot <deploy@nodebb.org>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Julian Lam 6840a7423b feat: show an informative message when no plugins are found after filtering
fixes 
Opliko 23cb67a112 feat: Allow defining active plugins in config ()
* Revert "Revert "feat: cross origin opener policy options ()""

This reverts commit 46050ace1a.

* Revert "Revert "chore(i18n): fallback strings for new resources: nodebb.admin-settings-advanced""

This reverts commit 9f291c07d3.

* feat: closes , don't trim children if category is marked section

* feat: fire hook to allow plugins to filter the pids returned in a user profile

/cc 

* fix: use `user.hidePrivateData();` more consistently across user retrieval endpoints

* feat: Allow defining active plugins in config

resolves 

* fix: assign the db result to files properly

* test: add tests with plugins in config

* feat: better theme change handling

* feat: add visual indication that plugins can't be activated

* test: correct hooks

* test: fix test definitions

* test: remove instead of resetting nconf to avoid affecting other tests

* test: ... I forgot how nconf worked

* fix: remove negation

* docs: improve wording of error message

* feat: reduce code duplication

* style: remove a redundant space

* fix: remove unused imports

* fix: use nconf instead of requiring config.json

* fix: await...

* fix: second missed await

* fix: move back from getActiveIds to getActive

* fix: use paths again?

* fix: typo

* fix: move require into the function

* fix: forgot to change back to getActive

* test: getActive returns only id

* test: accedently commented out some stuff

* feat: added note to top of plugins page if \!canChangeState

Co-authored-by: Julian Lam <julian@nodebb.org>
Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Julian Lam a6af47da02 feat: allow plugins to toggle whether IPs are shown in the users CSV export
Julian Lam 1b9c68196f fix: better looking placeholder text for ACP search
Julian Lam 0529f2fb5d fix: use `user.hidePrivateData();` more consistently across user retrieval endpoints
Julian Lam c26be43ac5 feat: fire hook to allow plugins to filter the pids returned in a user profile
/cc 
Barış Soner Uşaklı 7e80cc1033 feat: closes , don't trim children if category is marked section
Julian Lam ad072c03d1 Revert "Revert "feat: cross origin opener policy options ()""
This reverts commit 46050ace1a.
Tong Ho bbc7f2afba fix: cannot turn off all networks
Tong Ho 2e088a8ef0 fix: cannot setting networks for sharing posts
Julian Lam c93bd0105e fix: expire email validation tokens on password change
Julian Lam 0d58e8a6af fix: remove extraneous console.log
Julian Lam 3c41ae04cd fix: , extraneous apostrophes in plugin upgrader
Julian Lam 60114219c1 fix: get version from install/package.json instead
Julian Lam 8d701ec3e2 fix: , always re-add theme to active plugins, on theme set
Julian Lam f38b2a737a fix: improper handling of single vs. multiple inputs for hidePrivateData
Julian Lam ecf0e8ce22 fix: observe user-specific and ACP-specific hiding rules for fullname
Julian Lam 3f5ae893c6 refactor: allow user.hidePrivateData() to handle an array of `userData`
Julian Lam 17e44ff5c9 feat: fire hook to allow plugins to filter the pids returned in a user profile
/cc 
Barış Soner Uşaklı be917e8d39 feat: closes , don't trim children if category is marked section
Julian Lam 0d68643bcb Revert "Revert "feat: cross origin opener policy options ()""
This reverts commit 46050ace1a.
Julian Lam 43f9e6c8e4 fix: handle ENOENT on file deletion, closes
Julian Lam 46050ace1a Revert "feat: cross origin opener policy options ()"
This reverts commit 881323583f.
Barış Soner Uşaklı 881323583f
feat: cross origin opener policy options ()
Julian Lam 22368b996e refactor: move orphan cleaning logic to its own method, added tests for getOrphans and cleanOrphans
Julian Lam 88aee43947 feat: new cronjob and ACP option to delete orphans after configurable number of days, closes
Julian Lam bef236f371 chore: remove unnecessary `affected` set from deprecated plugin hook
Julian Lam b9d4724e0f feat: allowed plugins to modify email verification details prior to db saving or email send/plugin fire
+ new hook `filter:user.verify`
- hook `filter:user.verify.code`
Julian Lam 3a015eb8e3 fix: no need to pass in empty Set in deprecated hooks
Barış Soner Uşaklı b6f8e2fd05 fix:
Julian Lam a04da673fa fix: , all uploads in `uploads/files` showing orphaned
Julian Lam 7f870beb59 fix: bug where post associations are not shown when the directory is `files`
Julian Lam ece733eddc feat: pass absolute url to post into post tools response,
Julian Lam a35642601c fix: buildBreadcrumbs naively prepending relative path even if absolute paths are passed in
Barış Soner Uşaklı 191fb9f443 test: fix tests again
Barış Soner Uşaklı e802fab87f fix: get rid of math.random in utils.generateUUID
Barış Soner Uşaklı 7e4d2852f6 fix: , gray out disabled nav items
use enabled property if present
change default to true, so added nav items are enabled by default
Barış Soner Uşaklı 0084b563f3 fix: , fix user digest setting display acp
Julian Lam 54ff768f51 chore: remove optional `middleware` parameter from setupPageRoute and setupAdminPageRoute calls
Barış Soner Uşaklı c926358d73 feat: add mute history, closes
Barış Soner Uşaklı 9acdc6808c feat: allow unban/unmute on flag details page. closes
Barış Soner Uşaklı b17a81bfb0 fix: translate api error messages to user lang, closes ,
Barış Soner Uşaklı 3a009f96cd fix: closes , convert \r\n to \n so it isn't counted as 2 characters
Barış Soner Uşaklı b860c2605c feat: paginaton for admins-mods, closes
ability to select categoriest to see children
Julian Lam 1411059698 feat: fix typo, show route in deprecation notice for third-param removal in `setupPageRoute`
Barış Soner Uşaklı 3a77e71443 lint: fix semicolon
Barış Soner Uşaklı a583141252 feat: add button to see category children, closes
Barış Soner Uşaklı 0e60a704a5 fix: 'unread' postIndex regression closes
Barış Soner Uşaklı f07b4484cf feat: add post to hook params
Julian Lam e2ff1e39b1 fix: exit code 1 on failed plugin activation
Barış Soner Uşaklı 5e7d366f55 fix: , dont show backlinks if you dont have read privilege
Julian Lam 0c19b1e57c feat: send back missing parameters as array of missing properties, in API response
Barış Soner Uşaklı 323dbc9789 feat: add hook for user invite
Barış Soner Uşaklı 84f2726391
refactor: deprecate middleware param ()
* refactor: deprecate middleware param

make middlewares optional

* chore: add node 18 again
Barış Soner Uşaklı ea01ba0152 fix: , fix category move event text
Barış Soner Uşaklı 23175110a2 feat: post queue bulk actions closes , fix ,
Barış Soner Uşaklı d20b07cfea
Webpack5 ()
* feat: webpack 5 part 1

* fix: gruntfile fixes

* fix: fix taskbar warning

add app.importScript
copy public/src/modules to build folder

* refactor: remove commented old code

* feat: reenable admin

* fix: acp settings pages, fix sortable on manage categories

embedded require in html not allowed

* fix: bundle serialize/deserizeli so plugins dont break

* test: fixe util tests

* test: fix require path

* test: more test fixes

* test: require correct utils module

* test: require correct utils

* test: log stack

* test: fix db require blowing up tests

* test: move and disable bundle test

* refactor: add aliases

* test: disable testing route

* fix: move webpack modules necessary for build, into `dependencies`

* test: fix one more test

remove 500-embed.tpl

* fix: restore use of assets/nodebb.min.js, at least for now

* fix: remove unnecessary line break

* fix: point to proper ACP bundle

* test: maybe fix build test

* test: composer

* refactor: dont need dist

* refactor: more cleanup

use everything from build/public folder

* get rid of conditional import in app.js

* fix: ace

* refactor: cropper alias

* test: lint and test fixes

* lint: fix

* refactor: rename function to app.require

* refactor: go back to using app.require

* chore: use github branch

* chore: use webpack branch

* feat: webpack webinstaller

* feat: add chunkFile name with contenthash

* refactor: move hooks to top

* refactor: get rid of template500Function

* fix(deps): use webpack5 branch of 2factor plugin

* chore: tagging v2.0.0-beta.0 pre-release version 💥 :shipit: 🎉 🚀

* refactor: disable cache on templates

loadTemplate is called once by benchpress and the result is cache internally

* refactor: add server side helpers.js

* feat: deprecate /plugins shorthand route, closes 

* refactor: use build/public for webpack

* test: fix filename

* fix: more specific selector

* lint: ignore

* refactor: fix comments

* test: add debug for random failing test

* refactor: cleanup

remove test page, remove dupe functions in utils.common

* lint: use relative path  for now

* chore: bump prerelease version

* feat: add translateKeys

* fix: optional params

* fix: get rid of extra timeago files

* refactor: cleanup, require timeago locale earlier

remove translator.prepareDOM, it is in header.tpl html tag

* refactor: privileges system to use a Map in the backend instead of separate objects for keys and labels ()

* refactor: privileges system to use a Map in the backend instead of separate objects for keys and labels

- Existing hooks are preserved (to be deprecated at a later date, possibly)
- New init hooks are called on NodeBB start, and provide a one-stop shop to add new privileges, instead of having to add to four different hooks

* docs: fix typo in comment

* test: spec changes

* refactor: privileges system to use a Map in the backend instead of separate objects for keys and labels ()

* refactor: privileges system to use a Map in the backend instead of separate objects for keys and labels

- Existing hooks are preserved (to be deprecated at a later date, possibly)
- New init hooks are called on NodeBB start, and provide a one-stop shop to add new privileges, instead of having to add to four different hooks

* docs: fix typo in comment

* test: spec changes

* feat: allow app.require('bootbox'/'benchpressjs')

* refactor: require server side utils

* test: jquery ready

* change istaller to use build/public

* test: use document.addEventListener

* refactor: closes 

* refactor: generateTopicClass

* fix: column counts for other privileges

* fix: , regression where sorted-list items did not render into the DOM in the predicted order [breaking]

* fix: typo in hook name

* refactor: introduce a generic autocomplete.init() method that can be called to add nodebb-style autocompletion but using different data sources (e.g. not user/groups/tags)

* fix: crash if `delay` not passed in (as it cannot be destructured)

* refactor: replace substr

* feat: set --panel-offset style in html element based on stored value in localStorage

* refactor: addDropupHandler() logic to be less naive

- Take into account height of the menu
- Don't apply dropUp logic if there's nothing in the dropdown
- Remove 'hidden' class (added by default in Persona for post tools) when menu items are added

closes 

* refactor: simplify utils.params [breaking]

Retrospective analysis of the usage of this method suggests that the options passed in are superfluous, and that only `url` is required. Using a browser built-in makes more sense to accomplish what this method sets out to do.

* feat: add support for returning full URLSearchParams for utils.params

* fix: utils.params() fallback handling

* fix: default empty obj for params()

* fix: remove \'loggedin\' and \'register\' qs parameters once they have been used, delay invocation of messages until ajaxify.end

* fix: utils.params() not allowing relative paths to be passed in

* refactor(DRY): new assertPasswordValidity utils method

* fix: incorrect error message returned on insufficient privilege on flag edit

* fix: read/update/delete access to flags API should be limited for moderators to only post flags in categories they moderate

- added failing tests and patched up middleware.assert.flags to fix

* refactor: flag api v3 tests to create new post and flags on every round

* fix: missing error:no-flag language key

* refactor: flags.canView to check flag existence, simplify middleware.assert.flag

* feat: flag deletion API endpoint, 

* feat: UI for flag deletion, closes 

* chore: update plugin versions

* chore: up emoji

* chore: update markdown

* chore: up emoji-android

* fix: regression caused by utils.params() refactor, supports arrays and pipes all values through utils.toType, adjusts tests to type check

Co-authored-by: Julian Lam <julian@nodebb.org>
Julian Lam e4a9c07817 feat: output canonical URL as last line on NodeBB boot
Barış Soner Uşaklı 82389469f6 feat: make it simpler to use redis sentinels
Barış Soner Uşaklı d98ca43799 Revert "refactor: closes #10509"
This reverts commit 7f241dbbe6.
Barış Soner Uşaklı 7f241dbbe6 refactor: closes
deprecate third param(middleware) to setupPageRoute/setupAdminPageRoute
make middlewares optional on all 3 helpers
Barış Soner Uşaklı ac125538d0 refactor: show invalid uri
Barış Soner Uşaklı a8e642ade2 refactor: skip content length check if submitting from post-queue
Barış Soner Uşaklı b9f9164308 fix: , allow unblocking admin/mod
if they were blocked before becoming admin/mod it wasn't possible to unblock them
Barış Soner Uşaklı b28f9f776a feat: closes , minimum reputation to chat
Barış Soner Uşaklı 5316029f91 fix: dont add caller to arrays
Barış Soner Uşaklı c52401da02 fix: , don't leak deleted message in cleanedContent
Julian Lam 9f91db16cb fix: , trim trailing slashes on config url
Barış Soner Uşaklı 398777633f fix: closes , fix DST issue on acp dashboard
Barış Soner Uşaklı 767973717b
perf: WIP , allow array of pids for posts.purge ()
* perf: WIP , allow array of pids for posts.purge

* refactor: deletePostDiffs

* perf: deletePostFromReplies/deletePostFromGroups

* refactor: upload

* refactor: deleteFromCategoryRecentPosts

deleteFromUsersBookmarks
deleteFromUsersVotes

* feat: closes , add incrObjectFieldByBulk

* refactor: allow nids for notifications.rescind

* refactor: allow uids array for user.updatePostCount

* refactor: rewrite deleteFromTopicUserNotification to work with an array

* feat: deprecate action:post.purge as well

* lint: add missing comma
Barış Soner Uşaklı 799e94e02e feat: , add cutoff to suggested topics
Barış Soner Uşaklı e8058ca35c feat: add response:helpers.notAllowed
Barış Soner Uşaklı b8765df5f4 feat: add filter:image.stripEXIF
CommanderRoot 200f0b2e4f
refactor: replace deprecated String.prototype.substr() ()
.substr() is deprecated so we replace it with .slice() which works similarily but isn't deprecated

Signed-off-by: Tobias Speicher <rootcommander@gmail.com>
chadjw fe072d6091
Allows socket authentication to be handled within plugins ()
Barış Soner Uşaklı 002a241cc5 fix: delete history as well
Barış Soner Uşaklı 93b6053284 fix: handle purge posts as well
Barış Soner Uşaklı 31251282ad feat: delete flagId field from post/user on flag purge
Barış Soner Uşaklı 03fdb5bede fix: byCid removal, targetCid not stored in flagObj
Barış Soner Uşaklı 3b529b84b5 feat: add flags.purge
Barış Soner Uşaklı 9abe22a04b refactor: remove some verbose logging
Barış Soner Uşaklı 29b86b3276 refactor: :trollface:
Barış Soner Uşaklı 421ba6e1a2 feat: new admin events, closes