Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati
  • Differenze per "Sicurezza/AppArmor"
Differenze tra le versioni 13 e 14
Versione 13 del 23/10/2007 11.31.31
Dimensione: 8445
Commento:
Versione 14 del 12/03/2008 21.58.27
Dimensione: 8542
Commento: sistemata
Le cancellazioni sono segnalate in questo modo. Le aggiunte sono segnalate in questo modo.
Linea 4: Linea 4:
||<tablestyle="float:right; font-size: 0.9em; width:40%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;">'''Indice'''[[BR]][[TableOfContents(2)]]||

= Nota =
La traduzione di questo documento non è ancora completa. Consultare la sezione ''Ulteriori risorse'' per collegamento al documento originale.

L'ultima modifica dell'originale è del 2007-10-16 01:07:34, fatta da MathiasGug
||<tablestyle="float:right; font-size: 0.9em; width:35%; background:#F1F1ED; margin: 0 0 1em 1em;" style="padding:0.5em;">'''Indice'''[[BR]][[TableOfContents(2)]]||
Linea 12: Linea 7:
App``Armor è una implementazione Linux Security Module di controlli d'accesso basato sul nome. App``Armor confina i singoli programmi a un gruppo di file elencati e "draft capabilities posix 1003.1e"
''-- se non ci capite nulla, beh, non siete i soli --Luca''


App``Armor è stato reso disponibile su Ubuntu per la prima volta in Ubuntu 7.04 nel repository Universe.
'''App``Armor''' è una implementazione del '''Linux Security Module''' di controlli d'accesso basati sul nome. App``Armor confina i singoli programmi a un gruppo di file selezionati e capacità POSIX 1003.1e draft.

'''App``Armor''' è stato reso disponibile su Ubuntu per la prima volta in Ubuntu 7.04 nel [:Repository:repository] '''universe'''.
Linea 20: Linea 14:
In Gutsy, App``Armor è installato e caricato in modo predefinito. Alcuni pacchetti installano dei profili propri. Profili aggiuntivi possono essere trovati nel pacchetto ''apparmor-profiles'' nel repository Universe. In Ubuntu 7.10, '''App``Armor''' è installato e caricato in modo predefinito. Alcuni pacchetti installano dei profili propri, ma profili aggiuntivi possono essere trovati nel pacchetto ''apparmor-profiles'' nel repository universe.
Linea 23: Linea 17:
 * Abilitare il repository Universe.  * Abilitare il [:Repository:repository] '''universe'''.
