Commit Graph

963 Commits (dd7424e5b5c7e285a7b6e6cb35564099a11449b6)

Author SHA1 Message Date
Barış Soner Uşaklı b9cff5775c fix: edge case in test
if user is created the other one will be renamed
Barış Soner Uşaklı 844f2b4ed0 feat: , allow editing category of queued topic
Barış Soner Uşaklı 6f889c9c83 fix: try again
Barış Soner Uşaklı a46adb3fd5 fix: more tests
Barış Soner Uşaklı 65395ae59d fix: tests
Barış Soner Uşaklı 2485a55092 feat: , allow editing title before posting from queue
Barış Soner Uşaklı 00d39fb32c feat: , export groups members as csv
Barış Soner Uşaklı 73ddf1cb98 fix: groups.updateCover
Barış Soner Uşaklı c513b88dff feat: , daily downvote limits
Barış Soner Uşaklı c2ca02dfc7 fix:
make isPrimary and isCluster always booleans
they were strings when using ./nodebb start and boolean if they were in config.json and started with node app.js
Barış Soner Uşaklı 02ac44cc5a fix: dont allow searching by ip/banned/flagged for regular users
Barış Soner Uşaklı e95cd28f6f
Zscan ()
* feat: zscan

* fix: mongodb tests

* feat: scan, ip search starts with
Barış Soner Uşaklı 723fe8e8e0
feat: zscan ()
* feat: zscan

* fix: mongodb tests
Barış Soner Uşaklı f0ce309d03 fix: test
Barış Soner Uşaklı c718b7293e feat: , min/max tags per category
Barış Soner Uşaklı 6aecc1770c feat: increase wait
Barış Soner Uşaklı f03ca0867b fix: tests
Barış Soner Uşaklı 48b41debe6
fix: vulnerability in cover and admin uploads ()
* fix: vulnerability in cover and admin uploads

* fix: remove old test

* fix: update tests
Barış Soner Uşaklı bef37e27cb
fix: test lock for user create ()
* fix: test lock for user create

* fix: redis hdel with undefined

* feat: add test for undefined key in deleteObjectFields
Julian Lam f909ed2541 feat: show editor in post diffs if available
Julian Lam d5578c9906 fix: tests breaking due to
Barış Soner Uşaklı 18d892398f fix: add timestamp to initial username history
Barış Soner Uşaklı bb3aa54006 feat: merge changes
allow selecting main topic to merge into
allow specifying a new title for merge topic
upon merge go to correct topic
new tests for merging with options
Barış Soner Uşaklı 3be4d5f7d5 feat: redirect /me to user profile
Julian Lam 6b1d1acb48 fix(style): more switch..case
Barış Soner Uşaklı 75b3a81dad fix: clear error log before checking
fix intermittent test failure due to analytics being written every 10 seconds
Peter Jaszkowiak de7ec47f13
fix: , remove webfonts ()
Julian Lam da90fd562e fix: more tests
Julian Lam a51fff8bd1
refactor: remove general menu from ACP ()
* refactor: remove general menu from ACP

* fix: incorrect translation keys, fixed tests
Julian Lam a66fe01377 fix: test breakages from 8d995d1eb6
Barış Soner Uşaklı 0009f54e6e feat: add getSortedSetMembers
Barış Soner Uşaklı ec5582b53c
feat: add privilege give/rescind hooks ()
* feat: add privilege give/rescind hooks

action:privileges.categories.give/rescind
action:privileges.global.give/rescind

breaking change, privileges.categories.give/rescind and privileges.global.give/rescind use full privilege name for groups ie `groups:find` instead of `find`

* fix: tests, privileges renamed
Barış Soner Uşaklı 3b6d57e497 refactor: move code
Barış Soner Uşaklı 4ee3543ea4 feat: tweak intersection code, add tests
Julian Lam 6f504c4142
Remove allowFileUploads ACP option ()
* feat: allow awaitable upgrade scripts

* feat: allowFileUploads removal upgrade script

* refactor: remove unnecessary ACP option `allowFileUploads`

* fix: updated upgrade script template to not use callback arg

* fix: upgrade script as per @baris

* fix: add missing await

