Browse Source

Merge pull request #299 from dalf/noreferrer

Noreferrer
Adam Tauber 10 years ago
parent
commit
81479a9b60

+ 2
- 1
searx/templates/courgette/base.html View File

5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
7
         <meta name="generator" content="searx/{{ searx_version }}">
7
         <meta name="generator" content="searx/{{ searx_version }}">
8
+        <meta name="referrer" content="no-referrer">
8
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <title>{% block title %}{% endblock %}searx</title>
10
         <title>{% block title %}{% endblock %}searx</title>
10
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />
11
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />
39
             <script src="{{ url_for('static', filename='js/searx.js') }}" ></script>
40
             <script src="{{ url_for('static', filename='js/searx.js') }}" ></script>
40
         </div>
41
         </div>
41
     </body>
42
     </body>
42
-</html>
43
+</html>

BIN
searx/templates/courgette/result_templates/.code.html.swp View File


+ 2
- 2
searx/templates/courgette/result_templates/code.html View File

1
 <div class="result {{ result.class }}">
1
 <div class="result {{ result.class }}">
2
-    <h3 class="result_title">{% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
2
+    <h3 class="result_title">{% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
3
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
3
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
4
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
4
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
5
-    {% if result.repository %}<p class="content"><a href="{{ result.repository|safe }}">{{ result.repository }}</a></p>{% endif %}
5
+    {% if result.repository %}<p class="content"><a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %}
6
     <div dir="ltr">
6
     <div dir="ltr">
7
     {{ result.codelines|code_highlighter(result.code_language)|safe }}
7
     {{ result.codelines|code_highlighter(result.code_language)|safe }}
8
 	</div>
8
 	</div>

+ 2
- 2
searx/templates/courgette/result_templates/default.html View File

5
     {% endif %}
5
     {% endif %}
6
 
6
 
7
     <div>
7
     <div>
8
-        <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
8
+        <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
9
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
9
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
10
         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p>
10
         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p>
11
         <p class="url">{{ result.pretty_url }}&lrm;</p>
11
         <p class="url">{{ result.pretty_url }}&lrm;</p>
12
     </div>
12
     </div>
13
-</div>
13
+</div>

+ 2
- 2
searx/templates/courgette/result_templates/images.html View File

1
 <div class="image_result">
1
 <div class="image_result">
2
     <p>
2
     <p>
3
-        <a href="{{ result.img_src }}"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
4
-        <span class="url"><a href="{{ result.url }}" class="small_font">{{ _('original context') }}</a></span>
3
+        <a href="{{ result.img_src }}" rel="noreferrer"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
4
+        <span class="url"><a href="{{ result.url }}" rel="noreferrer" class="small_font">{{ _('original context') }}</a></span>
5
     </p>
5
     </p>
6
 </div>
6
 </div>

+ 2
- 2
searx/templates/courgette/result_templates/map.html View File

5
     {% endif %}
5
     {% endif %}
6
 
6
 
7
     <div>
7
     <div>
8
-        <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
8
+        <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
9
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
9
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}
10
         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p>
10
         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p>
11
         <p class="url">{{ result.pretty_url }}&lrm;</p>
11
         <p class="url">{{ result.pretty_url }}&lrm;</p>
12
     </div>
12
     </div>
13
-</div>
13
+</div>

+ 3
- 3
searx/templates/courgette/result_templates/torrent.html View File

2
     {% if "icon_"~result.engine~".ico" in favicons %}
2
     {% if "icon_"~result.engine~".ico" in favicons %}
3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
4
     {% endif %}
4
     {% endif %}
5
-    <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
5
+    <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
6
     {% if result.content %}<span class="content">{{ result.content|safe }}</span><br />{% endif %}
6
     {% if result.content %}<span class="content">{{ result.content|safe }}</span><br />{% endif %}
7
     <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span><br />
7
     <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span><br />
8
     <span>
8
     <span>
9
         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %} 
9
         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %} 
10
-        {% if result.torrentfile %}<a href="{{ result.torrentfile }}" class="torrentfile">{{ _('torrent file') }}</a>{% endif %}
10
+        {% if result.torrentfile %}<a href="{{ result.torrentfile }}" class="torrentfile" rel="noreferrer">{{ _('torrent file') }}</a>{% endif %}
11
     </span>
