abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    26.12. 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

    Ladislav Hagara | Komentářů: 0
    26.12. 13:22 | Zajímavý software

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 7
    26.12. 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    26.12. 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 30
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (35%)
     (1%)
     (18%)
     (1%)
     (1%)
     (1%)
     (13%)
     (12%)
     (16%)
    Celkem 145 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: systemd template unit: jak vyřešit proměnnou ve volbě "User"

    10.7.2017 22:22 Deryl | skóre: 11
    systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Přečteno: 527×
    Zdravím,

    cílem je spouštění samostaných služeb pro stahování emailu:

    Např:
    User=pepa
    ExecStart=stáhni poštu z účtu pepa1@gmail.com
    
    a
    User=pepa
    ExecStart=stáhni poštu z účtu pepa.novak@yahoo.com
    
    Otázka zní, jak vytvořit service unit template (stahni-postu@.service), aby šlo splnit výše uvedené.

    Zatím jsem přišel na to, že více parametrů zadat nelze, ale jde to obejít pomocí volby EnvironmentFile=%i a proměnné nastavit v souboru %i dle libosti (_USER, EMAIL_ACC). Jenže tyto proměnné se nedají využít u volby User=, pouze u Exec....

    Takže aktuální "řešení" je:
    ExecStart=/bin/su - c'/bin/getmail stáhni poštu z účtu $EMAIL_ACC' - $_USER
    
    A to má nepříjemný dopad, že v journalu se místo názvu procesu getmail objevuje su.

    P.S. Jedná se server (IMAP), poštu je třeba stahovat průběžně, nikoliv až po případném přihlášení pepy (nelze tedy IMHO použít /etc/systemd/user/...).

    Je nějaké elegantnější řešení?

    Řešení dotazu:


    Odpovědi

    10.7.2017 22:52 LP
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    LOL
    Heron avatar 10.7.2017 23:02 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    fetchmail
    11.7.2017 07:34 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Můžete být konkrétnější?

    Předpokládám, že na rozdíl od getmailu se fetchmail spouští jen v jedné instanci a stahuje všechny možné účty.

    Dále bych potřeboval použít lokální MDA dovecot (kvůli konfiguraci maildir:LAYOUT=fs:DIRNAME=aMaixI a okamžité FTS indexaci). MDA už by měl běžet pod právy konečného příjemce (lokální uživatel).

    Předpokládám správně, že jako MDA za fetchmailem by byla ta obezlička /usr/bin/su -c '/usr/lib/dovecot/deliver ....' - $_USER, přičemž doufám, že proměnnou _USER nějak zvládnu nastavit v rámci fetchmailu v rámci mapování emailových účtů na lokální uživatele...
    Heron avatar 11.7.2017 09:52 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    fetchmail může běžet ve dvou rezimech. Buď jako systémová služba (o tom moc nevím), nebo si to může spustit každý úživatel sám. Emaily umí poslat do lokálního mailserveru.

    Tj místo X jednotek pro každého uživatele a jeho mailbox vám může stačit nastavit fetchmail pro každého uživatele (resp. ti uživatelé si to klidně mohou nastavit sami), nebo jeden systémový.

    Programů pro stahování emailů z jiných schránek a jejich ukládání do místní je více, kdysi jsem používal offlineimap.
    11.7.2017 20:36 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Uživatelé se vůbec nepřihlašují do shellu, takže to chápu spíše jako systémovou službu. Budu-li mít trochu více času a budu-li nespokojen se samostatnými procesy getmailu řízenými systemd, tak bych důkladněji kouknul na fetchmail (dost dlouhá man page) a možnosti, jak email doručit dovecotu.

    P.S. Offlineimap používám pro dalšího uživatele na dvoucestnou synchronizaci jedné schránky mezi IMAP servery. Funguje to dobře, ale je pekelně nenažraný, až se RPi zapotí.
    30.7.2017 15:55 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Podíval jsem se blíže na fetchmail: pro použití "IMAP IDLE" má stejné omezení jako getmail - je nutné pro každý účet spustit samostatný proces.
    11.7.2017 08:53 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Opravdu chcete pro každou schránku definovat novu jednotku? A proč chcete zadávat volbu User pomocí proměnné, proč ji nezadáte normálně přes override soubor? Budete mít jednotku třeba stahni-postu@pepa1_gmail.com.service, a k tomu soubor /etc/systemd/system/stahni-postu@pepa1_gmail.com.service.d/mail.conf s obsahem:
    [Service]
    User=pepa
    Environment=MAIL=pepa1@gmail.com
    
    11.7.2017 20:10 Deryl | skóre: 11
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    Chci mít samostatné jednotky, protože:
    • getmail umí --imap IDLE, ale jen s jedním konfiguračním souborem. To jest, musím jej spustit vícekrát jako samostatné procesy;
    • chci, aby systemd hlídal neočekávané ukončení procesu a restartoval jej. Nevím, zda systemd umí hlídat i další procesy spuštěné z hlavního skriptu, takže jednodušší a ve výsledku i přehlednější se mi jeví samostatné units, jež mají v názvu jméno uživatele a emailového účtu ke stažení.
    Je to pouze pro dva uživatele a pár účtů, takže mi to přijde jako poměrně schůdné řešení. Pro více uživatelů, bych to asi řešil jinak (možná fetchmail).
    11.7.2017 20:29 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    To dává smysl. Bál jsem se, zda takhle nechcete obsluhovat stovky účtů… Víc procesů z jedné jednotky systemd hlídat neumí, řešením je to, co používáte vy – mít pro každý proces samostatnou jednotku.
    michich avatar 13.7.2017 11:46 michich | skóre: 51 | blog: ohrivane_parky
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    P.S. Jedná se server (IMAP), poštu je třeba stahovat průběžně, nikoliv až po případném přihlášení pepy (nelze tedy IMHO použít /etc/systemd/user/...).
    Jde to použít. Uživateli to umožníš pomocí loginctl enable-linger pepa. Pak můžeš mít /etc/systemd/user/stahni-postu@.service:
    [Unit]
    Description=Stáhni poštu z %i
    [Service]
    ExecStart=/bin/getmail … %i
    [Install]
    WantedBy=default.target
    
    Uživatel pepa si udělá systemctl --user enable --now stahni-postu@pepa1@gmail.com.service stahni-postu@pepa.novak@yahoo.com.service.
    13.7.2017 12:51 Tomáš
    Rozbalit Rozbalit vše Re: systemd template unit: jak vyřešit proměnnou ve volbě "User"
    používám pro podobnou věc toto:

    v ExecStart je cesta k shell skriptu, kde se spouští fetchmail (mám tedy jeden fetchmail.conf pro všechny email účty, co stahuji).

    Fetchmail to předává lokálnímu postfixu, který potom doručuje pomocí deliver od dovecotu

    Stahuji asi čtyři schránky pro dva lokální uživatele.

    Není to tedy user unit, ale normální jedna systémová unit.

    Nevýhoda je v tom, že uživatelé nemohou editovat fetchmail.conf a je potřeba zásah roota. Ale protože to jsou děti, tak to není na závadu.

    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.