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í
×
    včera 04:00 | Zajímavý software

    Nourish (GitHub) je nový správce oken pro Linux. Tradiční plochy nahrazuje nekonečným plátnem a posouváním a přibližováním. Využívá vlastní kompozitor pro Wayland s názvem y5. Videoukázka.

    Ladislav Hagara | Komentářů: 3
    27.6. 15:33 | Komunita

    Po 20 letech a 17 otevřených (open source) krátkých filmech Blender Studio oznámilo plán na svůj první celovečerní film. Cílem samozřejmě není jenom nový otevřený film, ale především vývoj a vylepšení otevřených nástrojů pro spolupráci napříč celým procesem a vytvoření otevřené příručky (playbook) pro filmovou produkci ve velkém měřítku s informacemi, které jsou obvykle dostupné pouze uvnitř komerčních studií, a pomoci tak nezávislým tvůrcům překonat technické a organizační bariéry.

    Ladislav Hagara | Komentářů: 0
    27.6. 05:00 | Nová verze

    Byla vydána nová verze 26.6.25 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    26.6. 14:44 | IT novinky

    Apple bez varování odstranil ze svého obchodu sociální síť VKontaktě i další aplikace skupiny VK, jako je VK Music nebo VK Video [Novinky.cz].

    Ladislav Hagara | Komentářů: 18
    26.6. 14:22 | IT novinky

    V dubnu loňského roku představený poštovní klient Notion Mail bude 22. září ukončen.

    Ladislav Hagara | Komentářů: 3
    26.6. 04:33 | Komunita

    Konference OpenAlt 2026 hledá přednášející. Proběhne o víkendu 7. a 8. listopadu na půdě Fakulty informačních technologií VUT v Brně. Témata konference jsou: Otevřený a svobodný software, IoT a Hnutí tvůrců, Vzdělávání, Bezpečnost a soukromí, Otevřená společnost, komunity a data, OpenMobility a další.

    Ladislav Hagara | Komentářů: 0
    26.6. 04:22 | IT novinky

    Společnosti OpenAI a Broadcom oznámily čip optimalizovaný pro AI pojmenovaný Jalapeño.

    Ladislav Hagara | Komentářů: 0
    25.6. 20:22 | Nová verze

    Deno (Wikipedie), běhové prostředí (runtime) pro JavaScript, TypeScript a WebAssembly, bylo vydáno v nové verzi 2.9. Hlavní novinkou je deno desktop pro převod Deno projektu na desktopovou aplikaci. Jedná se o alternativu k frameworkům Electron nebo Tauri.

    Ladislav Hagara | Komentářů: 2
    25.6. 15:44 | IT novinky

    Od zítra jsou Datové schránky oficiálně na nové adrese datovka.gov.cz. Adresa mojedatovaschranka.cz zůstává funkční do 27. srpna 2026, následně budou uživatelé automaticky přesměrováni na datovka.gov.cz.

    Ladislav Hagara | Komentářů: 3
    25.6. 13:44 | Nová verze

    Dolphin (Wikipedie), tj. open source multiplatformní emulátor herních konzolí GameCube a Wii od Nintenda, byl vydán ve verzi 2606. S podporou Game Boy Playeru.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (7%)
     (2%)
     (17%)
     (31%)
     (4%)
     (6%)
     (2%)
     (15%)
     (26%)
    Celkem 2004 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dva autentikátory pro BincIMap a QMail

    14.2.2010 15:22 | Přečteno: 938× | Programování | Výběrový blog | poslední úprava: 14.2.2010 15:23

    Jelikož jsem v domácí síti přešel na ldap+kerberos autentifikaci, tak jsem potřeboval změnit autentifikátor pro IMAP server, který používám. Výsledkem jsou dva checkpassword kompatibilní autentifikátory. První je pro LDAP autentifikaci - potřebuje balíček python-ldap.
     cat binc_ldapauth/src/binc_ldapauth.py 
    #!/usr/bin/python
    '''
    Created on Feb 12, 2010
    
    @author: bartmann
    '''
    import os;
    import string;
    import sys;
    import ldap;
    import ldap.sasl;
    
    
    
    class binc_ldapauth:
            def __init__(self):
                    self.gssapi_auth=True;
    
            def get_creds(self):
                    fd=os.fdopen(3,"r");
    
                    ncreds=os.read(3, 128);
                    creds=ncreds;
                    while(ncreds!=""):
                            ncreds=os.read(3, 128);
                            creds+=ncreds;
    
                    creds=creds.split("\0");
                    self.username=creds[0];
                    self.password=creds[1];
    
            def auth(self):
                    ds = ldap.initialize("ldap://joomladev.dyndns.org");
                    ds.protocol_version=3;
    
                    if self.gssapi_auth==False:
                            try:
                                    ds.simple_bind_s("uid="+self.username+",ou=people,dc=joomladev.dyndns,dc=org",self.password);
                                    dn=string.replace(ds.whoami_s(),"dn:","");
                            except ldap.INVALID_CREDENTIALS:
                                    return 1;
                    else:
                            try:
                                    auth=ldap.sasl.gssapi();
                                    ds.sasl_interactive_bind_s("",auth);
                                    dn=string.replace(ds.whoami_s(),"dn:","");
                                    if(ds.compare_s(dn,'uid',self.username)):
                                            pass;
                                    else:
                                            return 1;
                            except ldap.INVALID_CREDENTIALS:
                                    return 1;
    
                    os.environ["USER"]=self.username;
    
                    home=ds.search_s(dn,ldap.SCOPE_BASE,'(objectclass=person)',['homeDirectory']);
                    os.environ["HOME"]=home[0][1]["homeDirectory"][0];
    
                    shell=home=ds.search_s(dn,ldap.SCOPE_BASE,'(objectclass=person)',['loginShell']);
                    os.environ["SHELL"]=shell[0][1]["loginShell"][0];
    
                    gid=home=ds.search_s(dn,ldap.SCOPE_BASE,'(objectclass=person)',['gidNumber']);
                    os.setgid(int(gid[0][1]["gidNumber"][0]));
    
                    uid=home=ds.search_s(dn,ldap.SCOPE_BASE,'(objectclass=person)',['uidNumber']);
                    os.setuid(int(uid[0][1]["uidNumber"][0]));
    
                    os.chdir(os.environ["HOME"]);
    
                    os.execlp(sys.argv[1],sys.argv[1]);
    
    if __name__ == '__main__':
            lauth=binc_ldapauth();
            lauth.get_creds();
            lauth.auth();
    
    
    a ten druhý autentifikuje přes PAM - k jeho funkci je nutné mít nainstalovaný PyPAM:
    cat binc_pamauth/src/binc_pamauth.py
    #!/usr/bin/python
    '''
    Created on Feb 12, 2010
    
    @author: bartmann
    '''
    import os;
    import sys;
    import PAM;
    import pwd;
    
    
    class binc_pamauth:
            def __init__(self):
                    self.gssapi_auth=True;
    
            def get_creds(self):
                    fd=os.fdopen(3,"r");
    
                    ncreds=os.read(3, 128);
                    creds=ncreds;
                    while(ncreds!=""):
                            ncreds=os.read(3, 128);
                            creds+=ncreds;
    
                    creds=creds.split("\0");
                    self.username=creds[0];
                    self.password=creds[1];
    
            def pam_conv(self,auth, query_list):
                    resp=[];
                    for (q, qtype) in query_list:
                            if qtype==PAM.PAM_PROMPT_ECHO_OFF :
                                    resp.append((self.password,0));
                            else:
                                    resp.append(('',0));
                    return resp;
    
            def auth(self):
                    pam_auth = PAM.pam();
                    pam_auth.start("imap");
                    pam_auth.set_item(PAM.PAM_USER,self.username);
                    pam_auth.set_item(PAM.PAM_CONV,self.pam_conv);
                    try:
                            pam_auth.authenticate();
                            pam_auth.acct_mgmt();
                    except PAM.error:
                            return 1;
    
                    pw=pwd.getpwnam(self.username);
    
                    os.environ["USER"]=self.username;
                    os.environ["HOME"]=pw[5];
                    os.environ["SHELL"]=pw[6];
                    os.setgid(int(pw[3]));
                    os.setuid(int(pw[2]));
                    os.chdir(os.environ["HOME"]);
    
                    os.execlp(sys.argv[1],sys.argv[1]);
    
    
    if __name__ == '__main__':
            pauth=binc_pamauth();
            pauth.get_creds();
            pauth.auth();
    
           

    Hodnocení: 100 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

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