summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--README.md14
-rwxr-xr-xrtv4d-dlbin52776 -> 67272 bytes
-rw-r--r--rtv4d-dl.c32
3 files changed, 42 insertions, 4 deletions
diff --git a/README.md b/README.md
index 0260c12..10aac13 100644
--- a/README.md
+++ b/README.md
@@ -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.
diff --git a/rtv4d-dl b/rtv4d-dl
index 0c62ff1..c780a48 100755
--- a/rtv4d-dl
+++ b/rtv4d-dl
Binary files differ
diff --git a/rtv4d-dl.c b/rtv4d-dl.c
index 6da6a61..c4343bd 100644
--- a/rtv4d-dl.c
+++ b/rtv4d-dl.c
@@ -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: