X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;ds=sidebyside;f=search-tags.py;h=6281a1bc6919f7814bd04b2a86cc7b955ae41dde;hb=HEAD;hp=c2884fab2942aeeeb7374451770cbd556d5c0581;hpb=2e7b7f0cd4c51eb465780317446a81401eb71faa;p=phdru.name%2Fcgi-bin%2Fblog-ru%2Fsearch-tags.git diff --git a/search-tags.py b/search-tags.py index c2884fa..228866b 100755 --- a/search-tags.py +++ b/search-tags.py @@ -1,24 +1,29 @@ -#! /usr/bin/env python +#! /usr/bin/env python3 # coding: koi8-r """Search tags CGI""" __author__ = "Oleg Broytman " -__copyright__ = "Copyright (C) 2014-2017 PhiloSoft Design" +__copyright__ = "Copyright (C) 2014-2024 PhiloSoft Design" __license__ = "GNU GPL" -import cgi, sys +from html import escape +from urllib.parse import parse_qs +import os +import sys + from lark import ParseError -from html.response import redirect, response + +from html_output.response import redirect, response from parser import parser -form = cgi.FieldStorage() -if not form.has_key('q'): +qs_dict = parse_qs(os.environ['QUERY_STRING'], encoding='koi8-r') +if 'q' not in qs_dict or len(qs_dict['q']) > 1: status = "400 Bad request" title = "Error!" body = "Required parameter is missing!" else: - q = form['q'].value + q = qs_dict['q'][0] try: tree = parser.parse(q) except ParseError: @@ -26,28 +31,34 @@ else: title = "Error!" body = "Bad query syntax!" else: - if tree[0] == 'NAME': # Single tag - just do redirect + if tree[0] == 'NAME': # Single tag - just do redirect tag = tree[1] assert isinstance(tag, str) - from tags import tag_exists - if tag_exists(tag): - redirect("/Russian/blog/tags/%s.html" % tag, status="301 Moved") + from tags import real_tag + rtag = real_tag(tag) + if rtag: + redirect( + "/Russian/blog/tags/%s.html" % rtag.replace(' ', '_'), + status="301 Moved") sys.exit() status = "404 Tag not found" title = "ïÛÉÂËÁ!" body = "ôÅÇ %s ÎÅ ÓÕÝÅÓÔ×ÕÅÔ!" % tag - else: # Process tree + else: # Process tree from tags import find_tags posts = find_tags(tree) status = None - title = "úÁÐÉÓÉ, ÎÁÊÄÅÎÎÙÅ ÄÌÑ ×ÙÒÁÖÅÎÉÑ " + cgi.escape(q) + title = "úÁÐÉÓÉ, ÎÁÊÄÅÎÎÙÅ ÄÌÑ ×ÙÒÁÖÅÎÉÑ " + escape(q) if posts: _posts = ["""\