Dimensione: 8445
Commento:
|
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 |
IndiceBRTableOfContents(2) |
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
Abilitare il [:Repository:repository] universe.
[:AmministrazioneSistema/InstallareProgrammi:Installare] il pacchetto apparmor-profiles.
Ubuntu 7.04 (Feisty)
AppArmor 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 sudo m-a -v -t -f build apparmor-modules sudo m-a -v -t install apparmor-modules
[:AmministrazioneSistema/InstallareProgrammi:Installare] i pacchetti apparmor-profiles, apparmor-utils e apparmor.
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
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
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"
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
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
[https://help.ubuntu.com/community/AppArmor Documento originale su ubuntu.com]
[http://en.opensuse.org/AppArmor_Geeks Intro to AppArmor for Geeks]: utilizzo dettagliato di apparmor
[http://outflux.net/blog/archives/2007/04/02/apparmor-now-in-feisty/ AppArmor now in Feisty]: breve tutorial sulla generazione di un nuovo profilo per Evince.
[http://www.novell.com/documentation/apparmor/index.html?page=/documentation/apparmor/apparmor_user/data/bktitleuser.html Guida rapida e Guida di Amministrazione su Novell Doc]