This repository has been archived on 2021-04-24. You can view files and clone it, but cannot push or open issues or pull requests.
Mikubot/plugins/url_title.lua

110 lines
3.5 KiB
Lua
Raw Normal View History

2015-04-14 20:21:23 +02:00
do
function getTitle(page)
local s = page
-- Remove optional spaces from the tags.
s = string.gsub(s, "\n", " ")
s = string.gsub(s, " *< *", "<")
s = string.gsub(s, " *> *", ">")
-- Character encoding
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&acute;", "´")
2015-06-11 17:10:03 +02:00
s = string.gsub(s, "&gt;", ">")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&quot;", '"')
s = string.gsub(s, "&lt;", "<")
s = string.gsub(s, "&mdash;", "")
s = string.gsub(s, "&nabla;", "")
2015-06-17 20:26:37 +02:00
s = string.gsub(s, "&ndash;", "")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&Psi;", "ψ")
s = string.gsub(s, "&psi;", "ψ")
2015-06-25 22:08:20 +02:00
s = string.gsub(s, "&raquo;", "»")
2015-11-27 22:11:32 +01:00
s = string.gsub(s, "&reg;", "®")
2015-11-18 17:08:15 +01:00
s = string.gsub(s, "&szlig;", "ß")
2015-11-21 19:23:59 +01:00
s = string.gsub(s, "&trade;", "")
s = string.gsub(s, "&#039;", "'")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&#39;", "'")
s = string.gsub(s, "&#124;", "|")
s = string.gsub(s, "&#160;", " ")
2015-09-08 22:23:48 +02:00
s = string.gsub(s, "&#187;", "»")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&#223;", "ß")
2015-07-31 18:01:10 +02:00
s = string.gsub(s, "&#8211;", "")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&#8217;", "'")
2015-07-02 14:09:56 +02:00
s = string.gsub(s, "&#8220;", "")
s = string.gsub(s, "&#8221;", "")
s = string.gsub(s, "&#8222;", "")
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&#8249;", "")
s = string.gsub(s, "&#8364;", "")
-- Ä Ö Ü
2015-07-20 23:03:03 +02:00
s = string.gsub(s, "&auml;", "ä")
s = string.gsub(s, "&Auml;", "Ä")
s = string.gsub(s, "&#228;", "ä")
s = string.gsub(s, "&#196;", "Ä")
2015-07-20 23:03:03 +02:00
s = string.gsub(s, "&ouml;", "ö")
s = string.gsub(s, "&Ouml;", "Ö")
s = string.gsub(s, "&#246;", "ö")
s = string.gsub(s, "&#214;", "Ö")
2015-07-20 23:03:03 +02:00
s = string.gsub(s, "&uuml;", "ü")
s = string.gsub(s, "&Uuml;", "Ü")
s = string.gsub(s, "&#252;", "ü")
s = string.gsub(s, "&#220;", "Ü")
2015-04-14 20:21:23 +02:00
-- Put all the tags in lowercase.
s = string.gsub(s, "(<[^ >]+)", string.lower)
2015-11-12 17:42:03 +01:00
s = string.gsub(s, "&amp;", "&") -- Be sure to do this after all others
2015-04-14 20:21:23 +02:00
local i, f, t = string.find(s, "<title>(.+)</title>")
return t or ""
end
function string.ends(str, fin)
return fin=='' or string.sub(str,-string.len(fin)) == fin
end
function run(msg, matches)
local url = matches[1]
if string.ends(url, ".jpg") or string.ends(url, ".gif") or string.ends(url, ".png") then
return
end
local result = http.request(url)
local title = getTitle(result)
2015-04-20 18:52:25 +02:00
--Ignoring 301, 302, 404 and more
2015-04-28 17:49:11 +02:00
if title == "301 Moved Permanently" or
2015-04-20 18:52:25 +02:00
title == "" or
title == "404 Not Found" or
title == "302 Found" or
2015-04-22 16:49:24 +02:00
title == "302 Moved" or
2015-04-20 18:52:25 +02:00
title == "Moved Permanently" or
2015-04-23 17:29:03 +02:00
title == "Redirection" or
2015-04-29 21:32:17 +02:00
title == "Object moved" or
2015-08-19 15:15:53 +02:00
title == "Error 404 (Not Found)!!1" or
2015-11-12 17:42:03 +01:00
title =="Moved Temporarily" or
2015-05-07 19:49:26 +02:00
string.match(title, "on Steam") or
string.match(title, "521: Web server is down") or
2015-04-21 15:59:09 +02:00
string.match(title, "eBay</title>") or
2015-05-10 13:09:06 +02:00
string.match(msg.text, "twitch.tv") or
2015-09-07 18:13:10 +02:00
string.match(msg.text, "twitter.com") or
2015-05-10 13:09:06 +02:00
string.match(msg.text, "steamcommunity.com/app/") or
2015-11-12 17:42:03 +01:00
string.match(msg.text, "myanimelist.net/anime/") or
string.match(msg.text, "myanimelist.net/manga/") or
2015-07-13 23:01:19 +02:00
string.match(msg.text, "deviantart.com") or
string.match(msg.text, "urbanup.com/") or
2015-11-12 17:42:03 +01:00
string.match(msg.text, "urbandictionary.com/define.php")or
2015-11-18 17:08:15 +01:00
string.match(msg.text, "wikia.com") or
string.match(msg.text, "rule34.xxx/index.php") or
string.match(msg.text, "openings.moe/%?video") or
2015-11-12 17:42:03 +01:00
string.match(msg.text, "dropbox.com/s/") then
2015-07-13 23:01:19 +02:00
print('Ungültig, da "'..title..'"')
2015-04-14 20:21:23 +02:00
else
return title
end
end
return {
2015-06-25 22:08:20 +02:00
description = "Postet den URL-Titel",
usage = {""},
patterns = {"^(https?://[%w-_%.%?%.:,/%+=&#!]+)$"},
2015-04-14 20:21:23 +02:00
run = run
}
end