abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 3
    včera 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Nová verze

    Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Nová verze

    Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.

    Ladislav Hagara | Komentářů: 2
    včera 04:11 | Nová verze

    Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    23.4. 23:22 | IT novinky

    Evropský parlament dnes přijal směrnici týkající se tzv. práva spotřebitele na opravu. Poslanci ji podpořili 584 hlasy (3 bylo proti a 14 se zdrželo hlasování). Směrnice ujasňuje povinnosti výrobců opravovat zboží a motivovat spotřebitele k tomu, aby si výrobky nechávali opravit a prodloužili tak jejich životnost.

    Ladislav Hagara | Komentářů: 9
    23.4. 16:11 | Nová verze

    Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 24
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 726 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: setuid, spuštění skriptu a špatný vlastník souboru

    11.1.2007 13:12 gagod | skóre: 2
    setuid, spuštění skriptu a špatný vlastník souboru
    Přečteno: 215×
    zdar, potřebuju pod apachem spustit skript, který zkompiluje a spustí cizí program pod jiným uživatelem. Pokud jsem správně pochopil setuid-skripty tak by měl ten program spustit shellskript právě pod tím jiným uživatelem.
    useradd -u 555 -g ulohy -M -d /tmp/ -s /sbin/nologin uloznik
    passwd -d uloznik
    
    test.c
    #include cstdlib
    #include iostream
    #include string
    // http://yolinux.com/TUTORIALS/ForkExecProcesses.html, man execve
    using namespace std;
    main(){
      // nove prostredi
      char *env[]={"UID=555","USER=uloznik","LANG=en_US.UTF-8","PATH=/usr/bin:/bin",(char *) 0};
      char *Env_argv[] = { "./ko.sh",NULL, (char *) 0 };
      int ret;
      ret = execve (Env_argv[0], Env_argv, env);
      cout << "Failure! execve error code=" << ret << endl;
    }
    
    ko.sh
    #!/bin/bash
    touch novy_soubor
    echo $USER
    groups
    
    jenže skript se sice spustí v novém prostředí, ale s mými pravy, což nechci
    $ ./test
    uloznik
    maro users
    $ ll novy_soubor test
    -rw-r--r-- 1 maro    maro    0 Jan 11 13:04 novy_soubor
    -rwsr-xr-x 1 uloznik maro 6787 Jan 11 12:48 test
    
    Co dělám špatně? Potřebuju, aby nový soubor (když už něco zkompiluji) měl práva jako "uloznik".

    Odpovědi

    marek_s avatar 11.1.2007 13:42 marek_s | skóre: 8 | Loučky
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    Nevim, nevim ... nemuze to byt tim, ze je oddil namountovan jako nosuid?
    "Consummatum est" -- Iesus Nazarenus
    11.1.2007 13:45 gagod | skóre: 2
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    spoustim to v /tmp/
    LABEL=/                 /                       ext3    defaults        1 1
    11.1.2007 17:13 marek
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    Uz je mne to jasne... V unixu existuji dva druhy uid (asi jeste vic) ... efektivni a realne. Efektivni je to co muzu delat a realne je to co jsem. Nastavenim setuidbitu zmenim Efektivni, NE VSAK realne. Potrebuji tedy v programu nastavit realne uid na efektivni. Jednoduse treba takto:
    euid=geteuid();
    setreuid(euid,euid);
    
    Takhle mi to funguje...
    11.1.2007 19:10 gagod | skóre: 2
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    jo, funguje, ale pro skupinu mi to nejede...
    $ cat ko.sh 
    #!/bin/bash
    touch novy_soubor
    echo "user $USER"
    echo "uid $UID"
    echo "euid $EUID"
    groups
    
    $ cat test.c 
    #include cstdlib
    #include iostream
    #include string
    // http://yolinux.com/TUTORIALS/ForkExecProcesses.html
    using namespace std;
    main(){
            //"EUID=555","UID=555","USER=uloznik",
            char *env[]={"LANG=en_US.UTF-8","PATH=/usr/bin:/bin",(char *) 0};
            char *Env_argv[] = { "./ko.sh",NULL, (char *) 0 };
            int ret,euid,egid;
            euid = geteuid();
            setreuid(euid,euid);
            egid = getegid();
            setegid(egid);
       ret = execve (Env_argv[0], Env_argv, env);
       cout << "Failure! execve error code=" << ret << endl;
    }
    
    # chown uloznik:ulohy /tmp/test
    # chmod gu+s /tmp/test
    
    $ ./test
    user 
    uid 555
    euid 555
    maro apache users
    
    $ ll test novy_soubor 
    -rw-r--r-- 1 uloznik maro     0 Jan 11 19:09 novy_soubor
    -rwsr-sr-x 1 uloznik ulohy 7160 Jan 11 19:08 test
    
    Tak mě napadá, proč teoreticky nestačí to EUID nastavit v novém prostředí?
    char *env[]={"UID=555","EUID=555","USER=uloznik","LANG=en_US.UTF-8","PATH=/usr/bin:/bin",(char *) 0};
    Zkoušel jsem tuto kombinaci, ale novy_soubor ma porad skupinu "maro"
    setreuid(euid,euid);
    egid = getegid();
    
    co ted?
    marek_s avatar 11.1.2007 19:28 marek_s | skóre: 8 | Loučky
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    myslim, ze setregid bude ta spravna volba. Podobne jako v predchozim to bude chtit (asi -nezkousel jsem to) udelat toto:
    gid=getegid();
    setregid(gid,gid);
    
    Samotny setegid(egid) Vam nepomuze - nastavite efektivni gid na efektivni gid - tedy nic jste neudelal. Potrebujete ovsem nastavit realne na efektivni...
    "Consummatum est" -- Iesus Nazarenus
    11.1.2007 20:33 gagod | skóre: 2
    Rozbalit Rozbalit vše Re: setuid, spuštění skriptu a špatný vlastník souboru
    dík moc, to jsem potřeboval

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.