käyttäen polussa heidän nimeään?
Eli home-tiedoston tyylisen?
Esim. /home/jotain/"joku"
jossa "joku" kohtaan tulee käyttäjän tunnus...
käyttäjiä on satoja, joten en viitsisi yksitellen tehdä, ja sen jopa osaisin ilman neuvoakin tehdä... :)
mites luon hakemistoja käyttäjille...
11
682
Vastaukset
- onnistunee...
Tee scripti joka lukee käyttäjänimiä tiedostosta luoden sitten hakemiston käyttäjälle. Eli yksinkertainen silmukka varmaan hoitaa tuon mallikkaasti.
Ei lienee monimutkaista, varmaan saisin itsekin aikaan, vaikka en olekaan noihin scripteihin perehtynyt sitten dosin komentojonojen jälkeen. Pitäisi kyllä.- *BSD
Esim. komentoriviltä voi (edellyttäen, että oikeudet riittää):
# for user in user1 user2 ... usern; do
> mkdir -p /home/jotain/$user
> chown $user /home/jotain/$user
> chgrp ..
done
#
Eli tossa on simppeli tapa tehdä homma. For-loopissa (sh/ksh/bash) lista 'user1 user2 user3' jne. Sitten taas jos (ja kun) kyseessä on satoja käyttäjiä on parempi varmaan tehdä tosta skripti, jossa on listattuna myös noi käyttäjät.
Suosittelen kokeilemaan em. viritystä ensin ilman root-tunnusta kun en testannut sitä mitenkään :) - kysymystä
*BSD kirjoitti:
Esim. komentoriviltä voi (edellyttäen, että oikeudet riittää):
# for user in user1 user2 ... usern; do
> mkdir -p /home/jotain/$user
> chown $user /home/jotain/$user
> chgrp ..
done
#
Eli tossa on simppeli tapa tehdä homma. For-loopissa (sh/ksh/bash) lista 'user1 user2 user3' jne. Sitten taas jos (ja kun) kyseessä on satoja käyttäjiä on parempi varmaan tehdä tosta skripti, jossa on listattuna myös noi käyttäjät.
Suosittelen kokeilemaan em. viritystä ensin ilman root-tunnusta kun en testannut sitä mitenkään :)Hyvä ja simppeli skripti! Mutta vieläkin eri versioissa on huomattava, tuo chgrp: joissa jakeluissa ryhmä käyttäjillä (oletuksena) on users, toisissa taas $user... jne.
(Saattaisi mennä tosin yhdelläkin chown-komennolla.) kysymystä kirjoitti:
Hyvä ja simppeli skripti! Mutta vieläkin eri versioissa on huomattava, tuo chgrp: joissa jakeluissa ryhmä käyttäjillä (oletuksena) on users, toisissa taas $user... jne.
(Saattaisi mennä tosin yhdelläkin chown-komennolla.)chown username file ..
chgrp groupname file ..
=
chown username.groupname file ..- *BSD
Mik26 kirjoitti:
chown username file ..
chgrp groupname file ..
=
chown username.groupname file ..Ja vielä BSD:ssä ja Solariksessa toi sama
on:
chown username:groupname file ... - kysymystä
*BSD kirjoitti:
Ja vielä BSD:ssä ja Solariksessa toi sama
on:
chown username:groupname file ...Kyllä tuo chown toimii samoin Linuxissa:
http://seth.positivism.org/man.cgi/chown
- kysymystä
Linuxissa (Unixeissa) on tiedostoilla ja hakemistoilla oikeuksia:
omistaja, ryhmä ja muut. Lisäksi näille on omat luku-, kirjoitus- ja ajo-oikeutensa...
Kurkkasepa mitä kertoo komento ls -l- kysymykseen
Uups. Vastasin väärään kysymykseen, mutta...
roottina hakemiston tekeminen käyttäjän hakemistoon jää oikeudet root-tunnukselle, joten myös tuo omistusoikeudet pitänee muuttaa.
Homma ei siis ole aivan yksinkertainen... mutta vaatinee (?) lisäksi chown komennon ajamisen skriptissä :(
- skriptaaja
# HUOM: ei testattu!
mkdir -p /home/jotain
cd /home/jotain
mkdir `ls /home`
chown `ls /home` `ls /home`
# yllä luotiin hakemistot (ja vähän liikaakin...)
# ja asetettiin hakemistoille oikeudet- skriptaaja
edellisessä tuo chown-rivi tekee asiat väärin, älä käytä sitä! Parempi olisi vaikkapa bashissa:
mkdir -p /home/jotain
cd /home/jotain
for user in `ls /home` ; do
mkdir -p $user
chown $user $user
# muuta tarvittavaa tänne...
done
- onion
Iski inspis, tässä kunnon pieni softa. Muokkaa itsellesi sopivaksi:
#include
#include
#include
#include
#include
#define BASEDIR "./home/testing/"
#define MIN_UID 100
struct passwd *ent;
int main (int argc, char **argv)
{
int gid;
char buffer[2048];
if (argc!=2) exit(1);
if (getuid()!=0) exit(2);
gid=atoi(argv[1]);
if (gid==0) {
printf("Not a valid GID\n");
exit(3);
}
while ( (ent=getpwent()) != NULL) {
if (ent->pw_uidpw_gid==gid) {
printf("The uid [%d] matches gid, creating dir: ", ent->pw_uid);
strcpy(buffer, BASEDIR);
strcat(buffer, ent->pw_name);
mkdir(buffer, S_IRWXU);
chown(buffer, ent->pw_uid, ent->pw_gid);
printf("%s\n", buffer);
}
}
endpwent();
return 0;
}
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Tulipalossa henkilövahinkoja, itsenäisyyspäivä alkoi huonosti, poliisi tiedottaa lisää
Savonlinna https://www.como.fi/uutiset/savonlinna-henkilovahinkoja-tulipalossa-poliisi-tiedottaa-lisaa/1629217Ennen ei ollut persuja ja työttömyyttä, lääkäriinkin pääsi
Ennen oli kaikilla töitä Kauppiaille kelpasi kun saivat voittoa Yritystukia ei ollut Lääkäriin pääsi kaikki haluklaat Nu1114124- 1143932
Somali ei kätellyt Stubbia Linnan juhlissa
Miksei somali osaa noudattaa hyviä käytöstapoja. https://www.iltalehti.fi/viihdeuutiset/a/563a3dea-fa3f-41f3-b64f-406d23973534- 553403
Antifasismi - mitä se on?
Se on äärivasemmistolaista anarkistista toimintaa joka käyttää fasisminvastaisuutta keppihevosena oikeuttaakseen toimint432730Yliajo Heinolassa
Mikä ihme ihmisiä vaivaa nykyään? Vähän ensin kähistellään nakkikioskilla ja sen jälkeen kostoksi murhataan autolla! Voi491989Kuka on menehtynyt?
https://yle.fi/a/74-20198293 Kuulemani mukaan ryyppyporukka ollut hapualla ja kuolemanenkeli (F.G) eli mies jonka seuras111961- 571947
Kauhea ikävä iski
Mietin vain, mitä olet juuri nyt tekemässä. Mietin myös, välittyykö se sinulle, kun olet koko ajan mielessäni, tunnetko201541