* fix: add missing await
Barış Soner Uşaklı f2907908c9 fix: another test fix
Barış Soner Uşaklı feb748a44d fix: tests
Barış Soner Uşaklı 12c6bc2e07 feat: convert queries so they used indices directly
Barış Soner Uşaklı 7a801abade fix: tests on redis
Barış Soner Uşaklı a032e12b7e fix: tests
Barış Soner Uşaklı 81e33b9391 fix:
Barış Soner Uşaklı bfad457275 feat: add methods for adding/removing tags from topics
Barış Soner Uşaklı 97c086aba9 fix: missing await
Barış Soner Uşaklı edf9fe3b7f feat: add null tests for sorted sets
Barış Soner Uşaklı aad0880f7c feat: add filter:categories.getRecentTopicReplies
pass req.query to getRecentTopicReplies
Barış Soner Uşaklı a969c5cec9 feat: allow activating additional plugins for testing via config.json
Barış Soner Uşaklı 3a23ddaba5 feat: move plugin tests to separate file
Barış Soner Uşaklı a6bb9f4364 fix: , run plugin tests for installed plugins
Barış Soner Uşaklı 3d0db9630f fix: remove deprecated mocha.opts
Barış Soner Uşaklı 9d153fd388 fix: , dont readd user after deletion
don't add user uid back to users:* sorted sets if they are deleted
upgrade script to fix users:* sorted sets
Barış Soner Uşaklı 0391856d7d fix: , rescind notif when its resolved/rejected
Julian Lam ccc6118d30
Testing suite integration for openapi spec ()
* feat: testing suite integration for openapi spec

The testing suite now takes the openapi spec into account. It will
check each route defined, make a call to it, and compare the
response with the defined schema. Any mismatches will cause the
test to fail.

* fix(openapi): removed debug stuff from tests

* fix(openapi): fixed some tests

* fix(openapi): added additional check to tests, test fixes

* fix(openapi): better tests, fixed spec errors

* fix(openapi): bad conditional in test

* fix: oops

* fix(openapi): more tests fixing

* fix(openapi): more tests

* fix(openapi): fix some more tests

* fix: verbose'd an info log

* fix: topic pagination route returns schema-optimized pagination block

* fix(openapi): more test/spec fixes

* fix(openapi): accidentally sending in authenticated jar for anon routes

* fix(openapi): more test/spec fixes

* fix(openapi): more spec fixes

* fix: timestampReadable Invalid Date

* fix(openapi): more tests... almost there

* fix(openapi): more tests fixing

* fix(openapi): finally all tests passing

* fix(openapi): added reverse test to compare response to spec

... and fixed all the tests that broke

* fix: remove tests related to group covers, as route is gone

* fix(openapi): broken test on travis

* fix(openapi): broken test on travis

* fix(openapi): broken test on travis

* fix(openapi): object cache is not present for psql

* fix: tests

Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Julian Lam 6edf02d4a5 fix: remove upload picture test (avatars)
Julian Lam 442fe65f5a fix: remove tests related to group covers, as route is gone
Julian Lam 8387178b25 feat(openapi): merging openapi-test branch into master
Barış Soner Uşaklı 8e23dec84b fix: lint
Barış Soner Uşaklı e72a29b3fd fix: return null if field does not exist
Andrew Rodrigues 3c9689a5ac
feat: settings sorted list ()
* feat: settings sorted list

see https://github.com/NodeBB/nodebb-plugin-quickstart/pull/9/files for sample
Barış Soner Uşaklı 067034082f fix: , update deleted/restored messages
Barış Soner Uşaklı 4d0636f847 fix: , prevent account deletion
Julian Lam d6e3f3f058
fix: , broken site if no server-side session ()
* fix: , broken site if no server-side session

During the `addHeader` middleware, a check is now done to see if
`req.session.meta` is present. This value is only present if the user
has a valid server-side session.  If it is missing, then it is probably
safe to assume that the server-side session was deleted (either
intentionally or accidentally). In that scenario, the client-side cookie
should be cleared.

Also, there was an issue where the sessionRefresh flag was never cleared
after a successful login, so that was fixed too.

* feat: exported method to get cookie config

* fix: don't clear cookie if cookie is being set

* fix: socket.io tests

