Jump to content

Infrastructure/Evaluation/Discourse: Difference between revisions

From KDE Community Wiki
Sitter (talk | contribs)
Created page with "= Discourse = Ongoing evaluation of Discourse for Forums / Mailing List needs. https://www.discourse.org Proposal thread: https://markmail.org/thread/rnmyc5upbxdqoug5 == P..."
 
 
(20 intermediate revisions by 2 users not shown)
Line 5: Line 5:
https://www.discourse.org
https://www.discourse.org


Proposal thread: https://markmail.org/thread/rnmyc5upbxdqoug5
Old proposal thread: https://markmail.org/thread/rnmyc5upbxdqoug5
 
== Trial ==
http://discuss.kde.org.uk
Give it a shot.  Testbed server from June 2019.  Set up by Jonathan.


== Pile of Requirements/Desires ==
== Pile of Requirements/Desires ==
Line 18: Line 22:
* Scalable search for amount of posts we have
* Scalable search for amount of posts we have
* Tagcloud
* Tagcloud
* Gallery (for krita; unclear of what is exactly required here)
* Retain all data from current forum
* Retain all data from current forum


Line 53: Line 58:
* Custom oauth plugin https://meta.discourse.org/t/login-to-discourse-with-custom-oauth2-provider/14717/3
* Custom oauth plugin https://meta.discourse.org/t/login-to-discourse-with-custom-oauth2-provider/14717/3
* Fully custom auth plugin https://meta.discourse.org/t/vk-com-login-vkontakte/12987
* Fully custom auth plugin https://meta.discourse.org/t/vk-com-login-vkontakte/12987
==> Should just need https://gitlab.com/blender-institute/discourse-blender-id/-/tree/master with the branding s/Blender ID/MyKDE