11
     </span>
12
     <p class="url">{{ result.pretty_url }}&lrm;</p>
12
     <p class="url">{{ result.pretty_url }}&lrm;</p>
13
-</div>
13
+</div>

+ 2
- 2
searx/templates/courgette/result_templates/videos.html View File

3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
4
 	{% endif %}
4
 	{% endif %}
5
 
5
 
6
-    <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
6
+    <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
7
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %}
7
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %}
8
-    <a href="{{ result.url }}"><img width="400" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
8
+    <a href="{{ result.url }}" rel="noreferrer"><img width="400" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
9
     <p class="url">{{ result.pretty_url }}&lrm;</p>
9
     <p class="url">{{ result.pretty_url }}&lrm;</p>
10
 </div>
10
 </div>

+ 1
- 0
searx/templates/default/base.html View File

5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
7
         <meta name="generator" content="searx/{{ searx_version }}">
7
         <meta name="generator" content="searx/{{ searx_version }}">
8
+        <meta name="referrer" content="no-referrer">
8
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <title>{% block title %}{% endblock %}searx</title>
10
         <title>{% block title %}{% endblock %}searx</title>
10
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />
11
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />

+ 1
- 1
searx/templates/default/infobox.html View File

17
     <div class="urls">
17
     <div class="urls">
18
         <ul>
18
         <ul>
19
             {% for url in infobox.urls %}
19
             {% for url in infobox.urls %}
20
-            <li class="url"><a href="{{ url.url }}">{{ url.title }}</a></li>
20
+            <li class="url"><a href="{{ url.url }}" rel="noreferrer">{{ url.title }}</a></li>
21
             {% endfor %}
21
             {% endfor %}
22
         </ul>
22
         </ul>
23
     </div>
23
     </div>

+ 3
- 3
searx/templates/default/result_templates/code.html View File

1
 <div class="result {{ result.class }}">
1
 <div class="result {{ result.class }}">
2
-    <h3 class="result_title"> {% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
3
-    <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}">{{ _('cached') }}</a></p>
2
+    <h3 class="result_title"> {% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
3
+    <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a></p>
4
     {% if result.publishedDate %}<p class="published_date">{{ result.publishedDate }}</p>{% endif %}
4
     {% if result.publishedDate %}<p class="published_date">{{ result.publishedDate }}</p>{% endif %}
5
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
5
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
6
-    {% if result.repository %}<p class="result-content"><a href="{{ result.repository|safe }}">{{ result.repository }}</a></p>{% endif %}
6
+    {% if result.repository %}<p class="result-content"><a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %}
7
     
7
     
8
     <div dir="ltr">
8
     <div dir="ltr">
9
     {{ result.codelines|code_highlighter(result.code_language)|safe }}
9
     {{ result.codelines|code_highlighter(result.code_language)|safe }}

+ 2
- 2
searx/templates/default/result_templates/default.html View File

1
 <div class="result {{ result.class }}">
1
 <div class="result {{ result.class }}">
2
-    <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
3
-    <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}">{{ _('cached') }}</a>
2
+    <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
3
+    <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a>
4
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p>
4
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p>
5
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
5
     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
6
 </div>
6
 </div>

+ 2
- 2
searx/templates/default/result_templates/images.html View File

1
 <div class="image_result">
1
 <div class="image_result">
2
     <p>
2
     <p>
3
-        <a href="{{ result.img_src }}"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a>
4
-        <span class="url"><a href="{{ result.url }}" class="small_font">{{ _('original context') }}</a></span>
3
+        <a href="{{ result.img_src }}" rel="noreferrer"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a>
4
+        <span class="url"><a href="{{ result.url }}" rel="noreferrer" class="small_font">{{ _('original context') }}</a></span>
5
     </p>
5
     </p>
6
 </div>
6
 </div>

+ 2
- 2
searx/templates/default/result_templates/map.html View File

5
     {% endif %}
5
     {% endif %}
6
 
6
 
7
     <div>
7
     <div>
8
-        <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
9
-        <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}">{{ _('cached') }}</a>
8
+        <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
9
+        <p class="url">{{ result.pretty_url }}&lrm; <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a>
10
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p>
10
         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p>
11
         <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
11
         <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p>
12
     </div>
12
     </div>