Co-authored-by: Barış Soner Uşaklı <barisusakli@gmail.com>
Baris Usakli 87225a90c3 fix: , upgrade mkdirp to 1.0.x
Barış Soner Uşaklı 8c48f94b96 fix: , dont allow restore if not deleted by self
Barış Soner Uşaklı 66febb8071 feat: add test for isOnline
Barış Soner Uşaklı df2c785127 feat: add test for change post owner
Barış Soner Uşaklı 23810cc64b fix: , check if user is in room before removing
Baris Usakli 418c174d56 fix: dont return flag data to client
Barış Soner Uşaklı 51236df4ed fix: check if user has read priv before flagging
Barış Soner Uşaklı 1f13ab8a19 fix: restrict getUsersInRoom to members
Julian Lam ecc579a29c fix: tests for messaging
Barış Soner Uşaklı 1b08f37612 fix: tests, was using hardcoded message id
Barış Soner Uşaklı bfaba89557 Merge branch 'master' of https://github.com/NodeBB/NodeBB
Julian Lam 8e5a2276af
feat: check flag values on save (assignee and state) ()
* feat: add assignee checking when updating flag

Prior to this, it was possible to update the assignee to any value (or
any user. This commit adds checking to allow only admins, global
moderators, or in the case of flagged posts, moderators.

Also some prep work was added for value checking `state`.

* feat: value checking `state` on flag update

The state should be one of the constants defined earlier in the file.
Barış Soner Uşaklı 6a63c1a100 fix: escape system message, don't allow editing system messages
Barış Soner Uşaklı 8c6a7954cf fix: delete upload
Barış Soner Uşaklı 01d1ae78c8 fix: , bubble errors from static hooks
Barış Soner Uşaklı 3e52557689 fix: change owner missing await
Barış Soner Uşaklı e06c1bfcd2 fix: escape config.userLang/acpLang, don't allow invalid language codes
Barış Soner Uşaklı 61da8c29ac fix: group create/join/update name validation
Barış Soner Uşaklı 10989cccaa fix: meta description missing if url doesn't have post index
Barış Soner Uşaklı 9d074731f4 fix: login with weak password
Baris Usakli c2cd7de891 fix: , dont show hidden groups in search
Opliko 0efe27b1f2 fix: make _csrf a secure cookie if the website is using https ()
* Make _csrf a secure cookie if the website is using https

* fix style for TravsCI

* Add `url_parsed` to databasemock
Barış Soner Uşaklı 480a64aaa7 feat: , pass query params when redirecting to posts
Barış Soner Uşaklı e3c9dafa08 fix: tests
Barış Soner Uşaklı 1cedc4a0d6 feat: , allow post queue based on group
allow multiple select in ACP pages
Julian Lam cf7e0cfd2d
feat: no more session cookie for guests ()
* feat: no more session cookie for guests

* fix(tests): added additional tests and fixed the broken test
Barış Soner Uşaklı 441dd86d29 fix: convert param to string in slugify
fixes adding users to privilege table
Barış Soner Uşaklı ca3be1f336
fix: ()
Baris Usakli 0da4f7ee8d fix: event tests
Barış Soner Uşaklı 661a0f5068 fix: don't show deleted topics on unread
Barış Soner Uşaklı 75bcb0f484 fix: remove unused data from post/topic/user hashes
Barış Soner Uşaklı 6fb29e8408 fix: tests
Barış Soner Uşaklı 02d38caf47 refactor: async/await
Barış Soner Uşaklı 3caa387ac6 fix: tests
Baris Usakli 9c051386d5 fix: tests
Barış Soner Uşaklı ffe3670ff5 feat: deprecate file.isFileTypeAllowed
use image.isFileTypeAllowed, this function was always meant for images
Barış Soner Uşaklı 310c6fd33f
properly filter /unread /recent /popular /top ()
* feat: add failing test for pagination

* feat: test

* fix: redis tests

* refactor: remove logs

* fix: add new test

* feat: make sortedSetRangeByScore work with keys on redis

* fix: hardcoded set name

* feat: show topics from readable categories on recent/popular/top

* feat: rewrite unread topics

respect watched categories and followed topics

* fix: term + watched
Barış Soner Uşaklı 22b02f1407
feat: add failing test for pagination ()
* feat: add failing test for pagination

* feat: test

* fix: redis tests

* refactor: remove logs
Barış Soner Uşaklı b602c04463 feat: refactor getSortedSetRange to allow big arrays