feedscout 1.8.1 → 2.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/common/discover/utils.d.ts +2 -3
- package/dist/common/locales.js +214 -10
- package/dist/common/types.d.ts +2 -1
- package/dist/common/uris/feed/types.d.ts +2 -2
- package/dist/common/uris/html/types.d.ts +4 -4
- package/dist/common/utils.d.ts +6 -4
- package/dist/common/utils.js +12 -3
- package/dist/feeds/defaults.d.ts +2 -1
- package/dist/feeds/defaults.js +116 -9
- package/dist/feeds/extractors.js +2 -2
- package/dist/feeds/platform/handlers/acast.js +26 -0
- package/dist/feeds/platform/handlers/ameblo.js +36 -0
- package/dist/feeds/platform/handlers/applePodcasts.js +1 -1
- package/dist/feeds/platform/handlers/arena.js +42 -0
- package/dist/feeds/platform/handlers/artstation.js +52 -0
- package/dist/feeds/platform/handlers/audioboom.js +23 -0
- package/dist/feeds/platform/handlers/bearblog.js +45 -0
- package/dist/feeds/platform/handlers/behance.js +7 -0
- package/dist/feeds/platform/handlers/blogspot.js +38 -2
- package/dist/feeds/platform/handlers/bookwyrm.js +48 -0
- package/dist/feeds/platform/handlers/buttondown.js +43 -0
- package/dist/feeds/platform/handlers/buzzsprout.js +22 -0
- package/dist/feeds/platform/handlers/codeberg.js +5 -5
- package/dist/feeds/platform/handlers/dailymotion.js +16 -0
- package/dist/feeds/platform/handlers/deviantart.js +25 -6
- package/dist/feeds/platform/handlers/devto.js +8 -0
- package/dist/feeds/platform/handlers/discourse.js +70 -0
- package/dist/feeds/platform/handlers/dreamwidth.js +48 -0
- package/dist/feeds/platform/handlers/exblog.js +35 -0
- package/dist/feeds/platform/handlers/fireside.js +24 -0
- package/dist/feeds/platform/handlers/friendica.js +44 -0
- package/dist/feeds/platform/handlers/ghost.js +30 -0
- package/dist/feeds/platform/handlers/github.js +6 -0
- package/dist/feeds/platform/handlers/githubGist.js +16 -5
- package/dist/feeds/platform/handlers/gitlab.js +31 -13
- package/dist/feeds/platform/handlers/goodreads.js +18 -8
- package/dist/feeds/platform/handlers/hackernews.js +21 -0
- package/dist/feeds/platform/handlers/hashnode.js +1 -1
- package/dist/feeds/platform/handlers/hatenablog.js +4 -1
- package/dist/feeds/platform/handlers/hearthis.js +32 -0
- package/dist/feeds/platform/handlers/heyWorld.js +18 -0
- package/dist/feeds/platform/handlers/insanejournal.js +69 -0
- package/dist/feeds/platform/handlers/itchio.js +24 -1
- package/dist/feeds/platform/handlers/lemmy.js +46 -4
- package/dist/feeds/platform/handlers/letterboxd.js +4 -0
- package/dist/feeds/platform/handlers/libsyn.js +25 -0
- package/dist/feeds/platform/handlers/listed.js +20 -0
- package/dist/feeds/platform/handlers/livejournal.js +68 -0
- package/dist/feeds/platform/handlers/mastodon.js +32 -0
- package/dist/feeds/platform/handlers/mataroa.js +16 -0
- package/dist/feeds/platform/handlers/medium.js +2 -2
- package/dist/feeds/platform/handlers/microblog.js +55 -0
- package/dist/feeds/platform/handlers/misskey.js +40 -0
- package/dist/feeds/platform/handlers/myanimelist.js +43 -0
- package/dist/feeds/platform/handlers/naverBlog.js +21 -0
- package/dist/feeds/platform/handlers/nebula.js +68 -0
- package/dist/feeds/platform/handlers/note.js +53 -0
- package/dist/feeds/platform/handlers/observable.js +34 -0
- package/dist/feeds/platform/handlers/odysee.js +20 -0
- package/dist/feeds/platform/handlers/pagecord.js +16 -0
- package/dist/feeds/platform/handlers/paragraph.js +1 -2
- package/dist/feeds/platform/handlers/pika.js +35 -0
- package/dist/feeds/platform/handlers/pinterest.js +13 -0
- package/dist/feeds/platform/handlers/pixelfed.js +46 -0
- package/dist/feeds/platform/handlers/pleroma.js +34 -0
- package/dist/feeds/platform/handlers/podbean.js +29 -0
- package/dist/feeds/platform/handlers/podigee.js +29 -0
- package/dist/feeds/platform/handlers/posthaven.js +24 -0
- package/dist/feeds/platform/handlers/prose.js +26 -0
- package/dist/feeds/platform/handlers/qiita.js +58 -0
- package/dist/feeds/platform/handlers/reddit.js +83 -9
- package/dist/feeds/platform/handlers/rssCom.js +20 -0
- package/dist/feeds/platform/handlers/seesaa.js +22 -0
- package/dist/feeds/platform/handlers/sourceforge.js +37 -4
- package/dist/feeds/platform/handlers/spreaker.js +21 -0
- package/dist/feeds/platform/handlers/stackExchange.js +26 -2
- package/dist/feeds/platform/handlers/steam.js +7 -0
- package/dist/feeds/platform/handlers/tildes.js +41 -0
- package/dist/feeds/platform/handlers/tistory.js +16 -0
- package/dist/feeds/platform/handlers/transistor.js +29 -0
- package/dist/feeds/platform/handlers/velog.js +24 -0
- package/dist/feeds/platform/handlers/vimeo.js +6 -0
- package/dist/feeds/platform/handlers/weblogLol.js +26 -0
- package/dist/feeds/platform/handlers/weebly.js +25 -0
- package/dist/feeds/platform/handlers/wordpress.js +173 -28
- package/dist/feeds/platform/handlers/writeas.js +51 -0
- package/dist/feeds/platform/handlers/ximalaya.js +1 -1
- package/dist/feeds/platform/handlers/youtube.js +4 -1
- package/dist/feeds/platform/handlers/zenn.js +54 -0
- package/dist/feeds.d.ts +2 -2
- package/dist/feeds.js +2 -2
- package/dist/utils.d.ts +2 -1
- package/package.json +24 -64
- package/dist/blogrolls/defaults.cjs +0 -51
- package/dist/blogrolls/defaults.d.cts +0 -17
- package/dist/blogrolls/extractors.cjs +0 -21
- package/dist/blogrolls/extractors.d.cts +0 -7
- package/dist/blogrolls/index.cjs +0 -25
- package/dist/blogrolls/index.d.cts +0 -7
- package/dist/blogrolls/types.d.cts +0 -6
- package/dist/blogrolls.cjs +0 -13
- package/dist/blogrolls.d.cts +0 -4
- package/dist/common/discover/defaults.cjs +0 -46
- package/dist/common/discover/defaults.d.cts +0 -6
- package/dist/common/discover/index.cjs +0 -105
- package/dist/common/discover/utils.cjs +0 -101
- package/dist/common/discover/utils.d.cts +0 -6
- package/dist/common/locales.cjs +0 -144
- package/dist/common/types.cjs +0 -10
- package/dist/common/types.d.cts +0 -89
- package/dist/common/uris/feed/index.cjs +0 -12
- package/dist/common/uris/feed/index.d.cts +0 -6
- package/dist/common/uris/feed/types.d.cts +0 -9
- package/dist/common/uris/guess/index.cjs +0 -8
- package/dist/common/uris/guess/index.d.cts +0 -7
- package/dist/common/uris/guess/types.d.cts +0 -10
- package/dist/common/uris/guess/utils.cjs +0 -42
- package/dist/common/uris/guess/utils.d.cts +0 -8
- package/dist/common/uris/headers/index.cjs +0 -26
- package/dist/common/uris/headers/index.d.cts +0 -6
- package/dist/common/uris/headers/types.d.cts +0 -9
- package/dist/common/uris/html/handlers.cjs +0 -45
- package/dist/common/uris/html/index.cjs +0 -19
- package/dist/common/uris/html/index.d.cts +0 -6
- package/dist/common/uris/html/types.d.cts +0 -12
- package/dist/common/uris/index.cjs +0 -32
- package/dist/common/uris/platform/index.cjs +0 -10
- package/dist/common/uris/platform/index.d.cts +0 -7
- package/dist/common/uris/platform/types.d.cts +0 -13
- package/dist/common/utils.cjs +0 -89
- package/dist/common/utils.d.cts +0 -10
- package/dist/favicons/defaults.cjs +0 -65
- package/dist/favicons/defaults.d.cts +0 -18
- package/dist/favicons/extractors.cjs +0 -25
- package/dist/favicons/extractors.d.cts +0 -7
- package/dist/favicons/index.cjs +0 -29
- package/dist/favicons/index.d.cts +0 -7
- package/dist/favicons/platform/handlers/bluesky.cjs +0 -27
- package/dist/favicons/platform/handlers/codeberg.cjs +0 -19
- package/dist/favicons/platform/handlers/deviantart.cjs +0 -29
- package/dist/favicons/platform/handlers/devto.cjs +0 -31
- package/dist/favicons/platform/handlers/github.cjs +0 -19
- package/dist/favicons/platform/handlers/githubGist.cjs +0 -19
- package/dist/favicons/platform/handlers/gitlab.cjs +0 -38
- package/dist/favicons/platform/handlers/lobsters.cjs +0 -21
- package/dist/favicons/platform/handlers/mastodon.cjs +0 -40
- package/dist/favicons/platform/handlers/reddit.cjs +0 -42
- package/dist/favicons/platform/handlers/sourceforge.cjs +0 -21
- package/dist/favicons/platform/handlers/tumblr.cjs +0 -16
- package/dist/favicons/types.d.cts +0 -4
- package/dist/favicons/utils.cjs +0 -10
- package/dist/favicons.cjs +0 -12
- package/dist/favicons.d.cts +0 -4
- package/dist/feeds/defaults.cjs +0 -178
- package/dist/feeds/defaults.d.cts +0 -20
- package/dist/feeds/extractors.cjs +0 -46
- package/dist/feeds/extractors.d.cts +0 -7
- package/dist/feeds/index.cjs +0 -26
- package/dist/feeds/index.d.cts +0 -7
- package/dist/feeds/platform/handlers/applePodcasts.cjs +0 -26
- package/dist/feeds/platform/handlers/behance.cjs +0 -49
- package/dist/feeds/platform/handlers/blogspot.cjs +0 -36
- package/dist/feeds/platform/handlers/bluesky.cjs +0 -20
- package/dist/feeds/platform/handlers/codeberg.cjs +0 -69
- package/dist/feeds/platform/handlers/csdn.cjs +0 -20
- package/dist/feeds/platform/handlers/dailymotion.cjs +0 -70
- package/dist/feeds/platform/handlers/deviantart.cjs +0 -66
- package/dist/feeds/platform/handlers/devto.cjs +0 -50
- package/dist/feeds/platform/handlers/douban.cjs +0 -56
- package/dist/feeds/platform/handlers/github.cjs +0 -116
- package/dist/feeds/platform/handlers/githubGist.cjs +0 -45
- package/dist/feeds/platform/handlers/gitlab.cjs +0 -80
- package/dist/feeds/platform/handlers/goodreads.cjs +0 -39
- package/dist/feeds/platform/handlers/hashnode.cjs +0 -16
- package/dist/feeds/platform/handlers/hatenablog.cjs +0 -53
- package/dist/feeds/platform/handlers/itchio.cjs +0 -88
- package/dist/feeds/platform/handlers/kickstarter.cjs +0 -22
- package/dist/feeds/platform/handlers/lemmy.cjs +0 -46
- package/dist/feeds/platform/handlers/letterboxd.cjs +0 -42
- package/dist/feeds/platform/handlers/lobsters.cjs +0 -57
- package/dist/feeds/platform/handlers/mastodon.cjs +0 -42
- package/dist/feeds/platform/handlers/medium.cjs +0 -68
- package/dist/feeds/platform/handlers/paragraph.cjs +0 -21
- package/dist/feeds/platform/handlers/pinterest.cjs +0 -44
- package/dist/feeds/platform/handlers/producthunt.cjs +0 -29
- package/dist/feeds/platform/handlers/reddit.cjs +0 -75
- package/dist/feeds/platform/handlers/soundcloud.cjs +0 -39
- package/dist/feeds/platform/handlers/sourceforge.cjs +0 -20
- package/dist/feeds/platform/handlers/stackExchange.cjs +0 -40
- package/dist/feeds/platform/handlers/steam.cjs +0 -28
- package/dist/feeds/platform/handlers/substack.cjs +0 -23
- package/dist/feeds/platform/handlers/tumblr.cjs +0 -24
- package/dist/feeds/platform/handlers/v2ex.cjs +0 -35
- package/dist/feeds/platform/handlers/vimeo.cjs +0 -69
- package/dist/feeds/platform/handlers/wordpress.cjs +0 -64
- package/dist/feeds/platform/handlers/wpengine.cjs +0 -10
- package/dist/feeds/platform/handlers/ximalaya.cjs +0 -20
- package/dist/feeds/platform/handlers/youtube.cjs +0 -94
- package/dist/feeds/types.d.cts +0 -9
- package/dist/feeds.cjs +0 -15
- package/dist/feeds.d.cts +0 -4
- package/dist/hubs/discover/index.cjs +0 -30
- package/dist/hubs/discover/index.d.cts +0 -7
- package/dist/hubs/discover/types.d.cts +0 -15
- package/dist/hubs/feed/index.cjs +0 -32
- package/dist/hubs/headers/index.cjs +0 -17
- package/dist/hubs/html/index.cjs +0 -28
- package/dist/hubs.cjs +0 -0
- package/dist/hubs.d.cts +0 -2
- package/dist/index.cjs +0 -13
- package/dist/index.d.cts +0 -8
- package/dist/methods.cjs +0 -15
- package/dist/methods.d.cts +0 -7
- package/dist/utils.cjs +0 -9
- package/dist/utils.d.cts +0 -2
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { composeHint } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/pleroma.ts
|
|
3
|
+
const profileRegex = /^\/users\/([^/]+)/;
|
|
4
|
+
const pleromaApiRegex = /\/api\/pleroma\//i;
|
|
5
|
+
const isPleromaHtml = (content) => {
|
|
6
|
+
return pleromaApiRegex.test(content);
|
|
7
|
+
};
|
|
8
|
+
const pleromaHandler = {
|
|
9
|
+
match: (url, content) => {
|
|
10
|
+
try {
|
|
11
|
+
if (!content || !isPleromaHtml(content)) return false;
|
|
12
|
+
const { pathname } = new URL(url);
|
|
13
|
+
return profileRegex.test(pathname);
|
|
14
|
+
} catch {}
|
|
15
|
+
return false;
|
|
16
|
+
},
|
|
17
|
+
resolve: (url) => {
|
|
18
|
+
try {
|
|
19
|
+
const { origin, pathname } = new URL(url);
|
|
20
|
+
const match = pathname.match(profileRegex);
|
|
21
|
+
if (!match?.[1]) return [];
|
|
22
|
+
return [{
|
|
23
|
+
uri: `${origin}/users/${match[1]}/feed.atom`,
|
|
24
|
+
hint: composeHint("pleroma:posts")
|
|
25
|
+
}, {
|
|
26
|
+
uri: `${origin}/users/${match[1]}/feed.rss`,
|
|
27
|
+
hint: composeHint("pleroma:posts-rss")
|
|
28
|
+
}];
|
|
29
|
+
} catch {}
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
//#endregion
|
|
34
|
+
export { pleromaHandler };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/podbean.ts
|
|
3
|
+
const domainSuffix = /\.podbean\.com$/i;
|
|
4
|
+
const reservedSlugs = new Set([
|
|
5
|
+
"www",
|
|
6
|
+
"feed",
|
|
7
|
+
"pbcdn1",
|
|
8
|
+
"sponsorship",
|
|
9
|
+
"podads",
|
|
10
|
+
"help",
|
|
11
|
+
"blog",
|
|
12
|
+
"support"
|
|
13
|
+
]);
|
|
14
|
+
const podbeanHandler = {
|
|
15
|
+
match: (url) => {
|
|
16
|
+
if (!isSubdomainOf(url, "podbean.com")) return false;
|
|
17
|
+
const slug = new URL(url).hostname.toLowerCase().replace(domainSuffix, "");
|
|
18
|
+
return !reservedSlugs.has(slug);
|
|
19
|
+
},
|
|
20
|
+
resolve: (url) => {
|
|
21
|
+
const { hostname } = new URL(url);
|
|
22
|
+
return [{
|
|
23
|
+
uri: `https://feed.podbean.com/${hostname.replace(domainSuffix, "")}/feed.xml`,
|
|
24
|
+
hint: composeHint("podbean:podcast")
|
|
25
|
+
}];
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
//#endregion
|
|
29
|
+
export { podbeanHandler };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/podigee.ts
|
|
3
|
+
const domainSuffix = /\.podigee\.io$/i;
|
|
4
|
+
const reservedSlugs = new Set([
|
|
5
|
+
"www",
|
|
6
|
+
"app",
|
|
7
|
+
"help",
|
|
8
|
+
"hilfe",
|
|
9
|
+
"blog",
|
|
10
|
+
"status",
|
|
11
|
+
"player",
|
|
12
|
+
"cdn"
|
|
13
|
+
]);
|
|
14
|
+
const podigeeHandler = {
|
|
15
|
+
match: (url) => {
|
|
16
|
+
if (!isSubdomainOf(url, "podigee.io")) return false;
|
|
17
|
+
const slug = new URL(url).hostname.toLowerCase().replace(domainSuffix, "");
|
|
18
|
+
return !reservedSlugs.has(slug);
|
|
19
|
+
},
|
|
20
|
+
resolve: (url) => {
|
|
21
|
+
const { origin } = new URL(url);
|
|
22
|
+
return [{
|
|
23
|
+
uri: `${origin}/feed/mp3`,
|
|
24
|
+
hint: composeHint("podigee:podcast")
|
|
25
|
+
}];
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
//#endregion
|
|
29
|
+
export { podigeeHandler };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/posthaven.ts
|
|
3
|
+
const tagRegex = /^\/tag\/([^/]+)/;
|
|
4
|
+
const posthavenHandler = {
|
|
5
|
+
match: (url) => {
|
|
6
|
+
return isSubdomainOf(url, "posthaven.com");
|
|
7
|
+
},
|
|
8
|
+
resolve: (url) => {
|
|
9
|
+
const { origin, pathname } = new URL(url);
|
|
10
|
+
const uris = [];
|
|
11
|
+
const tagMatch = pathname.match(tagRegex);
|
|
12
|
+
if (tagMatch?.[1]) uris.push({
|
|
13
|
+
uri: `${origin}/tag/${tagMatch[1]}.atom`,
|
|
14
|
+
hint: composeHint("posthaven:tag")
|
|
15
|
+
});
|
|
16
|
+
uris.push({
|
|
17
|
+
uri: `${origin}/posts.atom`,
|
|
18
|
+
hint: composeHint("posthaven:posts")
|
|
19
|
+
});
|
|
20
|
+
return uris;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
//#endregion
|
|
24
|
+
export { posthavenHandler };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { composeHint, isHostOf, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/prose.ts
|
|
3
|
+
const apexHosts = ["prose.sh", "www.prose.sh"];
|
|
4
|
+
const proseHandler = {
|
|
5
|
+
match: (url) => {
|
|
6
|
+
return isSubdomainOf(url, "prose.sh") || isHostOf(url, apexHosts);
|
|
7
|
+
},
|
|
8
|
+
resolve: (url) => {
|
|
9
|
+
const { origin, searchParams } = new URL(url);
|
|
10
|
+
if (isHostOf(url, apexHosts)) return [{
|
|
11
|
+
uri: "https://prose.sh/rss",
|
|
12
|
+
hint: composeHint("prose:discovery")
|
|
13
|
+
}];
|
|
14
|
+
const tag = searchParams.get("tag");
|
|
15
|
+
if (tag) return [{
|
|
16
|
+
uri: `${origin}/rss?tag=${encodeURIComponent(tag)}`,
|
|
17
|
+
hint: composeHint("prose:tag")
|
|
18
|
+
}];
|
|
19
|
+
return [{
|
|
20
|
+
uri: `${origin}/rss`,
|
|
21
|
+
hint: composeHint("prose:blog")
|
|
22
|
+
}];
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
//#endregion
|
|
26
|
+
export { proseHandler };
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { composeHint, isAnyOf, isHostOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/qiita.ts
|
|
3
|
+
const hosts = ["qiita.com", "www.qiita.com"];
|
|
4
|
+
const excludedPaths = [
|
|
5
|
+
"about",
|
|
6
|
+
"api",
|
|
7
|
+
"login",
|
|
8
|
+
"official-columns",
|
|
9
|
+
"organizations",
|
|
10
|
+
"popular-items",
|
|
11
|
+
"privacy",
|
|
12
|
+
"search",
|
|
13
|
+
"settings",
|
|
14
|
+
"signup",
|
|
15
|
+
"tags",
|
|
16
|
+
"terms",
|
|
17
|
+
"trend"
|
|
18
|
+
];
|
|
19
|
+
const tagRegex = /^\/tags\/([^/]+)/;
|
|
20
|
+
const organizationRegex = /^\/organizations\/([^/]+)/;
|
|
21
|
+
const popularItemsRegex = /^\/popular-items(\/|$)/;
|
|
22
|
+
const officialColumnsRegex = /^\/official-columns(\/|$)/;
|
|
23
|
+
const qiitaHandler = {
|
|
24
|
+
match: (url) => {
|
|
25
|
+
return isHostOf(url, hosts);
|
|
26
|
+
},
|
|
27
|
+
resolve: (url) => {
|
|
28
|
+
const { pathname } = new URL(url);
|
|
29
|
+
const tagMatch = pathname.match(tagRegex);
|
|
30
|
+
if (tagMatch?.[1]) return [{
|
|
31
|
+
uri: `https://qiita.com/tags/${tagMatch[1]}/feed.atom`,
|
|
32
|
+
hint: composeHint("qiita:tag")
|
|
33
|
+
}];
|
|
34
|
+
const orgMatch = pathname.match(organizationRegex);
|
|
35
|
+
if (orgMatch?.[1]) return [{
|
|
36
|
+
uri: `https://qiita.com/organizations/${orgMatch[1]}/activities.atom`,
|
|
37
|
+
hint: composeHint("qiita:organization")
|
|
38
|
+
}];
|
|
39
|
+
if (popularItemsRegex.test(pathname)) return [{
|
|
40
|
+
uri: "https://qiita.com/popular-items/feed.atom",
|
|
41
|
+
hint: composeHint("qiita:popular")
|
|
42
|
+
}];
|
|
43
|
+
if (officialColumnsRegex.test(pathname)) return [{
|
|
44
|
+
uri: "https://qiita.com/official-columns/feed/",
|
|
45
|
+
hint: composeHint("qiita:zine")
|
|
46
|
+
}];
|
|
47
|
+
const pathSegments = pathname.split("/").filter(Boolean);
|
|
48
|
+
if (pathSegments.length === 0) return [];
|
|
49
|
+
const username = pathSegments[0];
|
|
50
|
+
if (isAnyOf(username, excludedPaths)) return [];
|
|
51
|
+
return [{
|
|
52
|
+
uri: `https://qiita.com/${username}/feed.atom`,
|
|
53
|
+
hint: composeHint("qiita:posts")
|
|
54
|
+
}];
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
//#endregion
|
|
58
|
+
export { qiitaHandler };
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { composeHint, isAnyOf, isHostOf } from "../../../common/utils.js";
|
|
2
2
|
//#region src/feeds/platform/handlers/reddit.ts
|
|
3
3
|
const commentsRegex = /^\/r\/([^/]+)\/comments\/([^/]+)/;
|
|
4
|
+
const subredditWikiRegex = /^\/r\/([^/]+)\/wiki/;
|
|
5
|
+
const subredditSearchRegex = /^\/r\/([^/]+)\/search/;
|
|
4
6
|
const subredditRegex = /^\/r\/([^/]+)(?:\/([^/]+))?/;
|
|
5
7
|
const multiredditRegex = /^\/user\/([^/]+)\/m\/([^/]+)/;
|
|
6
|
-
const userRegex = /^\/(u|user)\/([^/]+)
|
|
8
|
+
const userRegex = /^\/(?:u|user)\/([^/]+)(?:\/(submitted|comments))?/;
|
|
7
9
|
const domainRegex = /^\/domain\/([^/]+)/;
|
|
10
|
+
const subredditsRegex = /^\/(?:subreddits|reddits)(?:\/(new|popular))?/;
|
|
8
11
|
const hosts = [
|
|
9
12
|
"reddit.com",
|
|
10
13
|
"www.reddit.com",
|
|
@@ -16,18 +19,71 @@ const sortOptions = [
|
|
|
16
19
|
"new",
|
|
17
20
|
"rising",
|
|
18
21
|
"controversial",
|
|
19
|
-
"top"
|
|
22
|
+
"top",
|
|
23
|
+
"best"
|
|
20
24
|
];
|
|
25
|
+
const timeOptions = new Set([
|
|
26
|
+
"hour",
|
|
27
|
+
"day",
|
|
28
|
+
"week",
|
|
29
|
+
"month",
|
|
30
|
+
"year",
|
|
31
|
+
"all"
|
|
32
|
+
]);
|
|
33
|
+
const timeFilteredSorts = new Set(["top", "controversial"]);
|
|
34
|
+
const getTimeframeSuffix = (sort, searchParams) => {
|
|
35
|
+
if (!timeFilteredSorts.has(sort)) return "";
|
|
36
|
+
const timeframe = searchParams.get("t");
|
|
37
|
+
if (timeframe && timeOptions.has(timeframe)) return `?t=${timeframe}`;
|
|
38
|
+
return "";
|
|
39
|
+
};
|
|
21
40
|
const redditHandler = {
|
|
22
41
|
match: (url) => {
|
|
23
42
|
return isHostOf(url, hosts);
|
|
24
43
|
},
|
|
25
44
|
resolve: (url) => {
|
|
26
|
-
const { pathname } = new URL(url);
|
|
27
|
-
|
|
45
|
+
const { pathname, searchParams } = new URL(url);
|
|
46
|
+
const pathSegments = pathname.split("/").filter(Boolean);
|
|
47
|
+
if (pathSegments.length === 0) return [{
|
|
28
48
|
uri: "https://www.reddit.com/.rss",
|
|
29
49
|
hint: composeHint("reddit:posts")
|
|
30
50
|
}];
|
|
51
|
+
if (pathSegments.length === 1 && isAnyOf(pathSegments[0], sortOptions)) {
|
|
52
|
+
const sort = pathSegments[0];
|
|
53
|
+
return [{
|
|
54
|
+
uri: `https://www.reddit.com/${sort}/.rss${getTimeframeSuffix(sort, searchParams)}`,
|
|
55
|
+
hint: composeHint("reddit:posts")
|
|
56
|
+
}];
|
|
57
|
+
}
|
|
58
|
+
if (pathSegments[0] === "search") {
|
|
59
|
+
const query = searchParams.get("q");
|
|
60
|
+
if (query) return [{
|
|
61
|
+
uri: `https://www.reddit.com/search.rss?q=${encodeURIComponent(query)}`,
|
|
62
|
+
hint: composeHint("reddit:search")
|
|
63
|
+
}];
|
|
64
|
+
}
|
|
65
|
+
const subredditsMatch = pathname.match(subredditsRegex);
|
|
66
|
+
if (subredditsMatch) {
|
|
67
|
+
const sort = subredditsMatch[1];
|
|
68
|
+
return [{
|
|
69
|
+
uri: `https://www.reddit.com/${sort ? `subreddits/${sort}` : "subreddits"}/.rss`,
|
|
70
|
+
hint: composeHint("reddit:subreddits")
|
|
71
|
+
}];
|
|
72
|
+
}
|
|
73
|
+
const subredditSearchMatch = pathname.match(subredditSearchRegex);
|
|
74
|
+
if (subredditSearchMatch?.[1]) {
|
|
75
|
+
const subreddit = subredditSearchMatch[1];
|
|
76
|
+
const query = searchParams.get("q");
|
|
77
|
+
if (query) return [{
|
|
78
|
+
uri: `https://www.reddit.com/r/${subreddit}/search.rss?q=${encodeURIComponent(query)}&restrict_sr=on`,
|
|
79
|
+
hint: composeHint("reddit:search")
|
|
80
|
+
}];
|
|
81
|
+
}
|
|
82
|
+
const subredditWikiMatch = pathname.match(subredditWikiRegex);
|
|
83
|
+
if (subredditWikiMatch?.[1]) return [{
|
|
84
|
+
uri: `https://www.reddit.com/r/${subredditWikiMatch[1]}/wiki/index.rss`,
|
|
85
|
+
hint: composeHint("reddit:wiki")
|
|
86
|
+
}];
|
|
31
87
|
const commentsMatch = pathname.match(commentsRegex);
|
|
32
88
|
if (commentsMatch?.[1] && commentsMatch?.[2]) return [{
|
|
33
89
|
uri: `https://www.reddit.com/r/${commentsMatch[1]}/comments/${commentsMatch[2]}/.rss`,
|
|
@@ -39,7 +95,7 @@ const redditHandler = {
|
|
|
39
95
|
const sort = subredditMatch[2];
|
|
40
96
|
const uris = [];
|
|
41
97
|
if (sort && isAnyOf(sort, sortOptions)) uris.push({
|
|
42
|
-
uri: `https://www.reddit.com/r/${subreddit}/${sort}/.rss`,
|
|
98
|
+
uri: `https://www.reddit.com/r/${subreddit}/${sort}/.rss${getTimeframeSuffix(sort, searchParams)}`,
|
|
43
99
|
hint: composeHint("reddit:posts")
|
|
44
100
|
});
|
|
45
101
|
else uris.push({
|
|
@@ -58,10 +114,28 @@ const redditHandler = {
|
|
|
58
114
|
hint: composeHint("reddit:multireddit")
|
|
59
115
|
}];
|
|
60
116
|
const userMatch = pathname.match(userRegex);
|
|
61
|
-
if (userMatch?.[
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
117
|
+
if (userMatch?.[1]) {
|
|
118
|
+
const username = userMatch[1];
|
|
119
|
+
const filter = userMatch[2];
|
|
120
|
+
if (filter === "submitted") return [{
|
|
121
|
+
uri: `https://www.reddit.com/user/${username}/submitted/.rss`,
|
|
122
|
+
hint: composeHint("reddit:user-submitted")
|
|
123
|
+
}, {
|
|
124
|
+
uri: `https://www.reddit.com/user/${username}/.rss`,
|
|
125
|
+
hint: composeHint("reddit:posts")
|
|
126
|
+
}];
|
|
127
|
+
if (filter === "comments") return [{
|
|
128
|
+
uri: `https://www.reddit.com/user/${username}/comments/.rss`,
|
|
129
|
+
hint: composeHint("reddit:user-comments")
|
|
130
|
+
}, {
|
|
131
|
+
uri: `https://www.reddit.com/user/${username}/.rss`,
|
|
132
|
+
hint: composeHint("reddit:posts")
|
|
133
|
+
}];
|
|
134
|
+
return [{
|
|
135
|
+
uri: `https://www.reddit.com/user/${username}/.rss`,
|
|
136
|
+
hint: composeHint("reddit:posts")
|
|
137
|
+
}];
|
|
138
|
+
}
|
|
65
139
|
const domainMatch = pathname.match(domainRegex);
|
|
66
140
|
if (domainMatch?.[1]) return [{
|
|
67
141
|
uri: `https://www.reddit.com/domain/${domainMatch[1]}/.rss`,
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { composeHint, isHostOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/rssCom.ts
|
|
3
|
+
const hosts = ["rss.com", "www.rss.com"];
|
|
4
|
+
const podcastRegex = /^\/(?:[a-z]{2}\/)?podcasts\/([^/]+)/;
|
|
5
|
+
const rssComHandler = {
|
|
6
|
+
match: (url) => {
|
|
7
|
+
return isHostOf(url, hosts);
|
|
8
|
+
},
|
|
9
|
+
resolve: (url) => {
|
|
10
|
+
const { pathname } = new URL(url);
|
|
11
|
+
const match = pathname.match(podcastRegex);
|
|
12
|
+
if (!match?.[1]) return [];
|
|
13
|
+
return [{
|
|
14
|
+
uri: `https://media.rss.com/${match[1]}/feed.xml`,
|
|
15
|
+
hint: composeHint("rss-com:podcast")
|
|
16
|
+
}];
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//#endregion
|
|
20
|
+
export { rssComHandler };
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/seesaa.ts
|
|
3
|
+
const seesaaHandler = {
|
|
4
|
+
match: (url) => {
|
|
5
|
+
return isSubdomainOf(url, "seesaa.net");
|
|
6
|
+
},
|
|
7
|
+
resolve: (url) => {
|
|
8
|
+
const { origin } = new URL(url);
|
|
9
|
+
const uris = [];
|
|
10
|
+
uris.push({
|
|
11
|
+
uri: `${origin}/index20.rdf`,
|
|
12
|
+
hint: composeHint("seesaa:posts-rss2")
|
|
13
|
+
});
|
|
14
|
+
uris.push({
|
|
15
|
+
uri: `${origin}/index.rdf`,
|
|
16
|
+
hint: composeHint("seesaa:posts-rdf")
|
|
17
|
+
});
|
|
18
|
+
return uris;
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
//#endregion
|
|
22
|
+
export { seesaaHandler };
|
|
@@ -8,10 +8,43 @@ const sourceforgeHandler = {
|
|
|
8
8
|
resolve: (url) => {
|
|
9
9
|
const { origin, pathname } = new URL(url);
|
|
10
10
|
const pathSegments = pathname.split("/").filter(Boolean);
|
|
11
|
-
if (pathSegments[0] === "projects" && pathSegments[1])
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
11
|
+
if ((pathSegments[0] === "projects" || pathSegments[0] === "p") && pathSegments[1]) {
|
|
12
|
+
const project = pathSegments[1];
|
|
13
|
+
return [
|
|
14
|
+
{
|
|
15
|
+
uri: `${origin}/p/${project}/activity/feed`,
|
|
16
|
+
hint: composeHint("sourceforge:activity")
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
uri: `${origin}/p/${project}/feed`,
|
|
20
|
+
hint: composeHint("sourceforge:project-feed")
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
uri: `${origin}/projects/${project}/rss`,
|
|
24
|
+
hint: composeHint("sourceforge:files")
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
uri: `${origin}/p/${project}/news/feed.rss`,
|
|
28
|
+
hint: composeHint("sourceforge:news-rss")
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
uri: `${origin}/p/${project}/news/feed.atom`,
|
|
32
|
+
hint: composeHint("sourceforge:news-atom")
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
uri: `${origin}/p/${project}/discussion/feed`,
|
|
36
|
+
hint: composeHint("sourceforge:discussion")
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
uri: `${origin}/p/${project}/discussion/feed.atom`,
|
|
40
|
+
hint: composeHint("sourceforge:discussion-atom")
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
uri: `${origin}/p/${project}/bugs/feed`,
|
|
44
|
+
hint: composeHint("sourceforge:bugs")
|
|
45
|
+
}
|
|
46
|
+
];
|
|
47
|
+
}
|
|
15
48
|
return [];
|
|
16
49
|
}
|
|
17
50
|
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { composeHint, isHostOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/spreaker.ts
|
|
3
|
+
const hosts = ["spreaker.com", "www.spreaker.com"];
|
|
4
|
+
const podcastRegex = /^\/podcast\/[\w-]+--(\d+)/;
|
|
5
|
+
const showRegex = /^\/show\/(\d+)(?:\/|$)/;
|
|
6
|
+
const spreakerHandler = {
|
|
7
|
+
match: (url) => {
|
|
8
|
+
return isHostOf(url, hosts);
|
|
9
|
+
},
|
|
10
|
+
resolve: (url) => {
|
|
11
|
+
const { pathname } = new URL(url);
|
|
12
|
+
const id = pathname.match(podcastRegex)?.[1] ?? pathname.match(showRegex)?.[1];
|
|
13
|
+
if (!id) return [];
|
|
14
|
+
return [{
|
|
15
|
+
uri: `https://www.spreaker.com/show/${id}/episodes/feed`,
|
|
16
|
+
hint: composeHint("spreaker:podcast")
|
|
17
|
+
}];
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//#endregion
|
|
21
|
+
export { spreakerHandler };
|
|
@@ -3,6 +3,7 @@ import { composeHint, isHostOf, isSubdomainOf } from "../../../common/utils.js";
|
|
|
3
3
|
const tagRegex = /^\/questions\/tagged\/([\w.+-]+)/;
|
|
4
4
|
const questionRegex = /^\/questions\/(\d+)/;
|
|
5
5
|
const userRegex = /^\/users\/(\d+)/;
|
|
6
|
+
const collectiveRegex = /^\/collectives\/([^/]+)/;
|
|
6
7
|
const domains = [
|
|
7
8
|
"stackoverflow.com",
|
|
8
9
|
"serverfault.com",
|
|
@@ -12,15 +13,29 @@ const domains = [
|
|
|
12
13
|
"mathoverflow.net",
|
|
13
14
|
"stackexchange.com"
|
|
14
15
|
];
|
|
16
|
+
const validSorts = new Set([
|
|
17
|
+
"newest",
|
|
18
|
+
"active",
|
|
19
|
+
"votes",
|
|
20
|
+
"creation",
|
|
21
|
+
"hot",
|
|
22
|
+
"week",
|
|
23
|
+
"month"
|
|
24
|
+
]);
|
|
25
|
+
const getSortSuffix = (searchParams) => {
|
|
26
|
+
const sort = searchParams.get("sort") ?? searchParams.get("tab")?.toLowerCase();
|
|
27
|
+
if (sort && validSorts.has(sort)) return `?sort=${sort}`;
|
|
28
|
+
return "";
|
|
29
|
+
};
|
|
15
30
|
const stackExchangeHandler = {
|
|
16
31
|
match: (url) => {
|
|
17
32
|
return isHostOf(url, domains) || isSubdomainOf(url, domains);
|
|
18
33
|
},
|
|
19
34
|
resolve: (url) => {
|
|
20
|
-
const { origin, pathname } = new URL(url);
|
|
35
|
+
const { origin, pathname, searchParams } = new URL(url);
|
|
21
36
|
const tagMatch = pathname.match(tagRegex);
|
|
22
37
|
if (tagMatch?.[1]) return [{
|
|
23
|
-
uri: `${origin}/feeds/tag/${tagMatch[1]}`,
|
|
38
|
+
uri: `${origin}/feeds/tag/${tagMatch[1]}${getSortSuffix(searchParams)}`,
|
|
24
39
|
hint: composeHint("stackexchange:tag")
|
|
25
40
|
}];
|
|
26
41
|
const questionMatch = pathname.match(questionRegex);
|
|
@@ -33,6 +48,15 @@ const stackExchangeHandler = {
|
|
|
33
48
|
uri: `${origin}/feeds/user/${userMatch[1]}`,
|
|
34
49
|
hint: composeHint("stackexchange:user")
|
|
35
50
|
}];
|
|
51
|
+
const collectiveMatch = pathname.match(collectiveRegex);
|
|
52
|
+
if (collectiveMatch?.[1]) return [{
|
|
53
|
+
uri: `${origin}/feeds/collectives/${collectiveMatch[1]}`,
|
|
54
|
+
hint: composeHint("stackexchange:collective")
|
|
55
|
+
}];
|
|
56
|
+
if (pathname === "/" || pathname === "") return [{
|
|
57
|
+
uri: `${origin}/feeds`,
|
|
58
|
+
hint: composeHint("stackexchange:newest")
|
|
59
|
+
}];
|
|
36
60
|
return [];
|
|
37
61
|
}
|
|
38
62
|
};
|
|
@@ -21,6 +21,13 @@ const steamHandler = {
|
|
|
21
21
|
hint: composeHint("steam:group")
|
|
22
22
|
}];
|
|
23
23
|
}
|
|
24
|
+
if (hostname === "store.steampowered.com" && (pathname === "/" || pathname === "" || pathname.startsWith("/news"))) return [{
|
|
25
|
+
uri: "https://store.steampowered.com/feeds/news.xml",
|
|
26
|
+
hint: composeHint("steam:news-global")
|
|
27
|
+
}, {
|
|
28
|
+
uri: "https://store.steampowered.com/feeds/daily_deals.xml",
|
|
29
|
+
hint: composeHint("steam:daily-deals")
|
|
30
|
+
}];
|
|
24
31
|
return [];
|
|
25
32
|
}
|
|
26
33
|
};
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { composeHint, isHostOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/tildes.ts
|
|
3
|
+
const hosts = ["tildes.net", "www.tildes.net"];
|
|
4
|
+
const groupRegex = /^\/~([^/]+)/;
|
|
5
|
+
const tildesHandler = {
|
|
6
|
+
match: (url) => {
|
|
7
|
+
return isHostOf(url, hosts);
|
|
8
|
+
},
|
|
9
|
+
resolve: (url) => {
|
|
10
|
+
const { pathname, searchParams } = new URL(url);
|
|
11
|
+
const groupMatch = pathname.match(groupRegex);
|
|
12
|
+
const uris = [];
|
|
13
|
+
const tag = searchParams.get("tag");
|
|
14
|
+
const tagSuffix = tag ? `?tag=${encodeURIComponent(tag)}` : "";
|
|
15
|
+
if (groupMatch?.[1]) {
|
|
16
|
+
const group = groupMatch[1];
|
|
17
|
+
uris.push({
|
|
18
|
+
uri: `https://tildes.net/~${group}/topics.rss${tagSuffix}`,
|
|
19
|
+
hint: composeHint("tildes:group-rss")
|
|
20
|
+
});
|
|
21
|
+
uris.push({
|
|
22
|
+
uri: `https://tildes.net/~${group}/topics.atom${tagSuffix}`,
|
|
23
|
+
hint: composeHint("tildes:group-atom")
|
|
24
|
+
});
|
|
25
|
+
return uris;
|
|
26
|
+
}
|
|
27
|
+
if (pathname === "/" || pathname === "") {
|
|
28
|
+
uris.push({
|
|
29
|
+
uri: `https://tildes.net/topics.rss${tagSuffix}`,
|
|
30
|
+
hint: composeHint("tildes:topics-rss")
|
|
31
|
+
});
|
|
32
|
+
uris.push({
|
|
33
|
+
uri: `https://tildes.net/topics.atom${tagSuffix}`,
|
|
34
|
+
hint: composeHint("tildes:topics-atom")
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
return uris;
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
//#endregion
|
|
41
|
+
export { tildesHandler };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/tistory.ts
|
|
3
|
+
const tistoryHandler = {
|
|
4
|
+
match: (url) => {
|
|
5
|
+
return isSubdomainOf(url, "tistory.com");
|
|
6
|
+
},
|
|
7
|
+
resolve: (url) => {
|
|
8
|
+
const { origin } = new URL(url);
|
|
9
|
+
return [{
|
|
10
|
+
uri: `${origin}/rss`,
|
|
11
|
+
hint: composeHint("tistory:blog")
|
|
12
|
+
}];
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
//#endregion
|
|
16
|
+
export { tistoryHandler };
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { composeHint, isSubdomainOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/transistor.ts
|
|
3
|
+
const domainSuffix = /\.transistor\.fm$/i;
|
|
4
|
+
const reservedSlugs = new Set([
|
|
5
|
+
"www",
|
|
6
|
+
"feeds",
|
|
7
|
+
"share",
|
|
8
|
+
"support",
|
|
9
|
+
"help",
|
|
10
|
+
"developers",
|
|
11
|
+
"api",
|
|
12
|
+
"cdn"
|
|
13
|
+
]);
|
|
14
|
+
const transistorHandler = {
|
|
15
|
+
match: (url) => {
|
|
16
|
+
if (!isSubdomainOf(url, "transistor.fm")) return false;
|
|
17
|
+
const slug = new URL(url).hostname.toLowerCase().replace(domainSuffix, "");
|
|
18
|
+
return !reservedSlugs.has(slug);
|
|
19
|
+
},
|
|
20
|
+
resolve: (url) => {
|
|
21
|
+
const { hostname } = new URL(url);
|
|
22
|
+
return [{
|
|
23
|
+
uri: `https://feeds.transistor.fm/${hostname.replace(domainSuffix, "")}`,
|
|
24
|
+
hint: composeHint("transistor:podcast")
|
|
25
|
+
}];
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
//#endregion
|
|
29
|
+
export { transistorHandler };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { composeHint, isHostOf } from "../../../common/utils.js";
|
|
2
|
+
//#region src/feeds/platform/handlers/velog.ts
|
|
3
|
+
const hosts = ["velog.io", "www.velog.io"];
|
|
4
|
+
const userRegex = /^\/@([^/]+)/;
|
|
5
|
+
const velogHandler = {
|
|
6
|
+
match: (url) => {
|
|
7
|
+
return isHostOf(url, hosts);
|
|
8
|
+
},
|
|
9
|
+
resolve: (url) => {
|
|
10
|
+
const { pathname } = new URL(url);
|
|
11
|
+
const userMatch = pathname.match(userRegex);
|
|
12
|
+
if (userMatch?.[1]) return [{
|
|
13
|
+
uri: `https://v2.velog.io/rss/${userMatch[1]}`,
|
|
14
|
+
hint: composeHint("velog:posts")
|
|
15
|
+
}];
|
|
16
|
+
if (pathname === "/" || pathname === "") return [{
|
|
17
|
+
uri: "https://v2.velog.io/rss",
|
|
18
|
+
hint: composeHint("velog:trending")
|
|
19
|
+
}];
|
|
20
|
+
return [];
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
//#endregion
|
|
24
|
+
export { velogHandler };
|
|
@@ -4,6 +4,7 @@ const numericRegex = /^\d+$/;
|
|
|
4
4
|
const hosts = ["vimeo.com", "www.vimeo.com"];
|
|
5
5
|
const excludedPaths = [
|
|
6
6
|
"about",
|
|
7
|
+
"album",
|
|
7
8
|
"blog",
|
|
8
9
|
"business",
|
|
9
10
|
"careers",
|
|
@@ -26,6 +27,7 @@ const excludedPaths = [
|
|
|
26
27
|
"pro",
|
|
27
28
|
"search",
|
|
28
29
|
"settings",
|
|
30
|
+
"showcase",
|
|
29
31
|
"site_map",
|
|
30
32
|
"solutions",
|
|
31
33
|
"stock",
|
|
@@ -48,6 +50,10 @@ const vimeoHandler = {
|
|
|
48
50
|
uri: `${origin}/groups/${pathSegments[1]}/videos/rss`,
|
|
49
51
|
hint: composeHint("vimeo:group")
|
|
50
52
|
}];
|
|
53
|
+
if ((pathSegments[0] === "album" || pathSegments[0] === "showcase") && pathSegments[1] && numericRegex.test(pathSegments[1])) return [{
|
|
54
|
+
uri: `${origin}/album/${pathSegments[1]}/rss`,
|
|
55
|
+
hint: composeHint("vimeo:album")
|
|
56
|
+
}];
|
|
51
57
|
if (pathSegments.length > 0) {
|
|
52
58
|
const user = pathSegments[0];
|
|
53
59
|
if (!isAnyOf(user, excludedPaths) && !numericRegex.test(user)) {
|