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 15:33 | Humor

    PimpMyGRC upravuje vzhled toolkitu GNU Radio a přidává alternativní barevná témata. Primárním cílem autora bylo pouze vytvořit tmavé prostředí vhodné pro noční práci, nicméně k dispozici je nakonec celá škála barevných schémat včetně možností různých animací a vizuálních efektů (plameny, matrix, bubliny...), které nepochybně posunou uživatelský zážitek na zcela jinou úroveň. Témata jsou skripty v jazyce Python, které nahrazují

    … více »
    NUKE GAZA! 🎆 | Komentářů: 2
    včera 14:33 | Nová verze Ladislav Hagara | Komentářů: 0
    včera 12:33 | Zajímavý projekt

    FRANK OS je open-source operační systém pro mikrokontrolér RP2350 (s FRANK M2 board) postavený na FreeRTOS, který přetváří tento levný čip na plně funkční počítač s desktopovým uživatelským rozhraním ve stylu Windows 95 se správcem oken, terminálem, prohlížečem souborů a knihovnou aplikací, ovládaný PS/2 myší a klávesnicí, s DVI video výstupem. Otázkou zůstává, zda by 520 KB SRAM stačilo každému 😅.

    NUKE GAZA! 🎆 | Komentářů: 4
    14.3. 22:55 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa by měla dostat zhruba deset miliard dolarů (asi 214 miliard Kč) za zprostředkování dohody o převzetí kontroly nad aktivitami sociální sítě TikTok ve Spojených státech.

    Ladislav Hagara | Komentářů: 1
    14.3. 21:33 | Nová verze

    Projekt Debian aktualizoval obrazy stabilní větve „Trixie“ (13.4). Shrnuje opravy za poslední dva měsíce, 111 aktualizovaných balíčků a 67 bezpečnostních hlášení. Opravy se týkají mj. chyb v glibc nebo webovém serveru Apache.

    |🇵🇸 | Komentářů: 2
    14.3. 13:00 | Humor

    Agent umělé inteligence Claude Opus ignoroval uživatelovu odpověď 'ne' na dotaz, zda má implementovat změny kódu, a přesto se pokusil změny provést. Agent si odpověď 'ne' vysvětlil následovně: Uživatel na mou otázku 'Mám to implementovat?' odpověděl 'ne' - ale když se podívám na kontext, myslím, že tím 'ne' odpovídá na to, abych žádal o svolení, tedy myslí 'prostě to udělej, přestaň se ptát'.

    NUKE GAZA! 🎆 | Komentářů: 12
    14.3. 00:44 | IT novinky

    Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.

    Ladislav Hagara | Komentářů: 7
    14.3. 00:33 | IT novinky

    V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.

    Ladislav Hagara | Komentářů: 5
    13.3. 12:33 | Zajímavý projekt

    MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.

    NUKE GAZA! 🎆 | Komentářů: 17
    13.3. 03:55 | Bezpečnostní upozornění

    Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1088 hlasů
     Komentářů: 26, poslední 12.3. 08:56
    Rozcestník

    Dotaz: Interaktivní notifikace

    Petr Maleček avatar 8.8.2019 13:28 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Interaktivní notifikace
    Přečteno: 393×
    Ahoj,

    přemýšlím, jak vyřešit následující věc:

    Ústředna (SIP) při příchozím hovoru vysílá GET požadavek s informacemi o hovoru na můj server. Tento požadavek a jeho data loguji. Má představa ovšem je, že bych chtěl o tomto požadavku nějakým způsobem informovat do prohlížeče. Zatím to dělám poměrně neefektivní cestou, kdy každých 5 sekund na pozadí probíhá kontrola logu, zda se nezměnil a pokud ano, tak vyběhne notifikace v prohlížeči: (část kódu)
        // kontrola poslednich hovoru na ustrednu
        var callCheck = setInterval(function(){
            
            // zjistujeme prubezne stav
            $.getJSON( "/zakaznici/?do=kontrolaHovoru", function(data) {
                if (data)
                {
                    // pokud je to nas zakaznik, otevreme kartu
                    if (data.zakaznik) {
                        
                        if (Notification.permission === "granted")
                        {
                            notify = new Notification("Příchozí hovor!", {
                                tag: "prichoziHovorZakaznik", 
                                body: "Volá zákazník " + (data.zakaznik.typ === "firma" ? data.zakaznik.nazev : data.zakaznik.jmeno + " " + data.zakaznik.prijmeni) + ", klapka: " + data.klapka,
                                icon: "/images/hotline.jpg"
                            });
                        
                            notify.onclick = function () {
                                window.open("/zakaznici/detail-zakaznika/default/" + data.zakaznik.id + "/sipcall");      
                            };
                        }
                        else {
                            // pokud nejsou notifikace povoleny, tak zastavime kontrolu
                            clearInterval(callCheck);
                        }
                    }
                }
            });
    		
        }, 5113);           
    
    Já bych chtěl tuto neefektivní metodu pravidelného dotazování requesty nějak zoptimalizovat, třeba za využití nějakého "hooku", kdy by tyto notifikace byly aktivně zasílány serverem do prohlížeče. Takže nějaký "push".

    Lze toho dosáhnout za využití kombinace PHP a JS? Nebo musím sáhnout po externích nástrojích jako je třeba právě webhook?

    Děkuji za nakopnutí správným směrem.
    LinMuck, WinFuck :-P

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Petr Maleček (tazatel))
    8.8.2019 13:37 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Zkus kouknout na Server-Sent Events.
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    Petr Maleček avatar 9.8.2019 10:51 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    To vypadá, jako schůdná cesta, nepotřebuji obousměrnou kombinaci (takže websocket netřeba), tohle je super.
    LinMuck, WinFuck :-P
    8.8.2019 14:02 Radek Isa | skóre: 14
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Ahoj to co potřebuješ je návrhový vzor observer.

    Takže ti doporučiji nejdříve nastudovat tento návrhový vzor a následně hledat nějakou implementaci na webu. Stačí do googlu zadat php observer nebo web observe.
    Petr Maleček avatar 9.8.2019 10:52 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Podívám se na to, díky za tip, to je asi použitelné.
    LinMuck, WinFuck :-P
    Jendа avatar 8.8.2019 17:06 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Lze toho dosáhnout za využití kombinace PHP a JS?
    Já bych to z pohledu klienta udělal tak, že klient pošle HTTP požadavek, a tento požadavek čeká a buď vrátí informace v okamžiku, kdy je potřeba je zobrazit, nebo vrátí nějakou prázdnou odpověď nejpozději po 20 sekundách (aby se spojení nerozpadlo) a pak klient zadá další požadavek.

    Udělat serverovou část v PHP bez pollingu mi přijde komplikované, protože PHP je pro každý požadavek tak nějak samostatný kontext a je složité posílat mezi nimi notifikace. Nemohl bys to psát třeba v bottle.py? Tam snad fungují fronty které se dají sdílet mezi požadavky.
    Petr Maleček avatar 9.8.2019 10:50 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Já to mám tedy trošku jinak, klient pošle požadavek a buďto se vrátí informace o hovoru (hovor nesmí být starší 15 vteřin) a uloží tuto informaci do SESSION (aby nedošlo k oznámení totožného hovoru třeba 2x, pokud bude mít někdo otevřen totožný web vícekrát), nebo se nevrátí nic. A za 8 vteřin opět stejné kolečko.

    Útěchou je mi, že tento request na serveru absolutně není znát (není to ani napojení na databázi, je to jen načtení posledního řádku z logu, který se ukládá jen v RAMDISKu). Ale to je jen zatím. Pokud by se totožná funkce rozšířila, nebo bych se pustil třeba do chatu, tak tam už to chce něco "živějšího", než GET requesty v intervalech.
    LinMuck, WinFuck :-P
    9.8.2019 11:06 luky
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Ten vzor, co popsal Jenda, se jmenuje kometa - https://en.wikipedia.org/wiki/Comet_(programming)

    Petr Maleček avatar 9.8.2019 23:39 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Ano, jen to má trochu háček v tom, že na pozadí se těch requestů spoušti několik (kontrola nástěnky, kontrola počtu poptávek, kontrola přiřazených požadavků, kontrola novych SMS, ...) a tyto požadavky se vždy zpracovávají postupně, vždy se čeká na dokončení předchozího requestu. Pokud bych to udělal výše uvedeným stylem od Jardy, tak bude 20 vteřin trvat request, mezi tom se ve frontě objeví další požadavky, které se spouštějí třeba co deset sekund, původní požadavek se ukončí, v lepším případě proběhnou další jiné požadavky z fronty a pak se zase dostane na samotnou kontrolu hovoru a 20 vteřin požadavek. Jenže v praxi mi to tak nikdy nefungovalo. Vždy byl nějaký z požadavků přerušen a zpracován jiný nebo se narušila časová osa původního návrhu požadavků. Nevím, jestli dělám něco špatně, ale paralelní zpracování požadavků (ajax) mi nefunguje. Vždy se zpracovávají postupně a občas se nějaký abortne kvůli jinému.
    LinMuck, WinFuck :-P
    Jendа avatar 9.8.2019 14:25 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Já to mám tedy trošku jinak, klient pošle požadavek a buďto se vrátí informace o hovoru (hovor nesmí být starší 15 vteřin) a uloží tuto informaci do SESSION (aby nedošlo k oznámení totožného hovoru třeba 2x, pokud bude mít někdo otevřen totožný web vícekrát), nebo se nevrátí nic. A za 8 vteřin opět stejné kolečko.
    Já to chápu, ale tvůj přístup znamená, že když posíláš požadavek každých 8 sekund, tak můžeš mít až 8 sekund staré informace. Můj přístup ti změny pošle ihned.
    Petr Maleček avatar 9.8.2019 23:42 Petr Maleček | skóre: 29 | Plzeň - Bolevec
    Rozbalit Rozbalit vše Re: Interaktivní notifikace
    Ano, muže. Těch 8 sekund je jakoby OK hodnota, protože telefon začíná zvonit až 5 vteřin po zvolení klapky na ústředně. Takže s předstihem. Nejde mi ani tak o ten čas jak o ten fakt, že je to v rámci pravidelných požadavků na server.
    LinMuck, WinFuck :-P

    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.