Skip to content

Commit

Permalink
#938 optimize wdr urls
Browse files Browse the repository at this point in the history
  • Loading branch information
pidoubleyou committed Nov 21, 2023
1 parent 2d6eb39 commit a4dd4d8
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 7 deletions.
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
package de.mediathekview.mserver.crawler.ard;

import de.mediathekview.mserver.base.utils.UrlUtils;
import de.mediathekview.mserver.crawler.basic.AbstractCrawler;

import java.util.HashMap;
import java.util.Map;
import java.util.Optional;

public class ArdUrlOptimizer {

Expand Down Expand Up @@ -38,17 +39,40 @@ public ArdUrlOptimizer(AbstractCrawler aCrawler) {
}

public String optimizeHdUrl(final String url) {
for (Map.Entry<String, String[]> entry : HD_OPTIMIZE.entrySet()) {
if (url.contains(entry.getKey())) {
for (String optimizeFragment : entry.getValue()) {
final String optimizedUrl = url.replace(entry.getKey(), optimizeFragment);
if (crawler.requestUrlExists(optimizedUrl)) {
return optimizedUrl;
String fullHdUrl = "";
if (url.contains("wdrmedien")) {
fullHdUrl = determineWdrFullHdUrl(url);
} else {
for (Map.Entry<String, String[]> entry : HD_OPTIMIZE.entrySet()) {
if (url.contains(entry.getKey())) {
for (String optimizeFragment : entry.getValue()) {
fullHdUrl = url.replace(entry.getKey(), optimizeFragment);
}
}
}
}

if (!fullHdUrl.isEmpty() && crawler.requestUrlExists(fullHdUrl)) {
return fullHdUrl;
}

return url;
}

/**
* wdr urls uses the following pattern: the last part of the filename determines the quality this
* is the actual order: 1920, 480, 640, 960, 1280 to determine the 1920-url by the 1280-url
* substract 4 example: 1280: https://wdrmedien-a.akamaihd.net/.../2625725_54085881.mp4 1920:
* https://wdrmedien-a.akamaihd.net/.../2625725_54085877.mp4
*/
private String determineWdrFullHdUrl(String url) {
final Optional<String> fileName = UrlUtils.getFileName(url);
if (fileName.isPresent()) {
final String s = fileName.get();
final String substring = s.substring(s.indexOf("_") + 1).replace(".mp4", "");
final int hdInt = Integer.parseInt(substring) - 4;
return url.replace(substring, Integer.toString(hdInt));
}
return url;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package de.mediathekview.mserver.crawler.ard;

import static org.assertj.core.api.Assertions.assertThat;

import de.mediathekview.mserver.crawler.ard.tasks.ArdTaskTestBase;
import org.junit.jupiter.api.Test;

class ArdUrlOptimizerTest extends ArdTaskTestBase {

@Test
void optimizedHdUrlNotAvailable() {
runTest("/br_film_X.mp4", "/br_film_HD.mp4", 404, "/br_film_X.mp4");
}

@Test
void optimizedHdUrlBr() {
runTest("/br_film_X.mp4", "/br_film_HD.mp4", 200, "/br_film_HD.mp4");
}

@Test
void optimizedHdUrlWdr() {
// original host wdrmedien-a.akamaihd.net used in path because wdrmedien is used to filter wdr urls
runTest(
"/wdrmedien-a.akamaihd.net/medp/ondemand/de/fsk0/262/2625725/2625725_54085881.mp4",
"/wdrmedien-a.akamaihd.net/medp/ondemand/de/fsk0/262/2625725/2625725_54085877.mp4",
200,
"/wdrmedien-a.akamaihd.net/medp/ondemand/de/fsk0/262/2625725/2625725_54085877.mp4");
}

private void runTest(String url, String optimizedUrl, int headResponseCode, String expectedUrl) {
final String baseUrl = getWireMockBaseUrlSafe();
setupHeadResponse(optimizedUrl, headResponseCode);

ArdUrlOptimizer optimizer = new ArdUrlOptimizer(createCrawler());
final String actualUrl = optimizer.optimizeHdUrl(baseUrl + url);
assertThat(actualUrl).isEqualTo(baseUrl + expectedUrl);
}
}

0 comments on commit a4dd4d8

Please sign in to comment.