Plugin Strumenti Legali

Repository: GitHub - paviliondev/discourse-legal-tools: Tools to help with legal compliance when using Discourse · GitHub

Questo plugin fornisce strumenti per assistere nella conformità legale durante l’esecuzione di un forum Discourse. Gli strumenti verranno aggiunti in modo continuativo.

Si prega di prendere nota del disclaimer riportato di seguito. Questo plugin non offre alcuna garanzia di conformità legale.

Download Utente Esteso

Il download utente esteso è un singolo file CSV con le seguenti voci, ciascuna separata da due righe vuote:

  • Un’intestazione (modificabile: Personalizza > Contenuto di testo > “csv_export.extended.title”):

    Tutte le informazioni di %{username} archiviate da %{site_name}

    • “username” è il nome utente dell’utente di cui sono presenti le informazioni nel download.
    • “site_name” è l’impostazione del sito title.
  • Una nota sotto l’intestazione (modificabile: Personalizza > Contenuto di testo > “csv_export.extended.note”):

    Si prega di notare che alcune informazioni associate all’identificativo utente di %{username}
    sono state escluse da questo download a causa di interessi contrastanti in materia di privacy e legali.
    Per ulteriori informazioni, contattare %{site_contact}.

    • “username” è il nome utente dell’utente di cui sono presenti le informazioni nel download.
    • “site_contact” è l’impostazione del sito contact email.
  • Post. Le informazioni predefinite incluse nel download utente.

  • Account. Informazioni sull’account e sul profilo.

  • Account Esterni. Informazioni da account esterni (se presenti).

  • Statistiche. Informazioni statistiche archiviate riguardanti l’utente.

  • Accessi e Cronologia Accessi. Informazioni sugli accessi dell’utente.

  • Ricerche. Tutti i record con indirizzo IP registrato delle ricerche effettuate dall’utente.

  • Visualizzazioni Argomenti. Tutte le visualizzazioni di argomenti con indirizzo IP registrato effettuate dall’utente.

  • Clic sui Link degli Argomenti. Tutti i link agli argomenti con indirizzo IP registrato cliccati dall’utente.

  • Visualizzazioni Profilo. Tutte le visualizzazioni del profilo con indirizzo IP registrato effettuate dall’utente.

  • Azioni. Tutte le azioni intraprese dall’utente.

  • Cronologia. Tutti i record con indirizzo IP registrato delle azioni registrabili che coinvolgono l’utente.

Esistono due impostazioni del sito che abilitano il download esteso:

  • legal extended user download: Se abilitata, la funzione “Scarica tutto” nella pagina Attività Utente diventa un download esteso.

    • Si prega di notare che, come per il download utente normale, il download utente esteso può essere eseguito da un utente una sola volta al giorno.
  • legal extended user download admin. Se abilitata, il personale autorizzato può scaricare tutte le informazioni di qualsiasi utente del sito. Verrà visualizzato un nuovo pulsante “Scarica tutto” nella parte superiore delle informazioni utente dell’amministratore per ogni utente.

    Screenshot%20at%20May%2026%2014-55-03

    Opzioni:

    • Disabilitato (predefinito)
    • Solo Amministratori (solo gli amministratori possono utilizzare la funzione di download esteso per gli amministratori)
    • Amministratori e Personale (sia amministratori che personale possono utilizzare la funzione di download esteso per gli amministratori)

Le due impostazioni sono separabili, ovvero è possibile abilitare legal extended user download senza concedere ad amministratori o personale la possibilità di scaricare tutte le informazioni di ogni utente, oppure è possibile abilitare legal extended user download admin senza concedere agli utenti la possibilità di scaricare tutte le proprie informazioni.

Il contesto di questa funzione è il GDPR dell’UE. Si veda in particolare:

Si prega di notare che è necessario valutare le implicazioni di sicurezza derivanti dal consentire a utenti, personale e/o amministratori la possibilità di scaricare tutte le informazioni elencate. Questa funzione potrebbe non essere adatta in tutte le circostanze. Ulteriori informazioni su questo problema sono disponibili negli argomenti sopra citati.

Un’alternativa al download diretto delle informazioni dell’utente è che un membro del personale competente (un “Responsabile della Protezione dei Dati”) compili le informazioni tramite query al database.

Disclaimer