Linea 27: Linea 21:
App``Armor non è incluso in modo predefinito nel kernel fornito con Feisty. È necessario compilarlo manualmente.

 * Abilitare il repository Universe.
 * [:AmministrazioneSistema/InstallareProgrammi:Installare] i pacchetto ''apparmor-modules-sources'' e ''module-assistant''.
 * Compilare il modulo kernel apparmor:
{{{sudo m-a -v -t prepare
App``Armor non è incluso in modo predefinito nel kernel fornito con Ubuntu 7.04. È necessario compilarlo manualmente.

 * Abilitare il [:Repository:repository] '''universe'''.
 * [:AmministrazioneSistema/InstallareProgrammi:Installare] i pacchetti ''apparmor-modules-sources'' e ''module-assistant''.
 * Compilare il modulo kernel apparmor: {{{
sudo m-a -v -t prepare
Linea 36: Linea 30:
 * [:AmministrazioneSistema/InstallareProgrammi:Installare] i pacchetti ''apparmor-profiles'', ''apparmor-utils'' e ''apparmor packages''.  * [:AmministrazioneSistema/InstallareProgrammi:Installare] i pacchetti ''apparmor-profiles'', ''apparmor-utils'' e ''apparmor''.
Linea 39: Linea 33:
Per installare i pacchetti apparmor per Feisty più recenti, è necessario effettuare il rebuild dei pacchetti. Consultare [https://bugs.launchpad.net/ubuntu/+source/apparmor/+bug/116627 le ultime utilità apparmor per feisty (LP 116627) Per installare i pacchetti di '''App``Armor''' più recenti per Ubuntu 7.04, è necessario rigenerare i pacchetti. Per maggiori informazioni, consultare il [https://bugs.launchpad.net/ubuntu/+source/apparmor/+bug/116627 bug #116627] su Launchpad.
Linea 42: Linea 36:
Quando viene installato un nuovo kernel o una nuova versione di ''apparmor-module-source'', è necessario ricompilare il modulo apparmor:
{{{sudo m-a -v -t -f build apparmor-modules
Quando viene installato un nuovo kernel o una nuova versione di ''apparmor-module-source'', è necessario ricompilare il modulo ''apparmor'': {{{
sudo m-a -v -t -f build apparmor-modules
Linea 48: Linea 42:
= Utilizzo = = Uso =
Linea 51: Linea 45:
== Elencare lo stato corrente di apparmor == == Elencare lo stato corrente di AppArmor ==
Linea 60: Linea 54:
Esempio:
{{{
Esempio: {{{
Linea 65: Linea 58:
'''''NdT''': nella modalità apprendimento (in originale complain) vengono rilevate le violazioni alle regole dei profili di App``Armor (ad esempio il programma profilato accede a file non permessi dal profilo). Tali violazioni sono permesse, ma anche registrate. Questa modalità è conveniente per lo sviluppo di profili ed è usata dagli strumenti di App``Armor per la generazione dei profili. (dalla documentazione su novell.com)'' ||<tablestyle="text-align: justify; width:100%; " style="border:none;" 5%>[[Immagine(Icone/Piccole/note.png,,center)]] ||<style="padding:0.5em; border:none;">''Nella modalità apprendimento (in originale complain) vengono rilevate le violazioni alle regole dei profili di App``Armor (per esempio il programma profilato accede a file non permessi dal profilo). Tali violazioni sono permesse, ma anche registrate. Questa modalità è conveniente per lo sviluppo di profili ed è usata dagli strumenti di App``Armor per la generazione dei profili (dalla documentazione su novell.com).'' ||
Linea 76: Linea 69:
Esempio:
{{{
Esempio: {{{
Linea 81: Linea 73:
'''''NdT:''' il caricamento di un profilo nella modalità di esecuzione (enforcment) fa sì che sia rispettata la politica definita nel profilo e allo stesso tempo segnalata a syslogd ogni tentata violazione. (dalla documentazione su novell.com) ||<tablestyle="text-align: justify; width:100%; " style="border:none;" 5%>[[Immagine(Icone/Piccole/note.png,,center)]] ||<style="padding:0.5em; border:none;">''Il caricamento di un profilo nella modalità di esecuzione (enforcment) fa sì che sia rispettata la politica definita nel profilo e allo stesso tempo segnalata a syslogd ogni tentata violazione (dalla documentazione su novell.com).''||
Linea 109: Linea 101:
Esempio:
{{{
Esempio: {{{
Linea 131: Linea 122:
Esempio:
{{{
Esempio: {{{
Linea 137: Linea 127:
= Pesonalizzazione dei profili =
I profili possono essere trovati in {{{/etc/apparmor.d/}}}.

Alcune personalizzazioni possono essere compiute in {{{/etc/apparmor.d/tunables/}}}.
= Personalizzazione dei profili =
I profili possono essere trovati in `/etc/apparmor.d/`.

Alcune personalizzazioni possono essere compiute in `/etc/apparmor.d/tunables/`.
Linea 143: Linea 133:
La posizione delle directory home può essere regolata in {{{/etc/apparmor.d/tunables/home}}}. La posizione delle directory home può essere regolata in `/etc/apparmor.d/tunables/home`.
Linea 150: Linea 140:
App``Armor può tenere traccia e proteggere solo i processi che sono avviato dopo che il modulo kernel è stato caricato. Dopo l'installazione dei pacchetti apparmor, apparmor viene avviato. I processi già in esecuzione però non vengono protetti da App``Armor. Sia riavviare il processo che l'intero sistema corregge il problema.

È anche possibile applicare un profilo a un processo già in esecuzione attraverso il seguente comando:
{{{
'''App``Armor''' può tenere traccia e proteggere solo i processi che sono avviato dopo che il modulo kernel è stato caricato. Dopo l'installazione dei pacchetti ''apparmor'', '''App``Armor''' viene avviato. I processi già in esecuzione però non vengono protetti da '''App``Armor'''. Sia riavviare il processo che l'intero sistema corregge il problema.

È anche possibile applicare un profilo a un processo già in esecuzione attraverso il seguente comando: {{{
Linea 173: Linea 162:
Da un terminale, usare il comando ''aa-genprof''.
{{{
Da un terminale, usare il comando ''aa-genprof'': {{{
Linea 178: Linea 166:
Esempio:
{{{
Esempio: {{{
Linea 183: Linea 170:
Maggiori informazioni sono disponibili nella pagina di manuale: {{{man aa-genprof}}}. Maggiori informazioni sono disponibili nella pagina di manuale: {{{
man aa-genprof
}}}
Linea 195: Linea 184:
Quando il programma non si comporta in modo corretto, vengono inviati dei messaggi di audit ai file di registro. È possibile usare il programma ''aa-logprof'' per scansionare i file di registro in cerca dei messaggi di App``Armor, revisionare tali messaggi e aggiornare i profili.

{{{
Quando il programma non si comporta in modo corretto, vengono inviati dei messaggi di audit ai file di registro. È possibile usare il programma ''aa-logprof'' per scansionare i file di registro in cerca dei messaggi di '''App``Armor''', revisionare tali messaggi e aggiornare i profili: {{{
Linea 201: Linea 188:
Maggiori informazioni sono disponibili nella pagina di manuale: {{{man aa-logprof}}}. Maggiori informazioni sono disponibili nella pagina di manuale: {{{
man aa-logprof
}}}
Linea 211: Linea 200:
CategorySicurezza CategoryInTraduzione CategorySicurezza

BR

Introduzione

AppArmor è una implementazione del Linux Security Module di controlli d'accesso basati sul nome. AppArmor confina i singoli programmi a un gruppo di file selezionati e capacità POSIX 1003.1e draft.

AppArmor è stato reso disponibile su Ubuntu per la prima volta in Ubuntu 7.04 nel [:Repository:repository] universe.

Installazione

Ubuntu 7.10 (Gutsy)

In Ubuntu 7.10, AppArmor è installato e caricato in modo predefinito. Alcuni pacchetti installano dei profili propri, ma profili aggiuntivi possono essere trovati nel pacchetto apparmor-profiles nel repository universe.

Installare profili AppArmor addizionali

Ubuntu 7.04 (Feisty)

AppArmor non è incluso in modo predefinito nel kernel fornito con Ubuntu 7.04. È necessario compilarlo manualmente.

Installare la versione più recente

Per installare i pacchetti di AppArmor più recenti per Ubuntu 7.04, è necessario rigenerare i pacchetti. Per maggiori informazioni, consultare il [https://bugs.launchpad.net/ubuntu/+source/apparmor/+bug/116627 bug #116627] su Launchpad.

Aggiornamento kernel/apparmor-module-source

Quando viene installato un nuovo kernel o una nuova versione di apparmor-module-source, è necessario ricompilare il modulo apparmor:

sudo m-a -v -t -f build apparmor-modules
sudo m-a -v -t install apparmor-modules

Per essere sicuri che tutti i processi in esecuzione siano protetti, è necessario riavviare il sistema.

Uso

Tutti i comandi debbono essere eseguiti in un terminale.

Elencare lo stato corrente di AppArmor

sudo apparmor_status

Mettere un profilo in modalità apprendimento

sudo aa-complain /percorso/al/binario

Esempio:

sudo aa-complain /bin/ping

Immagine(Icone/Piccole/note.png,,center)

Nella modalità apprendimento (in originale complain) vengono rilevate le violazioni alle regole dei profili di AppArmor (per esempio il programma profilato accede a file non permessi dal profilo). Tali violazioni sono permesse, ma anche registrate. Questa modalità è conveniente per lo sviluppo di profili ed è usata dagli strumenti di AppArmor per la generazione dei profili (dalla documentazione su novell.com).

Mettere tutti i profili in modalità apprendimento

sudo aa-complain /etc/apparmor.d/*

Mettere un profilo in modalità esecutiva

sudo aa-enforce /percorso/al/binario

Esempio:

sudo aa-enforce /bin/ping

Immagine(Icone/Piccole/note.png,,center)

Il caricamento di un profilo nella modalità di esecuzione (enforcment) fa sì che sia rispettata la politica definita nel profilo e allo stesso tempo segnalata a syslogd ogni tentata violazione (dalla documentazione su novell.com).

Mettere tutti i profili in modalità esecutiva

sudo aa-enforce /etc/apparmor.d/*

Disabilitare l'infrastruttura AppArmor

sudo /etc/init.d/apparmor kill
sudo update-rc.d -f apparmor remove

Abilitare l'infrastruttura AppArmor

sudo /etc/init.d/apparmor start
sudo update-rc.d apparmor start 37 S .

Ricaricare tutti i profili

sudo /etc/init.d/apparmor reload

Ricaricare un profilo

cat /etc/apparmor.d/nome.profilo | sudo apparmor_parser -r

Esempio:

cat /etc/apparmor.d/bin.ping | sudo apparmor_parser -r

Disabilitare un profilo

ln -s /etc/apparmor.d/nome.profilo /etc/apparmor.d/disable/
apparmor_parser -R /etc/apparmor.d/nome.profilo

Esempio:

ln -s /etc/apparmor.d/bin.ping /etc/apparmor.d/disable/
apparmor_parser -R /etc/apparmor.d/bin.ping

Abilitare un profilo

In modo predefinito, i profili sono abilitati (cioè caricati all'interno del kernel e applicati ai processi).

rm /etc/apparmor.d/disable/nome.profilo
cat /etc/apparmor.d/nome.profilo | sudo apparmor_parser -a

Esempio:

rm /etc/apparmor.d/disable/bin.ping
cat /etc/apparmor.d/bin.ping | sudo apparmor_parser -a

Personalizzazione dei profili

I profili possono essere trovati in /etc/apparmor.d/.

Alcune personalizzazioni possono essere compiute in /etc/apparmor.d/tunables/.

Impostare la posizione delle directory home

La posizione delle directory home può essere regolata in /etc/apparmor.d/tunables/home.

Domande frequenti

apparmor_status riporta processi che sono non confinati ma che hanno definito un profilo

Riavviare i processi elencati. Anche eseguire un riavvio di sistema corregge il problema.

AppArmor può tenere traccia e proteggere solo i processi che sono avviato dopo che il modulo kernel è stato caricato. Dopo l'installazione dei pacchetti apparmor, AppArmor viene avviato. I processi già in esecuzione però non vengono protetti da AppArmor. Sia riavviare il processo che l'intero sistema corregge il problema.

È anche possibile applicare un profilo a un processo già in esecuzione attraverso il seguente comando:

sudo sh -c "echo 'setprofile /percorso/al/binario' > /proc/pid/attr/current"

Anchor(newprofile)

Creazione di un nuovo profilo

Progettare un piano di test

Provare a pensare a come è possibile mettere sotto tortura l'applicazione. Il piano di test dovrebbe essere diviso in casi di test più piccoli. Ciascun caso di test dovrebbe avere una piccola descrizione ed elencare i passi da seguire.

Alcuni casi di test standard sono:

  • avviare il programma
  • arrestare il programma
  • ricaricare il programma
  • controllare tutti i comandi supportati dallo script di init

Generare il nuovo profilo

Usare aa-genprof per generare un nuovo profilo.

Da un terminale, usare il comando aa-genprof:

sudo aa-genprof eseguibile

Esempio:

sudo aa-genprof slapd

Maggiori informazioni sono disponibili nella pagina di manuale:

man aa-genprof

Includere il proprio nuovo profilo nel pacchetto apparmor-profiles

Per fare in modo che il proprio nuovo profilo sia incluso nel pacchetto apparmor-profiles, aprire in Launchpad un bug per il [https://bugs.launchpad.net/ubuntu/+source/apparmor/+filebug pacchetto AppArmor]:

  • includere il proprio piano di test e i casi di test
  • allegare il proprio profilo al bug

Anchor(updateprofile)

Aggiornamento dei profili

Quando il programma non si comporta in modo corretto, vengono inviati dei messaggi di audit ai file di registro. È possibile usare il programma aa-logprof per scansionare i file di registro in cerca dei messaggi di AppArmor, revisionare tali messaggi e aggiornare i profili:

sudo aa-logprof

Maggiori informazioni sono disponibili nella pagina di manuale:

man aa-logprof

Ulteriori risorse


CategorySicurezza