+ 2
- 2
searx/templates/default/result_templates/torrent.html View File

2
   {% if "icon_"~result.engine~".ico" in favicons %}
2
   {% if "icon_"~result.engine~".ico" in favicons %}
3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
3
     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />
4
   {% endif %}
4
   {% endif %}
5
-    <h3 class="result_title"><a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
5
+    <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
6
     <p class="url">{{ result.pretty_url }}&lrm;</p>
6
     <p class="url">{{ result.pretty_url }}&lrm;</p>
7
     {% if result.content %}<p class="content">{{ result.content|safe }}</p>{% endif %}
7
     {% if result.content %}<p class="content">{{ result.content|safe }}</p>{% endif %}
8
     <p>
8
     <p>
9
         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %} 
9
         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %} 
10
-        {% if result.torrentfile %}<a href="{{ result.torrentfile }}" class="torrentfile">{{ _('torrent file') }}</a>{% endif %} - 
10
+        {% if result.torrentfile %}<a href="{{ result.torrentfile }}" rel="noreferrer" class="torrentfile">{{ _('torrent file') }}</a>{% endif %} - 
11
         <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span>
11
         <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span>
12
     </p>
12
     </p>
13
 </div>
13
 </div>

+ 2
- 2
searx/templates/default/result_templates/videos.html View File

1
 <div class="result">
1
 <div class="result">
2
-    <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}">{{ result.title|safe }}</a></h3>
2
+    <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3>
3
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %}
3
     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %}
4
-    <a href="{{ result.url }}"><img class="thumbnail" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
4
+    <a href="{{ result.url }}" rel="noreferrer"><img class="thumbnail" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a>
5
     <p class="url">{{ result.url }}&lrm;</p>
5
     <p class="url">{{ result.url }}&lrm;</p>
6
 </div>
6
 </div>

+ 1
- 0
searx/templates/oscar/base.html View File

6
     <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
6
     <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
7
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
7
     <meta http-equiv="X-UA-Compatible" content="IE=edge">
8
     <meta name="generator" content="searx/{{ searx_version }}">
8
     <meta name="generator" content="searx/{{ searx_version }}">
9
+    <meta name="referrer" content="no-referrer">
9
     <meta name="viewport" content="width=device-width, initial-scale=1 , maximum-scale=1.0, user-scalable=1" />
10
     <meta name="viewport" content="width=device-width, initial-scale=1 , maximum-scale=1.0, user-scalable=1" />
10
     {% block meta %}{% endblock %}
11
     {% block meta %}{% endblock %}
11
     <title>{% block title %}{% endblock %}searx</title>
12
     <title>{% block title %}{% endblock %}searx</title>

+ 1
- 1
searx/templates/oscar/infobox.html View File

20
         {% if infobox.urls %}
20
         {% if infobox.urls %}
21
         <div class="infobox_part">
21
         <div class="infobox_part">
22
             {% for url in infobox.urls %}
22
             {% for url in infobox.urls %}
23
-            <p class="btn btn-default btn-xs"><a href="{{ url.url }}">{{ url.title }}</a></p>
23
+            <p class="btn btn-default btn-xs"><a href="{{ url.url }}" rel="noreferrer">{{ url.title }}</a></p>
24
             {% endfor %}
24
             {% endfor %}
25
         </div>
25
         </div>
26
         {% endif %}
26
         {% endif %}

+ 3
- 3
searx/templates/oscar/macros.html View File

11
 
11
 
12
 <!-- Draw result header -->
12
 <!-- Draw result header -->
13
 {% macro result_header(result, favicons) -%} 
13
 {% macro result_header(result, favicons) -%} 