Il plugin Legal Tools (il “Plugin”) e il suo autore Angus McLeod (l’“Autore”) non sono avvocati né sostituti di un avvocato o di consulenza legale. Le comunicazioni tra voi e l’Autore non sono protette dal privilegio avvocato-cliente né come lavoro professionale. Il Plugin e il suo Autore non possono fornire alcun tipo di consiglio, spiegazione, parere, raccomandazione o garanzia riguardo a possibili diritti legali, rimedi, difese, opzioni, selezione di moduli o strategie.

62 Mi Piace

@codinghorror how much of this do you think belongs in core? Should we just amend our default “download all my data” to include all this stuff?

9 Mi Piace

No, we need @riking to come through with the removal of IP where it’s unnecessarily recorded and should not be first. If that can’t be achieved in a reasonable timeframe we need to get someone else to do it.

5 Mi Piace

Update here.

Scope of the download

All user-related records in user activity (record of likes, bookmarks, topics, replies etc) have been added to the download (commit).

I initially didn’t add this as it seemed like overkill. However @RGJ raised it with me and we had a productive exchange on the question.

Essentially, we decided that the best approach for the purposes of this feature was to include all records of activity tied to the user’s identifier that don’t entail countervailing concerns about the privacy of others or similar rights.

I would emphasise “for the purposes of this feature”, as the purpose of this feature is to take a ‘maximalist’ approach to possible interpretations of the GDPR. It does not attempt to parse ‘likely’ approaches. I’ve laid out some of my own views on the ‘likely’ approaches in this topic (which remain unchanged).

The specifics of the reasoning behind this ‘maximalist’ approach are:

  • The broadest interpretation of A.4.1 (the definition of ‘Personal Data’ in the GDPR) as it applies to Discourse is any record in the db that contains the user’s user_id, i.e.:

    any information … identified or identifiable natural person … identified, directly or indirectly, in particular by reference to … an identification number

  • Read literally, this definition doesn’t care about how the data is produced (e.g. whether the user is acting or not). It merely requires the data to be related to the user’s identifier in some way.

  • However, applying that literally would produce a fair amount of duplication (e.g. the records in the directory_items table are duplicative of various other entries).

  • The point of the extended download is to guard against even the small risk that Article 4.1 could receive a very broad interpretation by some authority or court in Europe.

  • The factors against including it - size of download, potentially security (?) - do not outweigh the possible benefit of including it.

We also considered whether to include ‘administrative’ records with the user’s user_id such as flags, complaints and staff whispers. We decided against this, reasoning as follows:

  • They’re already in the territory of information associated with the user purely by their identifier. They are not information about the user per se (i.e. name, email, age, location etc). This is already assuming a wide interpretation of A.4.1.

  • Whether administrative records intrude on the privacy of other parties, or other relevant concerns (i.e. R. 63.5 & A.15.4) must be determined on a case-by-case basis.

  • Other parties, such as Facebook, do no include such data in their user download functionality.

12 Mi Piace

Hey Angus,

I’m having some trouble getting this to work. I’ve enabled the ‘legal extended user download’ setting, refreshed the page and clicked the ‘Download all’ button on the activity page. This results in an archive that contains one CSV file with topics in it. I checked both as an admin and as a regular user. What is the expected output - multiple CSV files, each for a different table?

The expected output is a single csv with headers for each item mentioned in the first post in this topic. If you try it out on my sandbox, this is what you’ll get.

Do you see any errors at /sidekiq?

@RGJ have you had this issue?

Nope. We had a few users with the same kind of complaint though but it turned out to be a false alarm.
I guess they never scrolled down past the posts. Maybe it’s an idea to move the posts section (i.e. the most unstructured / multiline content) to be the last section.

1 Mi Piace

Could you provide a few of the header rows as an example so I can do a search for them?

See the ‘separator’ lines here.

Thanks Richard. Definitely not seeing those. So just to be sure I’m doing the right thing: this plugin is supposed to replace the ‘Download’ button in the Profile > Activity sidebar, right?

First words of admiration go to @angus :clap: :heart: :+1: for doing such a great job helping everyone here to get those highly useful tools (not only this plugin but other plugins too).

