diff options
-rw-r--r-- | README.md | 14 | ||||
-rwxr-xr-x | rtv4d-dl | bin | 52776 -> 67272 bytes | |||
-rw-r--r-- | rtv4d-dl.c | 32 |
3 files changed, 42 insertions, 4 deletions
@@ -39,13 +39,15 @@ z uporabo programa se strinjate z naslednjimi stavki: * **živo**: za možne programe in razlago dolžine glej *dodatno o prenosu v živo* # trenutna izdaja programa: -* program je bil nazadnje ročno testiran 13. decembra 2020 in takrat je DELOVAL. -* različica: 0.0.3 +* program je bil nazadnje ročno testiran 30. decembra 2020 in takrat je DELOVAL. +* različica: 0.0.4 ## dnevnik sprememb: * 0.0.2 - 13. december 2020: sedaj pravilno naloži samo največjo kvaliteto, pred tem se naloži naključna kvaliteta. * 0.0.3 - 24. december 2020: dodano prenašanje VTT podnapisov in prenosov v živo +* 0.0.4 - 30. december 2020: dodani alternativni strežniki za prenos v živo iz + tujine # o * program je spisan 100% v C programskem jeziku @@ -73,6 +75,8 @@ z uporabo programa se strinjate z naslednjimi stavki: - nizka prioriteta, bolje obdržati formo *brez knjižnjic* * narediti mehanizem za avtomatsko posodobitev binarne datoteke - namesto HTTP se bo uporabljajo preprosto podpisovanje, BREZ KNJIŽNIC +* ugotoviti mehanizem rotacije/ponovne uporabe identifikatorjev kosov v živo, + glej [dodatno o prenosu v živo](#dodatno_o_prenosu_v_živo). ## predvajanje v živo * ker predvajanje v živo na RTVSLO trenutno potrebuje Javascript, bi bilo @@ -107,3 +111,9 @@ z uporabo programa se strinjate z naslednjimi stavki: playlist.m3u8 datoteke in branje po kosih. * če program ni bil prekinjen, bo po končanem prenosu v stdout napisal metapodatke pretoka v živo. +* **težava:** vsake toliko časa bo strežnik številko kosa rotiral nazaj. to + prepreči snemanje neskončno v prihodnost in program bo ostal v krogu. +* za omogočanje snemanja iz tujine se gostiteljska imena pretočnih strežnikov + zamenjajo s slovenskimi. če slovenski strežniki niso več aktualni, program + ne bo delal. v tem primeru me kontaktirajte in med prevajanjem (angl. + *compilation*) nastavite zastavico RTV_NASTAVITEV_BREZ_LOKACIJSKIH_SPREMEMB. Binary files differ@@ -65,7 +65,7 @@ #define RTV_JWT_SIZEOF 43+1 #define RTV_PREDVAJALNIK_URL "http://4d." RTV_SLD "/arhiv/v/%u" #define RTV_PREDVAJALNIK_URL_SIZEOF (32+1 + 12) -#define RTV_VER "0.0.3" +#define RTV_VER "0.0.4" #define RTV_ZIVO_PROGRAM_SIZEOF 12 #define RTV_API_ZIVO_URL \ "http://api." RTV_SLD "/ava/getLiveStream/tv.%." \ @@ -122,6 +122,16 @@ #define RTV_FREE(param) do { free(param); param = NULL; } while (0) #define RTV_HTTP_SUCCESS(koda) ((koda / 100) == 2) /* če je koda 2xx */ #define RTV_ZIVO_P_DOLZINA 10 +#define RTV_INT_V_SLO(niz) /* niz naj bo http url */ \ + if (strstr(niz, "-int")) { /* je strstr-jati dvakrat potratno? */ \ + strncpy(strstr(niz, "-int"), "-slo", strlen("-slo")); /* nast. pov. \/ */ \ + niz[8]--; /* pri medn. je štev. ponav. za 1 večja */ /* kot mednarodno */ \ + RTV_NAPISI(OPOZORILO, "izven Slovenije prenašate vsebino RTVSLO. Če ne " \ + "plačujete RTV prispevka ali če za to niste pooblaščeni, KRŠITE" \ + "AVTORSKE PRAVICE in STE V PREKRŠKU - v tem primeru nemudoma " \ + "prenehajte uporabljati program s Ctrl-C! naslovi so bili spremenjeni, " \ + "tako da bo prenos še vedno deloval, če pa ne, pa poglejte navodila."); \ + } struct meta_oddaja { size_t naslov_sizeof; char * naslov; /* Vreme ob 22h */ @@ -442,6 +452,7 @@ int rtv_meta_izpolni(struct meta_oddaja * m) { int rtv_zivo_izpolni(struct rtv_zivo_meta * m) { #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wnonnull" +#pragma GCC diagnostic ignored "-Wstringop-truncation" /* za RTV_INT_V_SLO(u) */ int returnstatus = 0; FILE * odgstream; char * odg; @@ -479,6 +490,9 @@ int rtv_zivo_izpolni(struct rtv_zivo_meta * m) { /* če obstaja ?DVR na koncu, bo vsebina gzipana, to nas samo moti */ strchrnul(m->seznam_predvajanja_url, '?')[0] = '\0'; /* odstrani parametre */ RTV_HTTPS_V_HTTP(m->seznam_predvajanja_url); +#ifndef RTV_NASTAVITEV_BREZ_LOKACIJSKIH_SPREMEMB + RTV_INT_V_SLO(m->seznam_predvajanja_url); +#endif rewind(odgstream); http_get(m->seznam_predvajanja_url, odgstream); for (i = 0; i < ftell(odgstream); i++) { @@ -498,6 +512,9 @@ int rtv_zivo_izpolni(struct rtv_zivo_meta * m) { break; /* spet, potrebujemo samo prvi t. i. "chunklist". */ } } +#ifndef RTV_NASTAVITEV_BREZ_LOKACIJSKIH_SPREMEMB + RTV_INT_V_SLO(m->kazalo_url); +#endif RTV_NAPISI(HROSC, "kazalo_url => %s", m->kazalo_url); rewind(odgstream); returnstatus = http_get(m->kazalo_url, odgstream); @@ -557,6 +574,9 @@ int rtv_zivo_izpolni(struct rtv_zivo_meta * m) { memmove(e+2, e+strlen(temp), strlen(temp)+1); /* naredimo prostor 2 */ e[0] = '%'; e[1] = 'u'; /* napišemo format v prostorček */ RTV_HTTPS_V_HTTP(m->kos_format); +#ifndef RTV_NASTAVITEV_BREZ_LOKACIJSKIH_SPREMEMB + RTV_INT_V_SLO(m->kos_format); +#endif RTV_NAPISI(HROSC, "m->kos_format => %s", m->kos_format); } e = strrchr(m->kos_format+strlen("http://"), '/')+1; @@ -585,7 +605,7 @@ int rtv_zivo_izpolni(struct rtv_zivo_meta * m) { int main (int argc, char ** argv) { if (argc < 1+1) { - fprintf(stderr, "preberi README.md pred uporabo programa, saj vsebuje" + fprintf(stderr, "preberi README.md pred uporabo programa, saj vsebuje " "navodila in ostalo.\n"); return 1; } @@ -854,6 +874,14 @@ int main (int argc, char ** argv) { fclose(fd); returnstatus = 0; } + fprintf(stdout, "program: %s\nsedanjost: %u\nprvi: %u\ndolzina: %u\n" + "diskrepanca: %u\nprenesenih_kosov_preteklost: %u\n" + "prenesenih_kosov_prihodnost: %u\npreteklost: %u\nprihodnost: %u\n" + "seznam_predvajanja_url: %s\nkazalo_url: %s\nkos_format: %s\n" + "api_url: %s\n", z->program, z->sedanjost, z->prvi, z->dolzina, + z->diskrepanca, z->prenesenih_kosov_preteklost, + z->prenesenih_kosov_prihodnost, z->preteklost, z->prihodnost, + z->seznam_predvajanja_url, z->kazalo_url, z->kos_format, z->api_url); fclose(fd2); break; default: |