Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rclement/flask-language
Flask extension handling client-side language cookie
https://github.com/rclement/flask-language
cookie flask flask-extension language python web
Last synced: 2 months ago
JSON representation
Flask extension handling client-side language cookie
- Host: GitHub
- URL: https://github.com/rclement/flask-language
- Owner: rclement
- License: mit
- Created: 2018-03-07T16:14:33.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T00:50:44.000Z (about 2 years ago)
- Last Synced: 2024-10-12T04:46:30.323Z (3 months ago)
- Topics: cookie, flask, flask-extension, language, python, web
- Language: Python
- Homepage: https://flask-language.readthedocs.io
- Size: 56.6 KB
- Stars: 2
- Watchers: 2
- Forks: 2
- Open Issues: 8
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- License: LICENSE
Awesome Lists containing this project
README
Flask-Language
==============|PyPI Version| |PyPI License| |PyPI Versions| |Build Status| |Coverage
Status| |Documentation Status|Flask-Language is a Flask_ extension providing a
simple mechanism to handle a client-side language cookie.It is somewhat loosely based on this snippet: ``__
.. _Flask: http://flask.pocoo.org
Installation
------------Install the extension with with pipenv_ (recommended):
::
$ pipenv install flask-language
Or with pip_:
::
$ pip install flask-language
.. _pip: https://pip.pypa.io
.. _pipenv: https://docs.pipenv.orgUsage
-----Initialize the Flask-Language extension (also compatible with the `Application Factories`_ pattern):
::
from flask import Flask, jsonify
from flask_language import Language, current_languageapp = Flask(__name__)
lang = Language(app)Define the language hooks:
::
@lang.allowed_languages
def get_allowed_languages():
return ['en', 'fr']@lang.default_language
def get_default_language():
return 'en'Define the desired end-points to retrieve and manipulate the current language:
::
@app.route('/api/language')
def get_language():
return jsonify({
'language': str(current_language),
})@app.route('/api/language', methods=['POST'])
def set_language():
req = request.get_json()
language = req.get('language', None)lang.change_language(language)
return jsonify({
'language': str(current_language),
})Before each request, Flask-Language will automatically determine the current
language in the following order:1. The language cookie (if any and matching the allowed languages)
2. The ``Accept-Language`` HTTP header (if any and matching the allowed languages)
3. The provided default languageDuring each request context, the current language can be accessed using
``current_language``.After each request, the current language will be stored in the language cookie.
.. _Application Factories: http://flask.pocoo.org/docs/0.12/patterns/appfactories/
Configuration
-------------Flask-Language is configurable via the following configuration variables:
- ``LANGUAGE_COOKIE_NAME``: name for the cookie language (default: ``'lang'``)
- ``LANGUAGE_COOKIE_TIMEOUT``: validity duration of the cookie language (default: ``datetime.timedelta(days=365)``)
- ``LANGUAGE_COOKIE_DOMAIN``: domain for the cookie language (default: ``None``)
- ``LANGUAGE_COOKIE_SECURE``: set secure option for the cookie language (default: ``False``)
- ``LANGUAGE_COOKIE_HTTPONLY``: set HTTP-only for the cookie language (default: ``False``)Documentation
-------------The Sphinx-compiled documentation is available on
`ReadTheDocs `__.License
-------The MIT License (MIT)
Copyright (c) 2018 Romain Clement
.. |PyPI Version| image:: https://img.shields.io/pypi/v/flask-language.svg
:target: https://pypi.python.org/pypi/flask-language
.. |PyPI License| image:: https://img.shields.io/pypi/l/flask-language.svg
:target: https://pypi.python.org/pypi/flask-language
.. |PyPI Versions| image:: https://img.shields.io/pypi/pyversions/flask-language.svg
:target: https://pypi.python.org/pypi/flask-language
.. |Build Status| image:: https://travis-ci.org/rclement/flask-language.svg?branch=master
:target: https://travis-ci.org/rclement/flask-language
.. |Coverage Status| image:: https://coveralls.io/repos/github/rclement/flask-language/badge.svg?branch=master
:target: https://coveralls.io/github/rclement/flask-language?branch=master
.. |Documentation Status| image:: https://readthedocs.org/projects/flask-language/badge/?version=master
:target: http://flask-language.readthedocs.io/en/master/