14
-    <h4 class="result_header">{% if result.engine~".png" in favicons %}{{ draw_favicon(result.engine) }} {% endif %}<a href="{{ result.url }}">{{ result.title|safe }}</a></h4>
14
+    <h4 class="result_header">{% if result.engine~".png" in favicons %}{{ draw_favicon(result.engine) }} {% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h4>
15
 {%- endmacro %}
15
 {%- endmacro %}
16
 
16
 
17
 <!-- Draw result sub header -->
17
 <!-- Draw result sub header -->
18
 {% macro result_sub_header(result) -%}
18
 {% macro result_sub_header(result) -%}
19
     {% if result.publishedDate %}<time class="text-muted" datetime="{{ result.pubdate }}" >{{ result.publishedDate }}</time>{% endif %}
19
     {% if result.publishedDate %}<time class="text-muted" datetime="{{ result.pubdate }}" >{{ result.publishedDate }}</time>{% endif %}
20
-    <small><a class="text-info" href="https://web.archive.org/web/{{ result.url }}">{{ icon('link') }} {{ _('cached') }}</a></small>
20
+    <small><a class="text-info" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ icon('link') }} {{ _('cached') }}</a></small>
21
     {% if result.magnetlink %}<small> &bull; <a href="{{ result.magnetlink }}" class="magnetlink">{{ icon('magnet') }} {{ _('magnet link') }}</a></small>{% endif %}
21
     {% if result.magnetlink %}<small> &bull; <a href="{{ result.magnetlink }}" class="magnetlink">{{ icon('magnet') }} {{ _('magnet link') }}</a></small>{% endif %}
22
-    {% if result.torrentfile %}<small> &bull; <a href="{{ result.torrentfile }}" class="torrentfile">{{ icon('download-alt') }} {{ _('torrent file') }}</a></small>{% endif %}
22
+    {% if result.torrentfile %}<small> &bull; <a href="{{ result.torrentfile }}" class="torrentfile" rel="noreferrer">{{ icon('download-alt') }} {{ _('torrent file') }}</a></small>{% endif %}
23
 {%- endmacro %}
23
 {%- endmacro %}
24
 
24
 
25
 <!-- Draw result footer -->
25
 <!-- Draw result footer -->

+ 1
- 1
searx/templates/oscar/result_templates/code.html View File

5
 
5
 
6
 {% if result.content %}<p class="result-content">{{ result.content|safe }}</p>{% endif %}
6
 {% if result.content %}<p class="result-content">{{ result.content|safe }}</p>{% endif %}
7
 
7
 
8
-{% if result.repository %}<p class="result-content">{{ icon('file') }} <a href="{{ result.repository|safe }}">{{ result.repository }}</a></p>{% endif %}
8
+{% if result.repository %}<p class="result-content">{{ icon('file') }} <a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %}
9
 
9
 
10
 <div dir="ltr">
10
 <div dir="ltr">
11
 {{ result.codelines|code_highlighter(result.code_language)|safe }}
11
 {{ result.codelines|code_highlighter(result.code_language)|safe }}

+ 3
- 3
searx/templates/oscar/result_templates/images.html View File

1
 {% from 'oscar/macros.html' import draw_favicon %}
1
 {% from 'oscar/macros.html' import draw_favicon %}
2
 
2
 
3
-<a href="{{ result.img_src }}" data-toggle="modal" data-target="#modal-{{ index }}">
3
+<a href="{{ result.img_src }}" rel="noreferrer" data-toggle="modal" data-target="#modal-{{ index }}">
4
     <img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" alt="{{ result.title|striptags }}" title="{{ result.title|striptags }}" class="img-thumbnail">
4
     <img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" alt="{{ result.title|striptags }}" title="{{ result.title|striptags }}" class="img-thumbnail">
5
 </a>
5
 </a>
6
 
6
 
20
                 <span class="label label-default pull-right">{{ result.engine }}</span>
20
                 <span class="label label-default pull-right">{{ result.engine }}</span>
21
                 <p class="text-muted pull-left">{{ result.pretty_url }}</p>
21
                 <p class="text-muted pull-left">{{ result.pretty_url }}</p>
22
                 <div class="clearfix"></div>
22
                 <div class="clearfix"></div>
23
-                <a href="{{ result.img_src }}" class="btn btn-default">{{ _('Get image') }}</a>
24
-                <a href="{{ result.url }}" class="btn btn-default">{{ _('View source') }}</a>
23
+                <a href="{{ result.img_src }}" rel="noreferrer" class="btn btn-default">{{ _('Get image') }}</a>
24
+                <a href="{{ result.url }}" rel="noreferrer" class="btn btn-default">{{ _('View source') }}</a>
25
             </div>
25
             </div>
26
         </div>
26
         </div>
27
     </div>
27
     </div>

+ 1
- 1
searx/templates/oscar/result_templates/videos.html View File

15
 
15
 
