rules.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package rewrite // import "miniflux.app/v2/internal/reader/rewrite"
  4. import (
  5. "net/url"
  6. "strings"
  7. )
  8. // List of predefined rewrite rules (alphabetically sorted)
  9. // Available rules: "add_image_title", "add_youtube_video"
  10. // domain => rule name
  11. var predefinedRules = map[string]string{
  12. "abstrusegoose.com": "add_image_title",
  13. "amazingsuperpowers.com": "add_image_title",
  14. "blog.cloudflare.com": `add_image_title,remove("figure.kg-image-card figure.kg-image + img")`,
  15. "cowbirdsinlove.com": "add_image_title",
  16. "drawingboardcomic.com": "add_image_title",
  17. "exocomics.com": "add_image_title",
  18. "framatube.org": "nl2br,convert_text_link",
  19. "happletea.com": "add_image_title",
  20. "ilpost.it": `remove(".art_tag, #audioPlayerArticle, .author-container, .caption, .ilpostShare, .lastRecents, #mc_embed_signup, .outbrain_inread, p:has(.leggi-anche), .youtube-overlay")`,
  21. "imogenquest.net": "add_image_title",
  22. "lukesurl.com": "add_image_title",
  23. "medium.com": "fix_medium_images",
  24. "mercworks.net": "add_image_title",
  25. "monkeyuser.com": "add_image_title",
  26. "mrlovenstein.com": "add_image_title",
  27. "nedroid.com": "add_image_title",
  28. "oglaf.com": `replace("media.oglaf.com/story/tt(.+).gif"|"media.oglaf.com/comic/$1.jpg"),add_image_title`,
  29. "optipess.com": "add_image_title",
  30. "peebleslab.com": "add_image_title",
  31. "quantamagazine.org": `add_youtube_video_from_id, remove("h6:not(.byline,.post__title__kicker), #comments, .next-post__content, .footer__section, figure .outer--content, script")`,
  32. "sentfromthemoon.com": "add_image_title",
  33. "thedoghousediaries.com": "add_image_title",
  34. "theverge.com": `add_dynamic_image, remove("div.duet--recirculation--related-list, .hidden")`,
  35. "treelobsters.com": "add_image_title",
  36. "webtoons.com": `add_dynamic_image,replace("webtoon"|"swebtoon")`,
  37. "www.qwantz.com": "add_image_title,add_mailto_subject",
  38. "xkcd.com": "add_image_title",
  39. "youtube.com": "add_youtube_video",
  40. }
  41. // GetRefererForURL returns the referer for the given URL if it exists, otherwise an empty string.
  42. func GetRefererForURL(u string) string {
  43. parsedUrl, err := url.Parse(u)
  44. if err != nil {
  45. return ""
  46. }
  47. switch parsedUrl.Hostname() {
  48. case "moyu.im":
  49. return "https://i.jandan.net"
  50. case "i.pximg.net":
  51. return "https://www.pixiv.net"
  52. case "sp1.piokok.com":
  53. return "https://sp1.piokok.com"
  54. case "cdnfile.sspai.com":
  55. return "https://sspai.com"
  56. case "f.video.weibocdn.com":
  57. return "https://weibo.com"
  58. case "img.hellogithub.com":
  59. return "https://hellogithub.com"
  60. case "bjp.org.cn":
  61. return "https://bjp.org.cn"
  62. case "appinn.com":
  63. return "https://appinn.com"
  64. }
  65. switch {
  66. case strings.HasSuffix(parsedUrl.Hostname(), ".sinaimg.cn"):
  67. return "https://weibo.com"
  68. case strings.HasSuffix(parsedUrl.Hostname(), ".cdninstagram.com"):
  69. return "https://www.instagram.com"
  70. case strings.HasSuffix(parsedUrl.Hostname(), ".moyu.im"):
  71. return "https://i.jandan.net"
  72. }
  73. return ""
  74. }