== Data Import ==
== Data Import ==
Line 71: Line 78:
end-users to work with.
end-users to work with.
</blockquote>
</blockquote>
One would presume the structure could be very/entirely similar to what we have currently.  Discourse offers a fairly similar view, scalable to many different subforums (e.g. https://discourse.ubuntu.com/). It may be wise to also revisit the overall structure and possibly merge some forums though.


== Anti-Spam ==
== Anti-Spam ==
Line 85: Line 94:
* There is also built-in monitoring which allows admins to view a list of "suspicious" users by applying a bunch of metrics to determine if a  (new) user may be a spammer (/admin/users/list/suspect)
* There is also built-in monitoring which allows admins to view a list of "suspicious" users by applying a bunch of metrics to determine if a  (new) user may be a spammer (/admin/users/list/suspect)
* Discourse also has built-in screening capabilities where apparently all sorts of stuff can be used to block or mark posts for review. This at least includes originator IP (ranges), email addresses patterns and URL patterns.
* Discourse also has built-in screening capabilities where apparently all sorts of stuff can be used to block or mark posts for review. This at least includes originator IP (ranges), email addresses patterns and URL patterns.
* easy nuking of users and their posts; looks like this: https://meta.discourse.org/t/new-user-deleted-for-spam-posts/53647/2
*  Akismet https://www.discourse.org/plugins/akismet.html probably no bueno because akismet is a paid service and sends data off a third party service which may be problematic WRT our privacy policy
*  Akismet https://www.discourse.org/plugins/akismet.html probably no bueno because akismet is a paid service and sends data off a third party service which may be problematic WRT our privacy policy


= TODO =
= TODO =


* Figure out how our current forums' spam protection works.
* Figure out how our current forums' spam protection works. [sitter: the spam todo we can probably tick off. from what I've seen on the demo instance the protection capabilities should be about en-par with what we have on the phpbb side, in fact probably better because of the entire trust system limiting what new accounts can do]
* Talk to upstream about their awareness of docker security responsibility and the specific issues Ben highlighted on the mailing list.
* Talk to upstream about their awareness of docker security responsibility and the specific issues Ben highlighted on the mailing list.
* Get some test setup and figure out how to structure stuff (as in: how to mimic subforums etc)
* Get some test setup and figure out how to structure stuff (as in: how to mimic subforums etc)
* Look into how the various subforums utilize phpbb and if that still works with discourse
* Look into how the various subforums utilize phpbb and if that still works with discourse
* Figure out what to do about the custom mods we have on phpbb (generally we'd want to get rid of as much as possible to increase maintainability etc?)
* Figure out what to do about the custom mods we have on phpbb (generally we'd want to get rid of as much as possible to increase maintainability etc?) ( Krita customisations to preview first image post https://forum.kde.org/viewforum.php?f=275 )
* Do we also migrate mailing lists to discourse?  separate developers and end user categories
* Do we migrate mailing lists to the same discourse instance or separate user forums from developer forums by using separate instances?
* For mailing lists it's common to already have a list of e-mails of people to add in.  Can we add in e-mails into a Category in Discourse or does each user need to faff around adding themselves? invite method?
* Account integration with identity.kde.org? https://www.discourse.org/plugins/oauth.html
* Can it support multiple domains for incoming e-mails?
* Can we import threads from forum.kde.org phpBB ? https://meta.discourse.org/t/importing-from-phpbb3/30810
* For a forum with an incoming e-mail address how does a user find out what that address is?
* What are the tools to remove identifying info for users who request it?
* Command line tool to approve or not posts?
* IRC/Matrix announce bot (Persuvant for commit notification etc works fine)
* Guided Posting - equivalent to custom phpbb tool to guide users to correct forum to post in
* Can you have sub-forums with labels how Krita and others to on forums?
* Find projects to test moving to it e.g. kmymoney or gcompris or kde neon
* Possiblity to not deploy on Docker?

Latest revision as of 19:33, 30 September 2020

Discourse

Ongoing evaluation of Discourse for Forums / Mailing List needs.

https://www.discourse.org

Old proposal thread: https://markmail.org/thread/rnmyc5upbxdqoug5

Trial

http://discuss.kde.org.uk Give it a shot. Testbed server from June 2019. Set up by Jonathan.

Pile of Requirements/Desires

  • Easy and quick to use spamer nuke feature
  • Mark threads as solved
  • Forum banner / Newsbar banner
  • Guided posting wizard
  • Profile Icons to show OS/Distribution
  • Brainstorm (post voting)
  • Identity Integration (auth)
  • Scalable search for amount of posts we have
  • Tagcloud
  • Gallery (for krita; unclear of what is exactly required here)
  • Retain all data from current forum

Stack Eval

Look into the actual technology stack they use (seems to be Rails based in this case) to make sure there aren't any potential snags there

Ben took a quick look: My main one [concern] here is the lack of any options for installation other than Docker which makes no sense for a Rails application. Looking into their Docker image installation script I see that they build both Nginx and Imagemagick themselves (and stepping outside of package repositories is generally a bad idea). Imagemagick is of grave concern as this project has had numerous security advisories in the past and I see the version they're using isn't the latest one. I have further concerns for Nginx as they include a third party compression module, Brotli, whose codebase hasn't been touched in 2 years (plus it's a compression method, so you have the risk of CRIME/BREACH attacks).

Auth Options

Evaluate what support it has for authentication options (Identity requires LDAP at the moment, but will move to OAuth2 at some point using a custom API)

==> Should just need https://gitlab.com/blender-institute/discourse-blender-id/-/tree/master with the branding s/Blender ID/MyKDE

Data Import

Determine what's needed to import existing data we have

We have phpbb 3.0 which is supported to migrate from. There may be problems with custom mods adding custom stuff to the database (notably the OS/distro icon would not be migrated obviously). It may be good to actually have a schema to look at. Also, hard to tell how well this will work in practice without giving it a try with an actual db dump from the production phpbb forum.

Guide

Structure

Ascertain how best to structure things to make it easy for end-users to work with.

One would presume the structure could be very/entirely similar to what we have currently. Discourse offers a fairly similar view, scalable to many different subforums (e.g. https://discourse.ubuntu.com/). It may be wise to also revisit the overall structure and possibly merge some forums though.

Anti-Spam

Investigate what anti-spam options are available and how maintainable any customisations we need to support KDE specific workflows will be

TODO

  • Figure out how our current forums' spam protection works. [sitter: the spam todo we can probably tick off. from what I've seen on the demo instance the protection capabilities should be about en-par with what we have on the phpbb side, in fact probably better because of the entire trust system limiting what new accounts can do]
  • Talk to upstream about their awareness of docker security responsibility and the specific issues Ben highlighted on the mailing list.
  • Get some test setup and figure out how to structure stuff (as in: how to mimic subforums etc)
  • Look into how the various subforums utilize phpbb and if that still works with discourse
  • Figure out what to do about the custom mods we have on phpbb (generally we'd want to get rid of as much as possible to increase maintainability etc?) ( Krita customisations to preview first image post https://forum.kde.org/viewforum.php?f=275 )
  • Do we also migrate mailing lists to discourse? separate developers and end user categories
  • Do we migrate mailing lists to the same discourse instance or separate user forums from developer forums by using separate instances?
  • For mailing lists it's common to already have a list of e-mails of people to add in. Can we add in e-mails into a Category in Discourse or does each user need to faff around adding themselves? invite method?
  • Account integration with identity.kde.org? https://www.discourse.org/plugins/oauth.html
  • Can it support multiple domains for incoming e-mails?
  • Can we import threads from forum.kde.org phpBB ? https://meta.discourse.org/t/importing-from-phpbb3/30810
  • For a forum with an incoming e-mail address how does a user find out what that address is?
  • What are the tools to remove identifying info for users who request it?
  • Command line tool to approve or not posts?
  • IRC/Matrix announce bot (Persuvant for commit notification etc works fine)
  • Guided Posting - equivalent to custom phpbb tool to guide users to correct forum to post in
  • Can you have sub-forums with labels how Krita and others to on forums?
  • Find projects to test moving to it e.g. kmymoney or gcompris or kde neon
  • Possiblity to not deploy on Docker?