I’ve got one question though: wouldn’t it be better to have this export available to admins only (at least as option for those concerned)?
Isn’t it potentially risky in case when given account password is compromised and then ‘all activity’ is easily downloaded by unauthorized person? (Sorry that is two questions :slight_smile: )

3 Mi Piace

I just did a few more tests and tried it on your sandbox too. My results are just the default download - they don’t match your new format. I don’t think I see any errors in sidekiq (at least not in ‘Failed’ - ‘Errors’ is not clickable). Any suggestions how I can best find more information here?

Please post (or PM) a screenshot of the csv you got from my sandbox with the ip addresses blacked out (if any).

I think I’ll make this a setting.

Potentially. This is partly what I meant by

Nevertheless, some people will need / want the functionality of allowing users to directly download their info. So I think a setting is the move here.

1 Mi Piace

There are now two site settings that enable the extended download:

  • legal extended user download: When enabled, the “Download All” feature in the User Activity page becomes an extended download.

    • Please note that, like the normal user download, the extended user download can only be performed by a user once a day.
  • legal extended user download admin. When enabled, permitted staff can download all the information of any user of the site. They will see an new “Download All” button at the top of the the admin user information of each user.

    Screenshot%20at%20May%2026%2014-55-03

    Options:

    • Disabled (default)
    • Admins Only (only admins can use the admin extended download feature)
    • Admins and Staff (both admins and staff can use the admin extended download feature)

The two settings are severable, i.e. you can enable legal extended user download without giving admins or staff the ability to download all the information of every user, or you can enable legal extended user download admin without giving users the ability to download all of their information.

Due to the security implications of allowing users (even if they’re admins) to download all the information of other users, I’ve been particularly careful with protecting the admin extended user download server methods, however I would appreciate a second set of eyes on that aspect of the changes, particularly considering this feature seems to be quite popular. Perhaps you could take a look @riking if you have the time? (i.e. particularly the changes to the Guardian).

I’ve also added text to the top of the extended csv:

  • A header (can be edited: Customize > Text Content > “csv_export.extended.title”):

    All information of %{username} stored by %{site_name}

    • “username” is the username of the user who’s information is in the download.
    • “site_name” is the title site setting.
  • A note below the header (can be edited: Customize > Text Content > “csv_export.extended.note”):

    Please note that some information associated with the user identifier of %{username}
    has been excluded from this download due to countervailing privacy and legal interests.
    For more information, please contact %{site_contact}.

    • “username” is the username of the user who’s information is in the download.
    • “site_contact” is the contact email site setting.

This has all been tested on my sandbox where it is currently live.

@bartv Let me know if these updates fix your issue.

8 Mi Piace

This new version solves the issue I had before. Thanks for all your hard work on this, Angus!

The extended note is interesting; could you shed some light on which information has been excluded and for which reasons?

3 Mi Piace

That is primarily referring to the exclusion mentioned below, and also helps if we’ve not included something some authority happens to consider relevant.

4 Mi Piace

6 post sono stati spostati in un nuovo argomento: Esportazione dei dati utente non riuscita (transazione annullata)

Come amministratore ho appena provato a esportare i dati di un utente (una richiesta GDPR) cliccando sul pulsante giusto (scarica tutto), ma ho ricevuto un messaggio dal sistema che l’esportazione dei dati non è riuscita e che dovrei controllare i log.

Non riesco a capire se questo sia ora un problema all’interno del plugin o un problema dello stesso Discourse.
Aggiornamento 11 gennaio 17.40 UTC: Il team di Discourse ha appena detto che, guardando il backtrace, si tratta di un problema in un plugin di terze parti. @angus, puoi per favore dare un’occhiata a questo, grazie.

L’istanza di Discourse è in esecuzione su 2.7.0.beta1 ( 4f72830eb0 )
Aggiornamento 11 gennaio 16:15 UTC: ora sulla versione 2.7.0.beta1( 422f395042 ) ma l’errore rimane lo stesso.

Questo è ciò che è configurato all’interno del plugin:

