mirror of
https://github.com/apache/superset.git
synced 2026-04-21 09:04:38 +00:00
* setup docusaurus
* rename
* add introduction content
* chore(docsV2): move content from docs to docsV2 (#17714)
* add FAQs and contribution pages
* chore: add api, security, and roadmap pages, include swaggerui in dependency for api page
* chore: move api page header below imports
* chore: change API page info alert to use built in Infima class instead of custom class
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* chore(docs-v2): moving more markdown content to new documentation site (#17736)
* chore: move markdown content and images for docs installation directory to docs-v2
* chore: move docs miscellaneous directory content to docs-v2
* chore(docs-v2): move over connecting to databases content and rename some files to .mdx
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* Update styling and logo (#17990)
* update styling
* update colors
* chore(docs-v2): remove blog and tutorial and update some styling (#17929)
* add superset logo and favicon, change styles to better match current docs, add prettierrc
* change file types to mdx
* Add simple superset dark mode freindly logo
* clean up default pages - blog and tutorial docs
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
* Chore: moving charts and dashboard to docusaurus (#18036)
* add contributing add creating charts and dashboards
* delete extra images
* update rat-excludes
* Port homepage (#18115)
* Port community page (#18128)
* chore: add seo redirects for Docs v@ (#18092)
* fix: handle null values in time-series table (#18039)
* cleanup column_type_mappings (#17569)
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* important change to MakeFile (#18037)
* Update superset-e2e.yml (#18041)
* Revert "Update superset-e2e.yml (#18041)" (#18051)
This reverts commit b5652739c9.
* feat: Trino Authentications (#17593)
* feat: support Trino Authentications
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* docs: Trino Authentications
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* chore(supeset.utils.core): move all database utils to database utils module (#18058)
* chore(plugin-chart-echarts): add types to controls (#18059)
* fix(generator): more cleanup to plugin framework (#18027)
* fix(generator): more cleanup to plugin framework
* fix typo and package name
* add docs
* fix typo
* Update superset-frontend/webpack.config.js
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
* fix generator reference
* add steps to tutorial and fix package version
* refine docs/readme
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
* feat(advanced analytics): support groupby in resample (#18045)
* fix(dashboard): scope of nativefilter not update (#18048)
* fix(generator): add lockfile and fix styling issues (#18073)
* fix(generator): add lockfile and fix styling issues
* fix margins and remove redundant scroll
* update tutorial
* refactor(sql_lab): SQL Lab Persistent Saved State (#17771)
* a lot of console logs
* testing
* test
* added saved_query to remoteId
* created useEffect so that title properly changes in modal
* Update superset-frontend/src/SqlLab/actions/sqlLab.js
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
* refactor(example_data): replace the way the birth_names data is loaded to DB (#18060)
* refactor: replace the way the birth_names data is loaded to DB
* fix failed unit test
* fix failed unit test
* fix failed tests
* fix pass wrong flag of support datetime type
* remove unused fixture
* feat: add chart description in info tooltip (#17207)
* feat: add chart list description
* fix: text overflow
* fix: text-overflow with line-height
* Correction of proper names format in README (#18087)
* chore: added SEO routes
* fix can't use examples helpers on non app context based environment (#18086)
* chore: split CLI into multiple files (#18082)
* chore: split CLI into multiple files
* Update tests
* Who fixes the fixtures?
* Add subcommands dynamically
* Rebase
* fix misspelling (#18097)
* refactor: sqleditorleftbar to functional (#17807)
* Working on converting sqleditorleftbar to functional component
* Creating draft PR to address bug
* Still working on solving re rendering bug
* infinite rerender fix
* Creating draft PR to address bug
* Cleaning up in preparation for push
* Made changes suggested by Elizabeth
* Fixed issues as per Lindsey's comment
Co-authored-by: Arash <arash.afghahi@gmail.com>
* fix rat excludes and headers
* fix(docs): fix path of image for "Create New Chart" (#18089)
* Migrate Checkbox story to tsx - see #18100 (#18101)
Looks good!
* refactor: migrate RowCountLabel to TypeScript & added story (#18105)
* enable superbook for explore component
* migrate RowCountLabel to TypeScript
* add storybook for RowCountLabel
* fix: logging warning on dataframe (don't use python's warnings) (#18111)
* fix: logging warning on dataframe (don't use python's warnings)
* lint
* update changelog and updating for 1.4.0 (#18083)
* feat: Adds a key-value endpoint to store charts form data (#17882)
* feat: Adds a key-value endpoint to store charts form data
* Fixes linting problems
* Removes the query_params from the endpoints
* Refactors the commands
* Removes unused imports
* Changes the parameters to use dataclass
* Adds more access tests
* Gets the first dataset while testing
* Adds unit tests for the check_access function
* Changes the can_access check
* Always check for dataset access
* fix(explore): fix chart embed code modal glitch (#17843)
* feat(plugin-chart-echarts): support non-timeseries x-axis (#17917)
* feat(plugin-chart-echarts): support non-timeseries x-axis
* fix tests
* change formula return type from Date to number
* add x_axis test coverage
* rename func and improve coverage
* add x-axis control to bar chart
* remove redundant console.log
* fix description
* make x-axis control mandatory
* 🙃
* fix x-axis formatter
* fix showValues
* fix implicit rDTTM_ALIAS references in postProcessing
* replace TIME_COLUMN with DTTM_ALIAS
* fix remaining implicit indexes
* fix: Disable filtering on wide result sets (#18021)
* fix: handle null values in time-series table (#18039)
* cleanup column_type_mappings (#17569)
Signed-off-by: Đặng Minh Dũng <dungdm93@live.com>
* important change to MakeFile (#18037)
* add missing is_timeseries to pivot op
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
* feat(country-map): added new countries in country-chart-map (#18081)
* chore: migrating storybook jsx to typescript #18100 (#18133)
* Migrating storybook jsx to typescript #18100
* Migrating storybook jsx to typescript
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
* feat(annotation): add toast feedback to annotation templates (#18116)
* feat(dashboard): add toast feedback to dashboard actions (#18114)
* feat(explore): more toast feedback on user actions in Explore (#18108)
* feat(explore): add toasts feedback when user copies chart url
* Show toast message when updating chart properties
* Change toast type to success when saving chart
* Use success toast from props
* Fix tests
* Use withToasts instead of dispatch
* Use PropertiesModalProps instead of any
* Docs: fix typo (#18125)
* fix: undefined error when adding extra sequential color scheme (#18152)
* feat: allow assets to be managed externally (#18093)
* feat: allow assets to be managed externally
* Use server_default
* chore: use pkg_resources for cleaner config (#18130)
* refactor: Moves the Explore form_data endpoint (#18151)
* refactor: Moves the Explore form_data endpoint
* Removes unused imports
* Fixes openapi schema error
* Fixes typo
* Renames and UPDATING.md
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
Co-authored-by: Hugh A. Miles II <hughmil3s@gmail.com>
Co-authored-by: ofekisr <35701650+ofekisr@users.noreply.github.com>
Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com>
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
Co-authored-by: Yongjie Zhao <yongjie.zhao@gmail.com>
Co-authored-by: Stephen Liu <750188453@qq.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Adam Dobrawy <ad-m@users.noreply.github.com>
Co-authored-by: Beto Dealmeida <roberto@dealmeida.net>
Co-authored-by: Emily Wu <86927881+em0227@users.noreply.github.com>
Co-authored-by: Josue Lugaro <82119536+JosueLugaro@users.noreply.github.com>
Co-authored-by: Arash <arash.afghahi@gmail.com>
Co-authored-by: Ville Brofeldt <ville.v.brofeldt@gmail.com>
Co-authored-by: Daniel Vaz Gaspar <danielvazgaspar@gmail.com>
Co-authored-by: Elizabeth Thompson <eschutho@gmail.com>
Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com>
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Hammad-Raza <hammadraza42@hotmail.com>
Co-authored-by: jayakrishnankk <kk.jayakrishnan@gmail.com>
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
Co-authored-by: Farid Rener <proteusvacuum@users.noreply.github.com>
* remove unneeded requirement
Co-authored-by: Corbin Robb <31329271+corbinrobb@users.noreply.github.com>
Co-authored-by: Corbin Robb <corbin@Corbins-MacBook-Pro.local>
Co-authored-by: Daniel W <61300812+The-hyphen-user@users.noreply.github.com>
Co-authored-by: Geido <60598000+geido@users.noreply.github.com>
Co-authored-by: Srini Kadamati <skadamat@gmail.com>
Co-authored-by: Grace Guo <grace.guo@airbnb.com>
Co-authored-by: Đặng Minh Dũng <dungdm93@live.com>
Co-authored-by: AAfghahi <48933336+AAfghahi@users.noreply.github.com>
Co-authored-by: ofekisr <35701650+ofekisr@users.noreply.github.com>
Co-authored-by: Ville Brofeldt <33317356+villebro@users.noreply.github.com>
Co-authored-by: Kamil Gabryjelski <kamil.gabryjelski@gmail.com>
Co-authored-by: Yongjie Zhao <yongjie.zhao@gmail.com>
Co-authored-by: Stephen Liu <750188453@qq.com>
Co-authored-by: Lyndsi Kay Williams <55605634+lyndsiWilliams@users.noreply.github.com>
Co-authored-by: Adam Dobrawy <ad-m@users.noreply.github.com>
Co-authored-by: Beto Dealmeida <roberto@dealmeida.net>
Co-authored-by: Emily Wu <86927881+em0227@users.noreply.github.com>
Co-authored-by: Josue Lugaro <82119536+JosueLugaro@users.noreply.github.com>
Co-authored-by: Arash <arash.afghahi@gmail.com>
Co-authored-by: Ville Brofeldt <ville.v.brofeldt@gmail.com>
Co-authored-by: Daniel Vaz Gaspar <danielvazgaspar@gmail.com>
Co-authored-by: Elizabeth Thompson <eschutho@gmail.com>
Co-authored-by: Michael S. Molina <70410625+michael-s-molina@users.noreply.github.com>
Co-authored-by: Erik Ritter <erik.ritter@airbnb.com>
Co-authored-by: Hammad-Raza <hammadraza42@hotmail.com>
Co-authored-by: jayakrishnankk <kk.jayakrishnan@gmail.com>
Co-authored-by: Jayakrishnan Karolil <jayakrishnan.karolil@nielsen.com>
Co-authored-by: Farid Rener <proteusvacuum@users.noreply.github.com>
305 lines
12 KiB
Plaintext
305 lines
12 KiB
Plaintext
---
|
||
title: Configuring Superset
|
||
hide_title: true
|
||
sidebar_position: 3
|
||
version: 1
|
||
---
|
||
|
||
## Configuring Superset
|
||
|
||
### Configuration
|
||
|
||
To configure your application, you need to create a file `superset_config.py` and add it to your
|
||
`PYTHONPATH`. Here are some of the parameters you can set in that file:
|
||
|
||
```
|
||
# Superset specific config
|
||
ROW_LIMIT = 5000
|
||
|
||
SUPERSET_WEBSERVER_PORT = 8088
|
||
|
||
# Flask App Builder configuration
|
||
# Your App secret key
|
||
SECRET_KEY = '\2\1thisismyscretkey\1\2\e\y\y\h'
|
||
|
||
# The SQLAlchemy connection string to your database backend
|
||
# This connection defines the path to the database that stores your
|
||
# superset metadata (slices, connections, tables, dashboards, ...).
|
||
# Note that the connection information to connect to the datasources
|
||
# you want to explore are managed directly in the web UI
|
||
SQLALCHEMY_DATABASE_URI = 'sqlite:////path/to/superset.db'
|
||
|
||
# Flask-WTF flag for CSRF
|
||
WTF_CSRF_ENABLED = True
|
||
# Add endpoints that need to be exempt from CSRF protection
|
||
WTF_CSRF_EXEMPT_LIST = []
|
||
# A CSRF token that expires in 1 year
|
||
WTF_CSRF_TIME_LIMIT = 60 * 60 * 24 * 365
|
||
|
||
# Set this API key to enable Mapbox visualizations
|
||
MAPBOX_API_KEY = ''
|
||
```
|
||
|
||
All the parameters and default values defined in
|
||
[https://github.com/apache/superset/blob/master/superset/config.py](https://github.com/apache/superset/blob/master/superset/config.py)
|
||
can be altered in your local `superset_config.py`. Administrators will want to read through the file
|
||
to understand what can be configured locally as well as the default values in place.
|
||
|
||
Since `superset_config.py` acts as a Flask configuration module, it can be used to alter the
|
||
settings Flask itself, as well as Flask extensions like `flask-wtf`, `flask-caching`, `flask-migrate`,
|
||
and `flask-appbuilder`. Flask App Builder, the web framework used by Superset, offers many
|
||
configuration settings. Please consult the
|
||
[Flask App Builder Documentation](https://flask-appbuilder.readthedocs.org/en/latest/config.html)
|
||
for more information on how to configure it.
|
||
|
||
Make sure to change:
|
||
|
||
- `SQLALCHEMY_DATABASE_URI`: by default it is stored at ~/.superset/superset.db
|
||
- `SECRET_KEY`: to a long random string
|
||
|
||
If you need to exempt endpoints from CSRF (e.g. if you are running a custom auth postback endpoint),
|
||
you can add the endpoints to `WTF_CSRF_EXEMPT_LIST`:
|
||
|
||
```
|
||
WTF_CSRF_EXEMPT_LIST = [‘’]
|
||
```
|
||
|
||
### Running on a WSGI HTTP Server
|
||
|
||
While you can run Superset on NGINX or Apache, we recommend using Gunicorn in async mode. This
|
||
enables impressive concurrency even and is fairly easy to install and configure. Please refer to the
|
||
documentation of your preferred technology to set up this Flask WSGI application in a way that works
|
||
well in your environment. Here’s an async setup known to work well in production:
|
||
|
||
```
|
||
-w 10 \
|
||
-k gevent \
|
||
--timeout 120 \
|
||
-b 0.0.0.0:6666 \
|
||
--limit-request-line 0 \
|
||
--limit-request-field_size 0 \
|
||
--statsd-host localhost:8125 \
|
||
"superset.app:create_app()"
|
||
```
|
||
|
||
Refer to the [Gunicorn documentation](https://docs.gunicorn.org/en/stable/design.html) for more
|
||
information. _Note that the development web server (`superset run` or `flask run`) is not intended
|
||
for production use._
|
||
|
||
If you're not using Gunicorn, you may want to disable the use of `flask-compress` by setting
|
||
`COMPRESS_REGISTER = False` in your `superset_config.py`.
|
||
|
||
### Configuration Behind a Load Balancer
|
||
|
||
If you are running superset behind a load balancer or reverse proxy (e.g. NGINX or ELB on AWS), you
|
||
may need to utilize a healthcheck endpoint so that your load balancer knows if your superset
|
||
instance is running. This is provided at `/health` which will return a 200 response containing “OK”
|
||
if the the webserver is running.
|
||
|
||
If the load balancer is inserting `X-Forwarded-For/X-Forwarded-Proto` headers, you should set
|
||
`ENABLE_PROXY_FIX = True` in the superset config file (`superset_config.py`) to extract and use the
|
||
headers.
|
||
|
||
In case the reverse proxy is used for providing SSL encryption, an explicit definition of the
|
||
`X-Forwarded-Proto` may be required. For the Apache webserver this can be set as follows:
|
||
|
||
```
|
||
RequestHeader set X-Forwarded-Proto "https"
|
||
```
|
||
|
||
### Custom OAuth2 Configuration
|
||
|
||
Beyond FAB supported providers (Github, Twitter, LinkedIn, Google, Azure, etc), its easy to connect
|
||
Superset with other OAuth2 Authorization Server implementations that support “code” authorization.
|
||
|
||
Make sure the pip package [`Authlib`](https://authlib.org/) is installed on the webserver.
|
||
|
||
First, configure authorization in Superset `superset_config.py`.
|
||
|
||
```python
|
||
AUTH_TYPE = AUTH_OAUTH
|
||
OAUTH_PROVIDERS = [
|
||
{ 'name':'egaSSO',
|
||
'token_key':'access_token', # Name of the token in the response of access_token_url
|
||
'icon':'fa-address-card', # Icon for the provider
|
||
'remote_app': {
|
||
'client_id':'myClientId', # Client Id (Identify Superset application)
|
||
'client_secret':'MySecret', # Secret for this Client Id (Identify Superset application)
|
||
'client_kwargs':{
|
||
'scope': 'read' # Scope for the Authorization
|
||
},
|
||
'access_token_method':'POST', # HTTP Method to call access_token_url
|
||
'access_token_params':{ # Additional parameters for calls to access_token_url
|
||
'client_id':'myClientId'
|
||
},
|
||
'access_token_headers':{ # Additional headers for calls to access_token_url
|
||
'Authorization': 'Basic Base64EncodedClientIdAndSecret'
|
||
},
|
||
'api_base_url':'https://myAuthorizationServer/oauth2AuthorizationServer/',
|
||
'access_token_url':'https://myAuthorizationServer/oauth2AuthorizationServer/token',
|
||
'authorize_url':'https://myAuthorizationServer/oauth2AuthorizationServer/authorize'
|
||
}
|
||
}
|
||
]
|
||
|
||
# Will allow user self registration, allowing to create Flask users from Authorized User
|
||
AUTH_USER_REGISTRATION = True
|
||
|
||
# The default user self registration role
|
||
AUTH_USER_REGISTRATION_ROLE = "Public"
|
||
```
|
||
|
||
Then, create a `CustomSsoSecurityManager` that extends `SupersetSecurityManager` and overrides
|
||
`oauth_user_info`:
|
||
|
||
```python
|
||
import logging
|
||
from superset.security import SupersetSecurityManager
|
||
|
||
class CustomSsoSecurityManager(SupersetSecurityManager):
|
||
|
||
def oauth_user_info(self, provider, response=None):
|
||
logging.debug("Oauth2 provider: {0}.".format(provider))
|
||
if provider == 'egaSSO':
|
||
# As example, this line request a GET to base_url + '/' + userDetails with Bearer Authentication,
|
||
# and expects that authorization server checks the token, and response with user details
|
||
me = self.appbuilder.sm.oauth_remotes[provider].get('userDetails').data
|
||
logging.debug("user_data: {0}".format(me))
|
||
return { 'name' : me['name'], 'email' : me['email'], 'id' : me['user_name'], 'username' : me['user_name'], 'first_name':'', 'last_name':''}
|
||
...
|
||
```
|
||
|
||
This file must be located at the same directory than `superset_config.py` with the name
|
||
`custom_sso_security_manager.py`. Finally, add the following 2 lines to `superset_config.py`:
|
||
|
||
```
|
||
from custom_sso_security_manager import CustomSsoSecurityManager
|
||
CUSTOM_SECURITY_MANAGER = CustomSsoSecurityManager
|
||
```
|
||
|
||
**Notes**
|
||
|
||
- The redirect URL will be `https://<superset-webserver>/oauth-authorized/<provider-name>`
|
||
When configuring an OAuth2 authorization provider if needed. For instance, the redirect URL will
|
||
be `https://<superset-webserver>/oauth-authorized/egaSSO` for the above configuration.
|
||
|
||
- If an OAuth2 authorization server supports OpenID Connect 1.0, you could configure its configuration
|
||
document URL only without providing `api_base_url`, `access_token_url`, `authorize_url` and other
|
||
required options like user info endpoint, jwks uri etc. For instance:
|
||
```python
|
||
OAUTH_PROVIDERS = [
|
||
{ 'name':'egaSSO',
|
||
'token_key':'access_token', # Name of the token in the response of access_token_url
|
||
'icon':'fa-address-card', # Icon for the provider
|
||
'remote_app': {
|
||
'client_id':'myClientId', # Client Id (Identify Superset application)
|
||
'client_secret':'MySecret', # Secret for this Client Id (Identify Superset application)
|
||
'server_metadata_url': 'https://myAuthorizationServer/.well-known/openid-configuration'
|
||
}
|
||
}
|
||
]
|
||
```
|
||
|
||
### Flask app Configuration Hook
|
||
|
||
`FLASK_APP_MUTATOR` is a configuration function that can be provided in your environment, receives
|
||
the app object and can alter it in any way. For example, add `FLASK_APP_MUTATOR` into your
|
||
`superset_config.py` to setup session cookie expiration time to 24 hours:
|
||
|
||
```python
|
||
from flask import session
|
||
from flask import Flask
|
||
|
||
|
||
def make_session_permanent():
|
||
'''
|
||
Enable maxAge for the cookie 'session'
|
||
'''
|
||
session.permanent = True
|
||
|
||
# Set up max age of session to 24 hours
|
||
PERMANENT_SESSION_LIFETIME = timedelta(hours=24)
|
||
def FLASK_APP_MUTATOR(app: Flask) -> None:
|
||
app.before_request_funcs.setdefault(None, []).append(make_session_permanent)
|
||
```
|
||
|
||
### Feature Flags
|
||
|
||
To support a diverse set of users, Superset has some features that are not enabled by default. For
|
||
example, some users have stronger security restrictions, while some others may not. So Superset
|
||
allow users to enable or disable some features by config. For feature owners, you can add optional
|
||
functionalities in Superset, but will be only affected by a subset of users.
|
||
|
||
You can enable or disable features with flag from `superset_config.py`:
|
||
|
||
```python
|
||
FEATURE_FLAGS = {
|
||
'CLIENT_CACHE': False,
|
||
'ENABLE_EXPLORE_JSON_CSRF_PROTECTION': False,
|
||
'PRESTO_EXPAND_DATA': False,
|
||
}
|
||
```
|
||
|
||
A current list of feature flags can be found in [RESOURCES/FEATURE_FLAGS.md](https://github.com/apache/superset/blob/master/RESOURCES/FEATURE_FLAGS.md).
|
||
|
||
### SIP 15
|
||
|
||
[Superset Improvement Proposal 15](https://github.com/apache/superset/issues/6360) aims to
|
||
ensure that time intervals are handled in a consistent and transparent manner for both the Druid and
|
||
SQLAlchemy connectors.
|
||
|
||
Prior to SIP-15 SQLAlchemy used inclusive endpoints however these may behave like exclusive for
|
||
string columns (due to lexicographical ordering) if no formatting was defined and the column
|
||
formatting did not conform to an ISO 8601 date-time (refer to the SIP for details).
|
||
|
||
To remedy this rather than having to define the date/time format for every non-IS0 8601 date-time
|
||
column, once can define a default column mapping on a per database level via the `extra` parameter:
|
||
|
||
```
|
||
{
|
||
"python_date_format_by_column_name": {
|
||
"ds": "%Y-%m-%d"
|
||
}
|
||
}
|
||
```
|
||
|
||
**New Deployments**
|
||
|
||
All new deployments should enable SIP-15 by setting this value in `superset_config.py`:
|
||
|
||
```
|
||
SIP_15_ENABLED = True
|
||
|
||
```
|
||
|
||
**Existing Deployments**
|
||
|
||
Given that it is not apparent whether the chart creator was aware of the time range inconsistencies
|
||
(and adjusted the endpoints accordingly) changing the behavior of all charts is overly aggressive.
|
||
Instead SIP-15 proivides a soft transistion allowing producers (chart owners) to see the impact of
|
||
the proposed change and adjust their charts accordingly.
|
||
|
||
Prior to enabling SIP-15, existing deployments should communicate to their users the impact of the
|
||
change and define a grace period end date (exclusive of course) after which all charts will conform
|
||
to the [start, end) interval.
|
||
|
||
```python
|
||
from dateime import date
|
||
|
||
SIP_15_ENABLED = True
|
||
SIP_15_GRACE_PERIOD_END = date(<YYYY>, <MM>, <DD>)
|
||
```
|
||
|
||
To aid with transparency the current endpoint behavior is explicitly called out in the chart time
|
||
range (post SIP-15 this will be [start, end) for all connectors and databases). One can override the
|
||
defaults on a per database level via the `extra` parameter.
|
||
|
||
```python
|
||
{
|
||
"time_range_endpoints": ["inclusive", "inclusive"]
|
||
}
|
||
```
|
||
|
||
Note in a future release the interim SIP-15 logic will be removed (including the
|
||
`time_grain_endpoints` form-data field) via a code change and Alembic migration.
|