Introduksjon til doas på OpenBSD

Bakgrunn

OpenBSDs alternativ til sudoer doas, selv om det ikke fungerer på samme måte som sudo og krever noe konfigurasjon. Det er et akronym for "dedicated openbsd application subexecutor". OpenBSD 5.8, utgitt i 2015, var den første som inkluderte doas. Den ble laget av Ted Unangst etter at han var misfornøyd med kompleksiteten til sudo og hadde problemer med standard sudo-konfigurasjonen.

Den doaskommandoen er enkel ved design og ikke inneholder avanserte funksjoner som kreves for forseggjort sysadmin infrastrukturer. For de fleste er det mer enn nok. Hvis du trenger sudo, installer den med pkg_add sudosom root.

Installasjon

OpenBSD versjon 5.8 og nyere er doasforhåndsinstallert.

Konfigurasjon

For å gi brukere i hjulgruppen tilgang til doas, legg til følgende i /etc/doas.conf. Du trenger root-tilgang for å redigere denne filen.

permit :wheel

Dette vil gi alle brukere i hjulgruppen tillatelse til å utføre kommandoer som enhver bruker.

Hvis du vil at brukere skal kunne skrive inn passordet sitt én gang, og ikke trenger å angi det på en stund, bruk persistalternativet. Her er et eksempel som bare gir tillatelser til hjulgruppen:

permit persist :wheel

Du kan i stedet bruke nopassalternativet hvis du vil at de aldri skal måtte skrive inn passordet sitt:

permit nopass :wheel

Hvis du vil at brukeren "mynewuser" skal ha administratorrettigheter, kan du enten legge dem til hjulgruppen ved å kjøre usermod -G wheel mynewusersom root eller legge til en linje i din /etc/doas.confslik at den ser litt ut som følgende:

permit nopass :wheel
permit nopass mynewuser

Dette eksemplet forutsetter at du ikke trenger at brukerne dine oppgir et passord når du bruker doas. Hvis du vil sette det slik at mynewuser kun har tillatelse til å utføre kommandoer som www-bruker, vil konfigurasjonen være som følger:

permit nopass :wheel
permit nopass mynewuser as www

Hvis du vil at mynewuser bare skal kunne bruke "vim"-kommandoen med doas, bruk følgende konfigurasjon:

permit nopass :wheel
permit nopass mynewuser as www cmd vim

Det finnes andre konfigurasjonsalternativer, men de som dekkes her er de vanligste. Hvis du vil lese mer, kan du bruke kommandoen man doas.conftil å lese doas.conf(5) manpage.

Testing av konfigurasjonsfiler

For å teste en konfigurasjonsfil, bruk doas -C /etc/doas.confkommandoen. Hvis du oppgir en kommando etterpå, f.eks doas -C /etc/doas.conf vim. vil den fortelle deg om du har tillatelse til å kjøre en kommando eller ikke uten å prøve å utføre kommandoen.

Bruk

En bruker kan kjøre kommandoen echo "test"som root ved å bruke kommandoen: doas echo "test"

En bruker som har tillatelser til å bruke doas for å heve seg til brukeren "www" kan kjøre kommandoen vim /var/www/http/index.htmlsom brukeren "www" ved å bruke kommandoen: doas -u www vim index.html Dette er nyttig for noen som administrerer webserveren, men som ikke har fulle superbrukertillatelser.

Beste praksis

Det anbefales sterkt at du bruker tillatelse i stedet for å nekte der det er mulig. Hvis du nekter en bruker å bruke en bestemt kommando, kan de kanskje slippe unna med å bruke en alternativ bane eller navn på den kommandoen hvis den eksisterer. De kan også kopiere kommandoens kjørbare til hjemmekatalogen deres og deretter kjøre den kjørbare filen, og dermed beseire tillatelsessystemet ditt.

Generelt sett er det en bedre idé å bruke doas enn å bruke su fordi ingen trenger å dele root-passordet. Det er ingen sjanse for at noen endrer det, glemmer det og låser alle ute av systemet hvis alle bruker sitt eget passord for root-tilgang. Logger oppbevares i /var/log/secure.

Tips og triks

Du kan beholde alle miljøvariablene dine med keepenv, noe som er nyttig hvis du har editoren satt til noe og ikke vil at den skal endres når du blir en annen bruker. Her er et eksempel med mynewuser:

permit nopass keepenv mynewuser

Noen ganger er det situasjoner der overskriving av hver miljøvariabel kan ødelegge ting, men med setenv kan du velge og vrake hvilke du vil overføre. Her er et eksempel som vil holde editoren innstilt på hva du vil for bruk med git og noen andre ting.

permit nopass setenv { VISUAL EDITOR } mynewuser

Du kan også bruke setenv til å fjerne miljøvariabler (ved å sette en bindestrek foran hver av dem du vil fjerne) eller sette dem til spesifikke ting med et likhetstegn. Hvis du for eksempel ville at den skulle fjerne miljøvariabelen VISUAL og sette EDITOR til vim, ville du bruke denne konfigurasjonslinjen:

permit nopass setenv { -VISUAL EDITOR=vim } mynewuser

Hvis du doashar husket passordet ditt, kan du gjøre for doas -Lå få det til å glemme passordet.

Legg igjen en kommentar

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.

DDOS-angrep: en kort oversikt

DDOS-angrep: en kort oversikt

Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.

Har du noen gang lurt på hvordan hackere tjener penger?

Har du noen gang lurt på hvordan hackere tjener penger?

Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.

Funksjonaliteter til Big Data Reference Architecture Layers

Funksjonaliteter til Big Data Reference Architecture Layers

Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.

Evolusjon av datalagring – infografikk

Evolusjon av datalagring – infografikk

Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer