Flask extension to provide a search view for querying the webteam's Google Custom Search account
Project description
canonicalwebteam.search
Flask extension to provide a search view for querying the webteam's Google Custom Search account.
Installation
pip3 install canonicalwebteam.search
Or add canonicalwebteam.search
to your requirements.txt
.
Usage
Local development
For local development, it's best to test this module with one of our website projects like ubuntu.com. For more information, follow this guide (internal only).
Application code
You can add the extension on your project's application as follows:
import talisker.requests
from flask import Flask
from canonicalwebteam.search import build_search_view
app = Flask("myapp")
session = talisker.requests.get_session() # You must provide a requests session
app.add_url_rule("/search", "search", build_search_view(session))
# Or, a bit more complex example
app.add_url_rule(
"/docs/search",
"docs-search",
build_search_view(
session=session,
site="maas.io/docs",
template_path="docs/search.html",
search_engine_id="xxxxxxxxxx", # Optional argument, required by some of our sites
request_limit="500/day", # Allows your to configure the limit at which the user will be forbidden to query more. Defaults to 500 per day
)
)
The template
You need to create an HTML template at the specificed template_path
. By default this will be search.html
inside your templates folder. This template will be passed the following data:
{{ query }}
- the contents of theq=
search query parameter{{ start }}
- the contents of thestart=
query parameter - the offset at which to start returning results (used for pagination - default 0){{ num }}
- the contents of thenum=
query parameter - the number of search results to return (default 10){{ results }}
- the results returned from the Google Custom Search query. The actual search results are in{{ results.entries }}
.
The API key
You then need to provide the API key for the Google Custom Search API as an environment variable called SEARCH_API_KEY
when the server starts - e.g.:
SEARCH_API_KEY=xxxxx FLASK_APP=app.py flask run
Once this is done, you should be able to visit /search?q={some_query}
in your site and see search results built with your search.html
template.
For some sites, you will need to pass a specific search engine ID (cx) to the build_search_view
which you will find in the Custom Search Engine page.
New sites
If you created a new site and the API is not returning any results, you may need to add it to the Google Custom Search Engine list of sites. If you don't see any sites in this page, ask the Webteam.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for canonicalwebteam.search-1.3.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 21c1d611a6c34e61c699b408637e025606791962da0de867d5666cd79d9fd9a7 |
|
MD5 | 6e2d93e6ed06c34554bc8bcd2cca054c |
|
BLAKE2b-256 | 1365e70234588a02cae32d417799bb2d171d7aad0ff85a724787f51f06ccacab |
Hashes for canonicalwebteam.search-1.3.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bf4e2f2866d7a6c63dcad6b75490268e81a4e6b64f1f4a4307390da404cc1e13 |
|
MD5 | 9c96261e7149df4a3aa1588caadb6fbe |
|
BLAKE2b-256 | f235fed1c6289d7212dfb3f39ba03535746dd28c36e07d847d1576950a6e6f03 |