Uno script sh per settare i permessi di file e cartelle di wordpress

Lo script segue le pratiche consigliate per i permessi di WordPress:

  • File: Permessi a 644 (lettura/scrittura per il proprietario, lettura per altri).
  • Directory: Permessi a 755 (lettura/esecuzione per tutti, scrittura solo per il proprietario).
  • File sensibili: Come wp-config.php, impostati a 600 (solo il proprietario può leggere/scrivere).
  • Utente/Group: Facoltativamente, puoi assegnare un utente o un gruppo specifico.

#!/bin/bash

# Configura il percorso root di WordPress
WP_ROOT="/percorso/al/tuo/sito" # Cambia con il percorso corretto

# Configura il proprietario (user e group) - modifica se necessario
USER="www-data" # Utente web server (es: www-data, apache, nginx)
GROUP="www-data" # Gruppo web server

# Controlla se eseguito come root
if [ "$EUID" -ne 0 ]; then
echo "Per favore esegui lo script come root o con sudo."
exit 1
fi

echo "Impostazione dei permessi per il sito WordPress nella directory: $WP_ROOT"

# Imposta il proprietario per tutti i file e directory
echo "Imposto il proprietario a $USER:$GROUP..."
chown -R $USER:$GROUP "$WP_ROOT"

# Imposta i permessi per le directory
echo "Imposto i permessi delle directory a 755..."
find "$WP_ROOT" -type d -exec chmod 755 {} \;

# Imposta i permessi per i file
echo "Imposto i permessi dei file a 644..."
find "$WP_ROOT" -type f -exec chmod 644 {} \;

# Imposta i permessi sicuri per wp-config.php
if [ -f "$WP_ROOT/wp-config.php" ]; then
echo "Imposto permessi sicuri per wp-config.php (600)..."
chmod 600 "$WP_ROOT/wp-config.php"
fi

# Permessi speciali per wp-content/uploads (scrivibili dal server)
UPLOADS_DIR="$WP_ROOT/wp-content/uploads"
if [ -d "$UPLOADS_DIR" ]; then
echo "Imposto permessi per la directory uploads (775)..."
chmod -R 775 "$UPLOADS_DIR"
echo "Rendo uploads scrivibile da utente e gruppo..."
chown -R $USER:$GROUP "$UPLOADS_DIR"
fi

echo "Permessi impostati correttamente per WordPress!"

# Finitura
exit 0

Come usare lo script:

  1. Crea lo script:
    • Salva il codice in un file chiamato, ad esempio, set-wordpress-permissions.sh.
  2. Modifica le variabili:
    • Cambia WP_ROOT con il percorso della root del tuo sito WordPress.
    • Cambia USER e GROUP con l’utente e il gruppo utilizzati dal server web (es. www-data per Apache/Nginx su Ubuntu).
  3. Rendi lo script eseguibile:
    chmod +x set-wordpress-permissions.sh
  4. Esegui lo script con privilegi di amministratore:
    sudo ./set-wordpress-permissions.sh
  5. Verifica i permessi:
    Puoi controllare che i permessi siano stati applicati correttamente con
    ls -l /percorso/al/tuo/sito

Spiegazione dei permessi:

  • 644 (file): Lettura/scrittura per il proprietario, lettura per il gruppo e altri.
  • 755 (directory): Lettura/esecuzione per tutti, scrittura per il proprietario.
  • 600 (wp-config.php): Lettura/scrittura solo per il proprietario.
  • 775 (uploads): Lettura/scrittura per proprietario e gruppo, lettura per altri.

Nota:

  • Lo script si assume che il server web (Apache/Nginx) utilizzi l’utente/gruppo specificato (www-data).
  • Se stai utilizzando configurazioni diverse, assicurati di modificare di conseguenza i permessi o il proprietario.
  • Avrai bisogno di un’utenza con abbastanza privilegi per eseguire il file sh sulla macchina dove gira il tuo wordpress.

Come faccio a eliminare massivamente gli utenti di wordpress che hanno una certa email?

Questo script SH viene in nostro soccorso:

#!/bin/bash

# usalo per RIMUOVERE UTENTI CON UNA CERTA EMAIL @dominio-da-eliminare.com

# Trova gli utenti con email che contengono "@dominio-da-eliminare.com" e cancella ciascuno di essi
wp user list --field=ID,user_email --allow-root | while read -r line; do
user_id=$(echo "$line" | awk '{print $1}')
user_email=$(echo "$line" | awk '{print $2}')

# Controlla se l'email contiene "@dominio-da-eliminare.com"
if [[ "$user_email" == *"@dominio-da-eliminare.com"* ]]; then
echo "Eliminazione utente con ID: $user_id e email: $user_email"
# Elimina l'utente senza chiedere conferma
wp user delete "$user_id" --yes --allow-root
fi
done

Teniamo presente che lo script si può personalizzare per ottenere un elenco di utenti corrispondente ad altre caratteristiche, che possono provenire anche da comandi cli personalizzati.

Inoltre, per coloro che hanno una bella banca dati e che vogliono lasciare il processo attivo, senza necessità di stare collegato contestualmente via console (ssh), che il comando può essere lanciato con screen.

Spiegazione dello script

  1. Elenco ID degli utenti: il comando wp user list --field=ID --allow-root restituisce una lista di ID di tutti gli utenti.
  2. Ciclo sugli ID degli utenti: usa while read -r user_id per iterare su ciascun ID utente.
  3. Controllo dell’email: per ogni utente, il comando wp user get "$user_id" --field=user_email --allow-root recupera l’email dell’utente. Successivamente, viene eseguito un controllo per verificare se l’email contiene la stringa "@pippo.".
  4. Eliminazione dell’utente: se l’email contiene “@pippo.”, l’utente viene eliminato con wp user delete "$user_id" --reassign=0 --allow-root. L’opzione --reassign=0 assicura che i contenuti creati da questi utenti siano assegnati all’utente con ID 0 (tipicamente “Admin”).

ATTENZIONE

  • Back up: Assicurati di effettuare un backup del database prima di eseguire questo script, per evitare di perdere dati accidentalmente.
  • Log delle eliminazioni: L’output del comando echo ti aiuterà a monitorare quali utenti vengono eliminati.
  • Lo script utilizza la WP-CLI.

Spero di essere stato utile.

How to use HTML signature on Evolution email client

That’s an easy one, once you understand how it works.

I was struggling with this same issue (two years later).
But, no worries, I am on Ubuntu 22 and after some try I was able to use a pure HTML signature on Evolution.

How signatures work in Evolution email client

First of all, signatures are not dependent to account, meaning that you can have N signatures and 0 accounts on Evolution.

On the other hand, you can select one of your signatures during message composition or assign a specific (default) signature (among the available ones) to a specific account.

So to manipulate signatures go to “Edit” -> “Preferences” and than should be available something like “Composition preferences” (mine software is in Italian), where you can find the signatures to manipulate.

To assign a specific signature to a specific account as default behavior, you can go on “Edit” -> “Account” and than chose to edit the proper email account.

Keep in mind that external (remote) images are not visible, so to ensure everything is done good you must send a test email.

Hope this helps.