Nei log vedo il seguente errore:
Eccezione del job: metodo non definito `collect’ per nil:NilClass

/usr/local/lib/ruby/2.7.0/csv/writer.rb:46:in `<<'
/usr/local/lib/ruby/2.7.0/csv.rb:1230:in `<<'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:66:in `block (3 levels) in execute'
/var/www/discourse/plugins/discourse-legal-tools/lib/export_csv_file_extension.rb:267:in `user_archive_export_extended'
/var/www/discourse/plugins/discourse-legal-tools/lib/export_csv_file_extension.rb:226:in `admin_user_archive_export'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:66:in `each'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:66:in `block (2 levels) in execute'
/usr/local/lib/ruby/2.7.0/csv.rb:658:in `open'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:64:in `block in execute'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:63:in `each'
/var/www/discourse/app/jobs/regular/export_csv_file.rb:63:in `execute'
/var/www/discourse/app/jobs/base.rb:232:in `block (2 levels) in perform'
rails_multisite-2.5.0/lib/rails_multisite/connection_management.rb:76:in `with_connection'
/var/www/discourse/app/jobs/base.rb:221:in `block in perform'
/var/www/discourse/app/jobs/base.rb:217:in `each'
/var/www/discourse/app/jobs/base.rb:217:in `perform'
sidekiq-6.1.2/lib/sidekiq/processor.rb:196:in `execute_job'
sidekiq-6.1.2/lib/sidekiq/processor.rb:164:in `block (2 levels) in process'
sidekiq-6.1.2/lib/sidekiq/middleware/chain.rb:138:in `block in invoke'
/var/www/discourse/lib/sidekiq/pausable.rb:138:in `call'
sidekiq-6.1.2/lib/sidekiq/middleware/chain.rb:140:in `block in invoke'
sidekiq-6.1.2/lib/sidekiq/middleware/chain.rb:143:in `invoke'
sidekiq-6.1.2/lib/sidekiq/processor.rb:163:in `block in process'
sidekiq-6.1.2/lib/sidekiq/processor.rb:136:in `block (6 levels) in dispatch'
sidekiq-6.1.2/lib/sidekiq/job_retry.rb:111:in `local'
sidekiq-6.1.2/lib/sidekiq/processor.rb:135:in `block (5 levels) in dispatch'
sidekiq-6.1.2/lib/sidekiq.rb:38:in `block in <module:Sidekiq>'
sidekiq-6.1.2/lib/sidekiq/processor.rb:131:in `block (4 levels) in dispatch'
sidekiq-6.1.2/lib/sidekiq/processor.rb:257:in `stats'
sidekiq-6.1.2/lib/sidekiq/processor.rb:126:in `block (3 levels) in dispatch'
sidekiq-6.1.2/lib/sidekiq/job_logger.rb:13:in `call'
sidekiq-6.1.2/lib/sidekiq/processor.rb:125:in `block (2 levels) in dispatch'
sidekiq-6.1.2/lib/sidekiq/job_retry.rb:78:in `global'
sidekiq-6.1.2/lib/sidekiq/processor.rb:124:in `block in dispatch'
sidekiq-6.1.2/lib/sidekiq/logger.rb:10:in `with'
sidekiq-6.1.2/lib/sidekiq/job_logger.rb:33:in `prepare'
sidekiq-6.1.2/lib/sidekiq/processor.rb:123:in `dispatch'
sidekiq-6.1.2/lib/sidekiq/processor.rb:162:in `process'
sidekiq-6.1.2/lib/sidekiq/processor.rb:78:in `process_one'
sidekiq-6.1.2/lib/sidekiq/processor.rb:68:in `run'
sidekiq-6.1.2/lib/sidekiq/util.rb:15:in `watchdog'
sidekiq-6.1.2/lib/sidekiq/util.rb:24:in `block in safe_thread'
1 Mi Piace

Scusa per la risposta tardiva qui, sono stato via :beach_umbrella:

Ho riprodotto il problema e l’ho risolto. Aggiorna e riprova il download. Se possibile, fammi sapere come va la richiesta.

6 Mi Piace

Nessun problema, era un weekend e nessuno è tenuto a rispondere subito.
Sono grato per questo plugin.

Ho aggiornato e riprovato.
Ha funzionato perfettamente, grazie mille per la correzione, apprezzo davvero il tuo ottimo lavoro.

Se volessi includere anche record “amministrativi” con l’user_id dell’utente, come flag, reclami e messaggi riservati allo staff, quali sarebbero le migliori istruzioni SQL per ottenere i dati con l’explorer dei dati?
Se necessario, potrei fornire questi dati separatamente all’utente che ha richiesto i dati.

3 Mi Piace