16
 <div class="container-fluid">
16
 <div class="container-fluid">
17
     <div class="row">
17
     <div class="row">
18
-        <a href="{{ result.url }}"><img class="thumbnail col-xs-6 col-sm-4 col-md-4 result-content" src="{{ image_proxify(result.thumbnail) }}" alt="{{ result.title|striptags }} {{ result.engine }}" /></a>
18
+        <a href="{{ result.url }}" rel="noreferrer"><img class="thumbnail col-xs-6 col-sm-4 col-md-4 result-content" src="{{ image_proxify(result.thumbnail) }}" alt="{{ result.title|striptags }} {{ result.engine }}" /></a>
19
         {% if result.content %}<p class="col-xs-12 col-sm-8 col-md-8 result-content">{{ result.content|safe }}</p>{% endif %}
19
         {% if result.content %}<p class="col-xs-12 col-sm-8 col-md-8 result-content">{{ result.content|safe }}</p>{% endif %}
20
     </div>
20
     </div>
21
 </div>
21
 </div>

+ 1
- 0
searx/templates/pix-art/base.html View File

5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
5
         <meta name="description" content="Searx - a privacy-respecting, hackable metasearch engine" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
6
         <meta name="keywords" content="searx, search, search engine, metasearch, meta search" />
7
         <meta name="generator" content="searx/{{ searx_version }}">
7
         <meta name="generator" content="searx/{{ searx_version }}">
8
+        <meta name="referrer" content="no-referrer">
8
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <meta name="viewport" content="width=device-width, maximum-scale=1.0, user-scalable=1" />
9
         <title>{% block title %}{% endblock %}searx</title>
10
         <title>{% block title %}{% endblock %}searx</title>
10
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />
11
         <link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}" type="text/css" media="screen" />

+ 3
- 2
searx/templates/pix-art/result_templates/default.html View File

1
-<a href="{{ result.url }}" title="{{ result.title | striptags }}">
1
+<a href="{{ result.url }}" title="{{ result.title | striptags }}" rel="noreferrer">
2
 	<canvas id="canvas-{{ pageno }}-{{ index }}" class="icon" width="16" height="16"></canvas>
2
 	<canvas id="canvas-{{ pageno }}-{{ index }}" class="icon" width="16" height="16"></canvas>
3
 </a>
3
 </a>
4
 <script type="text/javascript">
4
 <script type="text/javascript">
5
 favicons[{{ pageno }}][{{ index }}] = 'http://{{ result.url | extract_domain }}/favicon.ico';
5
 favicons[{{ pageno }}][{{ index }}] = 'http://{{ result.url | extract_domain }}/favicon.ico';
6
-</script>
6
+</script>
7
+

+ 2
- 2
searx/templates/pix-art/result_templates/images.html View File

1
 <div class="image_result">
1
 <div class="image_result">
2
     <p>
2
     <p>
3
-        <a href="{{ result.img_src }}"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a>
4
-        <span class="url"><a href="{{ result.url }}" class="small_font">{{ _('original context') }}</a></span>
3
+        <a href="{{ result.img_src }}" rel="noreferrer"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a>
4
+        <span class="url"><a href="{{ result.url }}" rel="noreferrer" class="small_font">{{ _('original context') }}</a></span>
5
     </p>
5
     </p>
6
 </div>
6
 </div>

+ 1
- 1
searx/tests/test_webapp.py View File

47
     def test_index_html(self):
47
     def test_index_html(self):
48
         result = self.app.post('/', data={'q': 'test'})
48
         result = self.app.post('/', data={'q': 'test'})
49
         self.assertIn(
49
         self.assertIn(
50
-            '<h3 class="result_title"><img width="14" height="14" class="favicon" src="/static/themes/default/img/icons/icon_youtube.ico" alt="youtube" /><a href="http://second.test.xyz">Second <span class="highlight">Test</span></a></h3>',  # noqa
50
+            '<h3 class="result_title"><img width="14" height="14" class="favicon" src="/static/themes/default/img/icons/icon_youtube.ico" alt="youtube" /><a href="http://second.test.xyz" rel="noreferrer">Second <span class="highlight">Test</span></a></h3>',  # noqa
51
             result.data
51
             result.data
52
         )
52
         )
53
         self.assertIn(
53
         self.assertIn(