[PeerTube] Support /a/ and /c/ short links
This commit is contained in:
parent
599a91c88c
commit
e0b8e142fc
2 changed files with 56 additions and 23 deletions
|
@ -10,7 +10,7 @@ import java.util.List;
|
||||||
public class PeertubeChannelLinkHandlerFactory extends ListLinkHandlerFactory {
|
public class PeertubeChannelLinkHandlerFactory extends ListLinkHandlerFactory {
|
||||||
|
|
||||||
private static final PeertubeChannelLinkHandlerFactory instance = new PeertubeChannelLinkHandlerFactory();
|
private static final PeertubeChannelLinkHandlerFactory instance = new PeertubeChannelLinkHandlerFactory();
|
||||||
private static final String ID_PATTERN = "(accounts|video-channels)/([^/?&#]*)";
|
private static final String ID_PATTERN = "((accounts|a)|(video-channels|c))/([^/?&#]*)";
|
||||||
public static final String API_ENDPOINT = "/api/v1/";
|
public static final String API_ENDPOINT = "/api/v1/";
|
||||||
|
|
||||||
public static PeertubeChannelLinkHandlerFactory getInstance() {
|
public static PeertubeChannelLinkHandlerFactory getInstance() {
|
||||||
|
@ -19,7 +19,7 @@ public class PeertubeChannelLinkHandlerFactory extends ListLinkHandlerFactory {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getId(String url) throws ParsingException {
|
public String getId(String url) throws ParsingException {
|
||||||
return Parser.matchGroup(ID_PATTERN, url, 0);
|
return fixId(Parser.matchGroup(ID_PATTERN, url, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -31,7 +31,7 @@ public class PeertubeChannelLinkHandlerFactory extends ListLinkHandlerFactory {
|
||||||
public String getUrl(String id, List<String> contentFilter, String sortFilter, String baseUrl)
|
public String getUrl(String id, List<String> contentFilter, String sortFilter, String baseUrl)
|
||||||
throws ParsingException {
|
throws ParsingException {
|
||||||
if (id.matches(ID_PATTERN)) {
|
if (id.matches(ID_PATTERN)) {
|
||||||
return baseUrl + "/" + id;
|
return baseUrl + "/" + fixId(id);
|
||||||
} else {
|
} else {
|
||||||
// This is needed for compatibility with older versions were we didn't support video channels yet
|
// This is needed for compatibility with older versions were we didn't support video channels yet
|
||||||
return baseUrl + "/accounts/" + id;
|
return baseUrl + "/accounts/" + id;
|
||||||
|
@ -40,6 +40,28 @@ public class PeertubeChannelLinkHandlerFactory extends ListLinkHandlerFactory {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onAcceptUrl(String url) {
|
public boolean onAcceptUrl(String url) {
|
||||||
return url.contains("/accounts/") || url.contains("/video-channels/");
|
return url.contains("/accounts/") || url.contains("/a/")
|
||||||
|
|| url.contains("/video-channels/") || url.contains("/c/");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fix id
|
||||||
|
*
|
||||||
|
* <p>
|
||||||
|
* a/:accountName and c/:channelName ids are supported
|
||||||
|
* by the PeerTube web client (>= v3.3.0)
|
||||||
|
* but not by the API.
|
||||||
|
* </p>
|
||||||
|
*
|
||||||
|
* @param id the id to fix
|
||||||
|
* @return the fixed id
|
||||||
|
*/
|
||||||
|
private String fixId(String id) {
|
||||||
|
if (id.startsWith("a/")) {
|
||||||
|
id = "accounts" + id.substring(1);
|
||||||
|
} else if (id.startsWith("c/")) {
|
||||||
|
id = "video-channels" + id.substring(1);
|
||||||
|
}
|
||||||
|
return id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,44 +20,55 @@ public class PeertubeChannelLinkHandlerFactoryTest {
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void setUp() {
|
public static void setUp() {
|
||||||
PeerTube.setInstance(new PeertubeInstance("https://peertube.mastodon.host", "PeerTube on Mastodon.host"));
|
PeerTube.setInstance(new PeertubeInstance("https://peertube.stream", "PeerTube on peertube.stream"));
|
||||||
linkHandler = PeertubeChannelLinkHandlerFactory.getInstance();
|
linkHandler = PeertubeChannelLinkHandlerFactory.getInstance();
|
||||||
NewPipe.init(DownloaderTestImpl.getInstance());
|
NewPipe.init(DownloaderTestImpl.getInstance());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void acceptUrlTest() throws ParsingException {
|
public void acceptUrlTest() throws ParsingException {
|
||||||
assertTrue(linkHandler.acceptUrl("https://peertube.mastodon.host/accounts/kranti@videos.squat.net"));
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/accounts/kranti@videos.squat.net"));
|
||||||
assertTrue(linkHandler.acceptUrl("https://peertube.mastodon.host/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa/videos"));
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/a/kranti@videos.squat.net"));
|
||||||
assertTrue(linkHandler.acceptUrl("https://peertube.mastodon.host/api/v1/accounts/kranti@videos.squat.net/videos"));
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/api/v1/accounts/kranti@videos.squat.net/videos"));
|
||||||
assertTrue(linkHandler.acceptUrl("https://peertube.mastodon.host/api/v1/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa"));
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/video-channels/kranti_channel@videos.squat.net/videos"));
|
||||||
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/c/kranti_channel@videos.squat.net/videos"));
|
||||||
|
assertTrue(linkHandler.acceptUrl("https://peertube.stream/api/v1/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getId() throws ParsingException {
|
public void getId() throws ParsingException {
|
||||||
assertEquals("accounts/kranti@videos.squat.net",
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/accounts/kranti@videos.squat.net").getId());
|
linkHandler.fromUrl("https://peertube.stream/accounts/kranti@videos.squat.net").getId());
|
||||||
assertEquals("accounts/kranti@videos.squat.net",
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/accounts/kranti@videos.squat.net/videos").getId());
|
linkHandler.fromUrl("https://peertube.stream/a/kranti@videos.squat.net").getId());
|
||||||
assertEquals("video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa",
|
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa/videos").getId());
|
|
||||||
assertEquals("accounts/kranti@videos.squat.net",
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/api/v1/accounts/kranti@videos.squat.net").getId());
|
linkHandler.fromUrl("https://peertube.stream/accounts/kranti@videos.squat.net/videos").getId());
|
||||||
assertEquals("accounts/kranti@videos.squat.net",
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/api/v1/accounts/kranti@videos.squat.net/videos").getId());
|
linkHandler.fromUrl("https://peertube.stream/a/kranti@videos.squat.net/videos").getId());
|
||||||
assertEquals("video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa",
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/api/v1/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa").getId());
|
linkHandler.fromUrl("https://peertube.stream/api/v1/accounts/kranti@videos.squat.net").getId());
|
||||||
|
assertEquals("accounts/kranti@videos.squat.net",
|
||||||
|
linkHandler.fromUrl("https://peertube.stream/api/v1/accounts/kranti@videos.squat.net/videos").getId());
|
||||||
|
|
||||||
|
assertEquals("video-channels/kranti_channel@videos.squat.net",
|
||||||
|
linkHandler.fromUrl("https://peertube.stream/video-channels/kranti_channel@videos.squat.net/videos").getId());
|
||||||
|
assertEquals("video-channels/kranti_channel@videos.squat.net",
|
||||||
|
linkHandler.fromUrl("https://peertube.stream/c/kranti_channel@videos.squat.net/videos").getId());
|
||||||
|
assertEquals("video-channels/kranti_channel@videos.squat.net",
|
||||||
|
linkHandler.fromUrl("https://peertube.stream/c/kranti_channel@videos.squat.net/video-playlists").getId());
|
||||||
|
assertEquals("video-channels/kranti_channel@videos.squat.net",
|
||||||
|
linkHandler.fromUrl("https://peertube.stream/api/v1/video-channels/kranti_channel@videos.squat.net").getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getUrl() throws ParsingException {
|
public void getUrl() throws ParsingException {
|
||||||
assertEquals("https://peertube.mastodon.host/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa",
|
assertEquals("https://peertube.stream/video-channels/kranti_channel@videos.squat.net",
|
||||||
linkHandler.fromId("video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa").getUrl());
|
linkHandler.fromId("video-channels/kranti_channel@videos.squat.net").getUrl());
|
||||||
assertEquals("https://peertube.mastodon.host/accounts/kranti@videos.squat.net",
|
assertEquals("https://peertube.stream/accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromId("accounts/kranti@videos.squat.net").getUrl());
|
linkHandler.fromId("accounts/kranti@videos.squat.net").getUrl());
|
||||||
assertEquals("https://peertube.mastodon.host/accounts/kranti@videos.squat.net",
|
assertEquals("https://peertube.stream/accounts/kranti@videos.squat.net",
|
||||||
linkHandler.fromId("kranti@videos.squat.net").getUrl());
|
linkHandler.fromId("kranti@videos.squat.net").getUrl());
|
||||||
assertEquals("https://peertube.mastodon.host/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa",
|
assertEquals("https://peertube.stream/video-channels/kranti_channel@videos.squat.net",
|
||||||
linkHandler.fromUrl("https://peertube.mastodon.host/api/v1/video-channels/7682d9f2-07be-4622-862e-93ec812e2ffa").getUrl());
|
linkHandler.fromUrl("https://peertube.stream/api/v1/video-channels/kranti_channel@videos.squat.net").getUrl());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue