mirror of
				https://github.com/inventree/InvenTree.git
				synced 2025-10-26 02:47:41 +00:00 
			
		
		
		
	Merge branch 'master' into make-fields-filterable
This commit is contained in:
		
							
								
								
									
										2
									
								
								.github/workflows/qc_checks.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/qc_checks.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -705,7 +705,7 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} |           GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||||
|       - name: Upload SARIF file |       - name: Upload SARIF file | ||||||
|         uses: github/codeql-action/upload-sarif@3599b3baa15b485a2e49ef411a7a4bb2452e7f93 # pin@v3 |         uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # pin@v3 | ||||||
|         with: |         with: | ||||||
|           sarif_file: results.sarif |           sarif_file: results.sarif | ||||||
|           category: zizmor |           category: zizmor | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/scorecard.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/scorecard.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -37,7 +37,7 @@ jobs: | |||||||
|           persist-credentials: false |           persist-credentials: false | ||||||
|  |  | ||||||
|       - name: "Run analysis" |       - name: "Run analysis" | ||||||
|         uses: ossf/scorecard-action@05b42c624433fc40578a4040d5cf5e36ddca8cde # v2.4.2 |         uses: ossf/scorecard-action@4eaacf0543bb3f2c246792bd56e8cdeffafb205a # v2.4.3 | ||||||
|         with: |         with: | ||||||
|           results_file: results.sarif |           results_file: results.sarif | ||||||
|           results_format: sarif |           results_format: sarif | ||||||
| @@ -67,6 +67,6 @@ jobs: | |||||||
|  |  | ||||||
|       # Upload the results to GitHub's code scanning dashboard. |       # Upload the results to GitHub's code scanning dashboard. | ||||||
|       - name: "Upload to code-scanning" |       - name: "Upload to code-scanning" | ||||||
|         uses: github/codeql-action/upload-sarif@3599b3baa15b485a2e49ef411a7a4bb2452e7f93 # v3.30.5 |         uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 | ||||||
|         with: |         with: | ||||||
|           sarif_file: results.sarif |           sarif_file: results.sarif | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/stale.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/stale.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -16,7 +16,7 @@ jobs: | |||||||
|       pull-requests: write |       pull-requests: write | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/stale@3a9db7e6a41a89f618792c92c0e97cc736e1b13f # pin@v10.0.0 |       - uses: actions/stale@5f858e3efba33a5ca4407a664cc011ad407f2008 # pin@v10.1.0 | ||||||
|         with: |         with: | ||||||
|           repo-token: ${{ secrets.GITHUB_TOKEN }} |           repo-token: ${{ secrets.GITHUB_TOKEN }} | ||||||
|           stale-issue-message: "This issue seems stale. Please react to show this is still important." |           stale-issue-message: "This issue seems stale. Please react to show this is still important." | ||||||
|   | |||||||
| @@ -166,6 +166,18 @@ function detect_envs() { | |||||||
|     export INVENTREE_DB_PASSWORD=$(jq -r '.[].database.PASSWORD' <<< ${INVENTREE_CONF_DATA}) |     export INVENTREE_DB_PASSWORD=$(jq -r '.[].database.PASSWORD' <<< ${INVENTREE_CONF_DATA}) | ||||||
|     export INVENTREE_DB_HOST=$(jq -r '.[].database.HOST' <<< ${INVENTREE_CONF_DATA}) |     export INVENTREE_DB_HOST=$(jq -r '.[].database.HOST' <<< ${INVENTREE_CONF_DATA}) | ||||||
|     export INVENTREE_DB_PORT=$(jq -r '.[].database.PORT' <<< ${INVENTREE_CONF_DATA}) |     export INVENTREE_DB_PORT=$(jq -r '.[].database.PORT' <<< ${INVENTREE_CONF_DATA}) | ||||||
|  |  | ||||||
|  |     # Parse site URL if not already set | ||||||
|  |     if [ -z "${INVENTREE_SITE_URL}" ]; then | ||||||
|  |       # Try to read out the app config | ||||||
|  |       if [ -n "$(inventree config:get INVENTREE_SITE_URL)" ]; then | ||||||
|  |         echo "# POI03| Getting site URL from app config" | ||||||
|  |         export INVENTREE_SITE_URL=$(inventree config:get INVENTREE_SITE_URL) | ||||||
|  |       else | ||||||
|  |         echo "# POI03| Getting site URL from config file" | ||||||
|  |         export INVENTREE_SITE_URL=$(jq -r '.[].site_url' <<< ${INVENTREE_CONF_DATA}) | ||||||
|  |       fi | ||||||
|  |     fi | ||||||
|   else |   else | ||||||
|     echo "# POI03| No config file found: ${INVENTREE_CONFIG_FILE}, using envs or defaults" |     echo "# POI03| No config file found: ${INVENTREE_CONFIG_FILE}, using envs or defaults" | ||||||
|  |  | ||||||
| @@ -190,6 +202,8 @@ function detect_envs() { | |||||||
|     export INVENTREE_DB_HOST=${INVENTREE_DB_HOST:-samplehost} |     export INVENTREE_DB_HOST=${INVENTREE_DB_HOST:-samplehost} | ||||||
|     export INVENTREE_DB_PORT=${INVENTREE_DB_PORT:-123456} |     export INVENTREE_DB_PORT=${INVENTREE_DB_PORT:-123456} | ||||||
|  |  | ||||||
|  |     export INVENTREE_SITE_URL=${INVENTREE_SITE_URL} | ||||||
|  |  | ||||||
|     export SETUP_CONF_LOADED=true |     export SETUP_CONF_LOADED=true | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
| @@ -209,6 +223,7 @@ function detect_envs() { | |||||||
|   fi |   fi | ||||||
|   echo "# POI03|    INVENTREE_DB_HOST=${INVENTREE_DB_HOST}" |   echo "# POI03|    INVENTREE_DB_HOST=${INVENTREE_DB_HOST}" | ||||||
|   echo "# POI03|    INVENTREE_DB_PORT=${INVENTREE_DB_PORT}" |   echo "# POI03|    INVENTREE_DB_PORT=${INVENTREE_DB_PORT}" | ||||||
|  |   echo "# POI03|    INVENTREE_SITE_URL=${INVENTREE_SITE_URL}" | ||||||
| } | } | ||||||
|  |  | ||||||
| function create_initscripts() { | function create_initscripts() { | ||||||
| @@ -313,7 +328,7 @@ function update_or_install() { | |||||||
|   # Run update as app user |   # Run update as app user | ||||||
|   echo "# POI12| Updating InvenTree" |   echo "# POI12| Updating InvenTree" | ||||||
|   sudo -u ${APP_USER} --preserve-env=$SETUP_ENVS bash -c "cd ${APP_HOME} && pip install wheel" |   sudo -u ${APP_USER} --preserve-env=$SETUP_ENVS bash -c "cd ${APP_HOME} && pip install wheel" | ||||||
|   sudo -u ${APP_USER} --preserve-env=$SETUP_ENVS bash -c "cd ${APP_HOME} && invoke update | sed -e 's/^/# POI12| u | /;'" |   sudo -u ${APP_USER} --preserve-env=$SETUP_ENVS bash -c "cd ${APP_HOME} && set -e && invoke update | sed -e 's/^/# POI12| u | /;'" | ||||||
|  |  | ||||||
|   # Make sure permissions are correct again |   # Make sure permissions are correct again | ||||||
|   echo "# POI12| Set permissions for data dir and media: ${DATA_DIR}" |   echo "# POI12| Set permissions for data dir and media: ${DATA_DIR}" | ||||||
| @@ -373,10 +388,15 @@ function set_site() { | |||||||
|  |  | ||||||
|   # Check if INVENTREE_SITE_URL in inventree config |   # Check if INVENTREE_SITE_URL in inventree config | ||||||
|   if [ -z "$(inventree config:get INVENTREE_SITE_URL)" ]; then |   if [ -z "$(inventree config:get INVENTREE_SITE_URL)" ]; then | ||||||
|     echo "# POI14| Setting up InvenTree site URL" |     # Prefer current INVENTREE_SITE_URL if set | ||||||
|     inventree config:set INVENTREE_SITE_URL=http://${INVENTREE_IP} |     if [ -n "${INVENTREE_SITE_URL}" ]; then | ||||||
|  |       inventree config:set INVENTREE_SITE_URL=${INVENTREE_SITE_URL} | ||||||
|  |     else | ||||||
|  |       echo "# POI14| Setting up InvenTree site URL" | ||||||
|  |       inventree config:set INVENTREE_SITE_URL=http://${INVENTREE_IP} | ||||||
|  |     fi | ||||||
|   else |   else | ||||||
|     echo "# POI14| Site URL already set - skipping" |     echo "# POI14| Site URL already set to '$INVENTREE_SITE_URL' - skipping" | ||||||
|   fi |   fi | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -385,11 +405,16 @@ function final_message() { | |||||||
|   echo -e "####################################################################################" |   echo -e "####################################################################################" | ||||||
|   echo -e "This InvenTree install uses nginx, the settings for the webserver can be found in" |   echo -e "This InvenTree install uses nginx, the settings for the webserver can be found in" | ||||||
|   echo -e "${SETUP_NGINX_FILE}" |   echo -e "${SETUP_NGINX_FILE}" | ||||||
|   echo -e "Try opening InvenTree with either\nhttp://localhost/ or http://${INVENTREE_IP}/\n" |   echo -e "Try opening InvenTree with any of \n${INVENTREE_SITE_URL} , http://localhost/ or http://${INVENTREE_IP}/ \n" | ||||||
|   echo -e "Admin user data:" |   # Print admin user data only if set | ||||||
|   echo -e "   Email: ${INVENTREE_ADMIN_EMAIL}" |   if ["${INVENTREE_ADMIN_USER}" ]; then | ||||||
|   echo -e "   Username: ${INVENTREE_ADMIN_USER}" |     echo -e "Admin user data:" | ||||||
|   echo -e "   Password: ${INVENTREE_ADMIN_PASSWORD}" |     echo -e "   Email: ${INVENTREE_ADMIN_EMAIL}" | ||||||
|  |     echo -e "   Username: ${INVENTREE_ADMIN_USER}" | ||||||
|  |     echo -e "   Password: ${INVENTREE_ADMIN_PASSWORD}" | ||||||
|  |   else | ||||||
|  |     echo -e "No admin set during this operation - depending on the deployment method a admin user might have been created with an initial password saved in `${SETUP_ADMIN_PASSWORD_FILE}`" | ||||||
|  |   fi | ||||||
|   echo -e "####################################################################################" |   echo -e "####################################################################################" | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ echo "# POI01| Importing functions" | |||||||
| echo "# POI01| Functions imported" | echo "# POI01| Functions imported" | ||||||
|  |  | ||||||
| # Envs that should be passed to setup commands | # Envs that should be passed to setup commands | ||||||
| export SETUP_ENVS=PATH,APP_HOME,INVENTREE_MEDIA_ROOT,INVENTREE_STATIC_ROOT,INVENTREE_BACKUP_DIR,INVENTREE_SITE_URL,INVENTREE_PLUGINS_ENABLED,INVENTREE_PLUGIN_FILE,INVENTREE_CONFIG_FILE,INVENTREE_SECRET_KEY_FILE,INVENTREE_DB_ENGINE,INVENTREE_DB_NAME,INVENTREE_DB_USER,INVENTREE_DB_PASSWORD,INVENTREE_DB_HOST,INVENTREE_DB_PORT,INVENTREE_ADMIN_USER,INVENTREE_ADMIN_EMAIL,INVENTREE_ADMIN_PASSWORD,SETUP_NGINX_FILE,SETUP_ADMIN_PASSWORD_FILE,SETUP_NO_CALLS,SETUP_DEBUG,SETUP_EXTRA_PIP,SETUP_PYTHON,SETUP_ADMIN_NOCREATION | export SETUP_ENVS=PATH,APP_HOME,INVENTREE_MEDIA_ROOT,INVENTREE_STATIC_ROOT,INVENTREE_BACKUP_DIR,INVENTREE_PLUGINS_ENABLED,INVENTREE_PLUGIN_FILE,INVENTREE_CONFIG_FILE,INVENTREE_SECRET_KEY_FILE,INVENTREE_DB_ENGINE,INVENTREE_DB_NAME,INVENTREE_DB_USER,INVENTREE_DB_PASSWORD,INVENTREE_DB_HOST,INVENTREE_DB_PORT,INVENTREE_ADMIN_USER,INVENTREE_ADMIN_EMAIL,INVENTREE_ADMIN_PASSWORD,INVENTREE_SITE_URL,SETUP_NGINX_FILE,SETUP_ADMIN_PASSWORD_FILE,SETUP_NO_CALLS,SETUP_DEBUG,SETUP_EXTRA_PIP,SETUP_PYTHON,SETUP_ADMIN_NOCREATION | ||||||
|  |  | ||||||
| # Get the envs | # Get the envs | ||||||
| detect_local_env | detect_local_env | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ echo "# PRI01| Running preinstall script - start - $(date)" | |||||||
| PATH=${APP_HOME}/env/bin:${APP_HOME}/:/sbin:/bin:/usr/sbin:/usr/bin: | PATH=${APP_HOME}/env/bin:${APP_HOME}/:/sbin:/bin:/usr/sbin:/usr/bin: | ||||||
|  |  | ||||||
| # Envs that should be passed to setup commands | # Envs that should be passed to setup commands | ||||||
| export SETUP_ENVS=PATH,APP_HOME,INVENTREE_MEDIA_ROOT,INVENTREE_STATIC_ROOT,INVENTREE_BACKUP_DIR,INVENTREE_PLUGINS_ENABLED,INVENTREE_PLUGIN_FILE,INVENTREE_CONFIG_FILE,INVENTREE_SECRET_KEY_FILE,INVENTREE_DB_ENGINE,INVENTREE_DB_NAME,INVENTREE_DB_USER,INVENTREE_DB_PASSWORD,INVENTREE_DB_HOST,INVENTREE_DB_PORT,INVENTREE_ADMIN_USER,INVENTREE_ADMIN_EMAIL,INVENTREE_ADMIN_PASSWORD,SETUP_NGINX_FILE,SETUP_ADMIN_PASSWORD_FILE,SETUP_NO_CALLS,SETUP_DEBUG,SETUP_EXTRA_PIP,SETUP_PYTHON | export SETUP_ENVS=PATH,APP_HOME,INVENTREE_MEDIA_ROOT,INVENTREE_STATIC_ROOT,INVENTREE_BACKUP_DIR,INVENTREE_PLUGINS_ENABLED,INVENTREE_PLUGIN_FILE,INVENTREE_CONFIG_FILE,INVENTREE_SECRET_KEY_FILE,INVENTREE_DB_ENGINE,INVENTREE_DB_NAME,INVENTREE_DB_USER,INVENTREE_DB_PASSWORD,INVENTREE_DB_HOST,INVENTREE_DB_PORT,INVENTREE_ADMIN_USER,INVENTREE_ADMIN_EMAIL,INVENTREE_ADMIN_PASSWORD,INVENTREE_SITE_URL,SETUP_NGINX_FILE,SETUP_ADMIN_PASSWORD_FILE,SETUP_NO_CALLS,SETUP_DEBUG,SETUP_EXTRA_PIP,SETUP_PYTHON | ||||||
|  |  | ||||||
| if test -f "${APP_HOME}/env/bin/pip"; then | if test -f "${APP_HOME}/env/bin/pip"; then | ||||||
|   # Check if clear-generated is available |   # Check if clear-generated is available | ||||||
|   | |||||||
| @@ -88,11 +88,17 @@ Note that inherited BOM Line Items only flow "downwards" in the variant inherita | |||||||
|  |  | ||||||
| ## BOM Creation | ## BOM Creation | ||||||
|  |  | ||||||
| BOMs can be created manually, by adjusting individual line items, or by upload an existing BOM file. | BOMs can be created manually, by adjusting individual line items, or by uploading (importing) an existing BOM file. | ||||||
|  |  | ||||||
|  | ### Importing a BOM | ||||||
|  |  | ||||||
|  | BOM data can be imported from an existing file (such as CSV or Excel) from the *BOM* panel for a particular part/assembly. This process is a special case of the more general [data import process](../settings/import.md). | ||||||
|  |  | ||||||
|  | At the top of the *BOM* panel, click on the {{ icon("file-arrow-left", color="green", title="Import BOM Data") }} icon to open the import dialog. | ||||||
|  |  | ||||||
| ### Add BOM Item | ### Add BOM Item | ||||||
|  |  | ||||||
| To manually add a BOM item, navigate to the part/assembly detail page then click on the "BOM" tab. On top of the tab view, click on the {{ icon("edit", color="blue", title="Edit") }} icon then, after the page reloads, click on the {{ icon("plus-circle") }} icon. | To manually add a BOM item, navigate to the part/assembly detail page then click on the *BOM* panel tab. On top of the *BOM* view, click on the {{ icon("edit", color="blue", title="Edit") }} icon then, after the page reloads, click on the {{ icon("plus-circle") }} icon. | ||||||
|  |  | ||||||
| The `Create BOM Item` form will be displayed: | The `Create BOM Item` form will be displayed: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,9 +9,12 @@ Errors - These are critical errors which should be addressed as soon as possible | |||||||
| #### INVE-E1 | #### INVE-E1 | ||||||
| **No frontend included - Backend/web** | **No frontend included - Backend/web** | ||||||
|  |  | ||||||
| Only stable / production releases of InvenTree include the frontend panel. This is both a measure of resource-saving and attack surface reduction. If you want to use the frontend panel, you can either:″ | Only stable / production releases of InvenTree include the frontend panel. This is both a measure of resource-saving and attack surface reduction. | ||||||
|  |  | ||||||
|  | If you want to use the frontend panel, you can either: | ||||||
|  |  | ||||||
| - use a docker image that is version-tagged or the stable version | - use a docker image that is version-tagged or the stable version | ||||||
| - use a package version that is from the stable or version stream | - use a package version that is from the stable or version stream - if you are and it is not working, run `sudo inventree run cli update` to re-run the upgrade | ||||||
| - install node and yarn on the server to build the frontend with the [invoke](../start/invoke.md) task `int.frontend-build` | - install node and yarn on the server to build the frontend with the [invoke](../start/invoke.md) task `int.frontend-build` | ||||||
|  |  | ||||||
| Raise an issue if none of these options work. | Raise an issue if none of these options work. | ||||||
|   | |||||||
| @@ -83,7 +83,7 @@ Date and time values are stored in the database in UTC format, and are converted | |||||||
|  |  | ||||||
| By default, the InvenTree server will not automatically apply database migrations. When the InvenTree installation is updated (*or a plugin is installed which requires database migrations*), database migrations must be applied manually by the system administrator. | By default, the InvenTree server will not automatically apply database migrations. When the InvenTree installation is updated (*or a plugin is installed which requires database migrations*), database migrations must be applied manually by the system administrator. | ||||||
|  |  | ||||||
| With "auto update" enabled, the InvenTree server will automatically apply database migrations as required. To enable automatic database updates, set `INVENTREE_AUTO_UPDATE` to `True`. | With "auto update" enabled, the InvenTree server will automatically apply database migrations as required when plugins are changed. To enable automatic database updates, set `INVENTREE_AUTO_UPDATE` to `True`. However, this setting is not sufficient when updating your InvenTree installation - you must still ensure that you follow the required steps for updating InvenTree as per your installation method. | ||||||
|  |  | ||||||
| ## Debugging and Logging Options | ## Debugging and Logging Options | ||||||
|  |  | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ def default_sentry_dsn(): | |||||||
|     return 'https://3928ccdba1d34895abde28031fd00100@o378676.ingest.sentry.io/6494600' |     return 'https://3928ccdba1d34895abde28031fd00100@o378676.ingest.sentry.io/6494600' | ||||||
|  |  | ||||||
|  |  | ||||||
| def sentry_ignore_errors(): | def sentry_ignore_errors():  # pragma: no cover | ||||||
|     """Return a list of error types to ignore. |     """Return a list of error types to ignore. | ||||||
|  |  | ||||||
|     These error types will *not* be reported to sentry.io. |     These error types will *not* be reported to sentry.io. | ||||||
| @@ -40,7 +40,7 @@ def sentry_ignore_errors(): | |||||||
|     ] |     ] | ||||||
|  |  | ||||||
|  |  | ||||||
| def init_sentry(dsn, sample_rate, tags): | def init_sentry(dsn, sample_rate, tags):  # pragma: no cover | ||||||
|     """Initialize sentry.io error reporting.""" |     """Initialize sentry.io error reporting.""" | ||||||
|     logger.info('Initializing sentry.io integration') |     logger.info('Initializing sentry.io integration') | ||||||
|  |  | ||||||
| @@ -66,7 +66,7 @@ def init_sentry(dsn, sample_rate, tags): | |||||||
|     sentry_sdk.set_tag('git_date', InvenTree.version.inventreeCommitDate()) |     sentry_sdk.set_tag('git_date', InvenTree.version.inventreeCommitDate()) | ||||||
|  |  | ||||||
|  |  | ||||||
| def report_exception(exc, scope: Optional[dict] = None): | def report_exception(exc, scope: Optional[dict] = None):  # pragma: no cover | ||||||
|     """Report an exception to sentry.io.""" |     """Report an exception to sentry.io.""" | ||||||
|     assert settings.TESTING == False, ( |     assert settings.TESTING == False, ( | ||||||
|         'report_exception should not be called in testing mode' |         'report_exception should not be called in testing mode' | ||||||
|   | |||||||
| @@ -170,7 +170,7 @@ structlog.configure( | |||||||
|     cache_logger_on_first_use=True, |     cache_logger_on_first_use=True, | ||||||
| ) | ) | ||||||
| # Optionally add database-level logging | # Optionally add database-level logging | ||||||
| if get_setting('INVENTREE_DB_LOGGING', 'db_logging', False): | if get_setting('INVENTREE_DB_LOGGING', 'db_logging', False):  # pragma: no cover | ||||||
|     LOGGING['loggers'] = {'django.db.backends': {'level': LOG_LEVEL or 'DEBUG'}} |     LOGGING['loggers'] = {'django.db.backends': {'level': LOG_LEVEL or 'DEBUG'}} | ||||||
|  |  | ||||||
| # Get a logger instance for this setup file | # Get a logger instance for this setup file | ||||||
| @@ -369,7 +369,7 @@ MIDDLEWARE = CONFIG.get( | |||||||
|  |  | ||||||
| # In DEBUG mode, add support for django-querycount | # In DEBUG mode, add support for django-querycount | ||||||
| # Ref: https://github.com/bradmontgomery/django-querycount | # Ref: https://github.com/bradmontgomery/django-querycount | ||||||
| if DEBUG and get_boolean_setting( | if DEBUG and get_boolean_setting(  # pragma: no cover | ||||||
|     'INVENTREE_DEBUG_QUERYCOUNT', 'debug_querycount', False |     'INVENTREE_DEBUG_QUERYCOUNT', 'debug_querycount', False | ||||||
| ): | ): | ||||||
|     MIDDLEWARE.append('querycount.middleware.QueryCountMiddleware') |     MIDDLEWARE.append('querycount.middleware.QueryCountMiddleware') | ||||||
| @@ -405,7 +405,7 @@ AUTHENTICATION_BACKENDS = ( | |||||||
|  |  | ||||||
| # LDAP support | # LDAP support | ||||||
| LDAP_AUTH = get_boolean_setting('INVENTREE_LDAP_ENABLED', 'ldap.enabled', False) | LDAP_AUTH = get_boolean_setting('INVENTREE_LDAP_ENABLED', 'ldap.enabled', False) | ||||||
| if LDAP_AUTH: | if LDAP_AUTH:  # pragma: no cover | ||||||
|     import django_auth_ldap.config  # type: ignore[unresolved-import] |     import django_auth_ldap.config  # type: ignore[unresolved-import] | ||||||
|     import ldap  # type: ignore[unresolved-import] |     import ldap  # type: ignore[unresolved-import] | ||||||
|  |  | ||||||
| @@ -943,7 +943,7 @@ Q_CLUSTER = { | |||||||
| } | } | ||||||
|  |  | ||||||
| # Configure django-q sentry integration | # Configure django-q sentry integration | ||||||
| if SENTRY_ENABLED and SENTRY_DSN: | if SENTRY_ENABLED and SENTRY_DSN:  # pragma: no cover | ||||||
|     Q_CLUSTER['error_reporter'] = {'sentry': {'dsn': SENTRY_DSN}} |     Q_CLUSTER['error_reporter'] = {'sentry': {'dsn': SENTRY_DSN}} | ||||||
|  |  | ||||||
| if GLOBAL_CACHE_ENABLED:  # pragma: no cover | if GLOBAL_CACHE_ENABLED:  # pragma: no cover | ||||||
| @@ -1296,14 +1296,14 @@ FRONTEND_SETTINGS = config.get_frontend_settings(debug=DEBUG) | |||||||
| FRONTEND_URL_BASE = FRONTEND_SETTINGS['base_url'] | FRONTEND_URL_BASE = FRONTEND_SETTINGS['base_url'] | ||||||
|  |  | ||||||
| # region auth | # region auth | ||||||
| for app in SOCIAL_BACKENDS: | for app in SOCIAL_BACKENDS:  # pragma: no cover | ||||||
|     # Ensure that the app starts with 'allauth.socialaccount.providers' |     # Ensure that the app starts with 'allauth.socialaccount.providers' | ||||||
|     social_prefix = 'allauth.socialaccount.providers.' |     social_prefix = 'allauth.socialaccount.providers.' | ||||||
|  |  | ||||||
|     if not app.startswith(social_prefix):  # pragma: no cover |     if not app.startswith(social_prefix): | ||||||
|         app = social_prefix + app |         app = social_prefix + app | ||||||
|  |  | ||||||
|     INSTALLED_APPS.append(app)  # pragma: no cover |     INSTALLED_APPS.append(app) | ||||||
|  |  | ||||||
| SOCIALACCOUNT_PROVIDERS = get_setting( | SOCIALACCOUNT_PROVIDERS = get_setting( | ||||||
|     'INVENTREE_SOCIAL_PROVIDERS', 'social_providers', None, typecast=dict |     'INVENTREE_SOCIAL_PROVIDERS', 'social_providers', None, typecast=dict | ||||||
| @@ -1331,7 +1331,7 @@ login_attempts = get_setting('INVENTREE_LOGIN_ATTEMPTS', 'login_attempts', 5) | |||||||
| try: | try: | ||||||
|     login_attempts = int(login_attempts) |     login_attempts = int(login_attempts) | ||||||
|     login_attempts = f'{login_attempts}/m,{login_attempts}/m' |     login_attempts = f'{login_attempts}/m,{login_attempts}/m' | ||||||
| except ValueError: | except ValueError:  # pragma: no cover | ||||||
|     pass |     pass | ||||||
|  |  | ||||||
| ACCOUNT_RATE_LIMITS = {'login_failed': login_attempts} | ACCOUNT_RATE_LIMITS = {'login_failed': login_attempts} | ||||||
| @@ -1493,7 +1493,7 @@ FLAGS = { | |||||||
|  |  | ||||||
| # Get custom flags from environment/yaml | # Get custom flags from environment/yaml | ||||||
| CUSTOM_FLAGS = get_setting('INVENTREE_FLAGS', 'flags', None, typecast=dict) | CUSTOM_FLAGS = get_setting('INVENTREE_FLAGS', 'flags', None, typecast=dict) | ||||||
| if CUSTOM_FLAGS: | if CUSTOM_FLAGS:  # pragma: no cover | ||||||
|     if not isinstance(CUSTOM_FLAGS, dict): |     if not isinstance(CUSTOM_FLAGS, dict): | ||||||
|         logger.error('Invalid custom flags, must be valid dict: %s', str(CUSTOM_FLAGS)) |         logger.error('Invalid custom flags, must be valid dict: %s', str(CUSTOM_FLAGS)) | ||||||
|     else: |     else: | ||||||
| @@ -1552,5 +1552,5 @@ OAUTH2_CHECK_EXCLUDED = [  # This setting mutes schema checks for these rule/met | |||||||
|     '/api/webhook/{endpoint}/:post', |     '/api/webhook/{endpoint}/:post', | ||||||
| ] | ] | ||||||
|  |  | ||||||
| if SITE_URL and not TESTING: | if SITE_URL and not TESTING:  # pragma: no cover | ||||||
|     SPECTACULAR_SETTINGS['SERVERS'] = [{'url': SITE_URL}] |     SPECTACULAR_SETTINGS['SERVERS'] = [{'url': SITE_URL}] | ||||||
|   | |||||||
| @@ -38,6 +38,10 @@ class InvenTreeUINotifications(NotificationMixin, InvenTreePlugin): | |||||||
|         if not users: |         if not users: | ||||||
|             return False |             return False | ||||||
|  |  | ||||||
|  |         # Ensure that there is always target object - see https://github.com/inventree/InvenTree/issues/10435 | ||||||
|  |         if not target: | ||||||
|  |             target = self.plugin_config() | ||||||
|  |  | ||||||
|         # Bulk create notification messages for all provided users |         # Bulk create notification messages for all provided users | ||||||
|         for user in users: |         for user in users: | ||||||
|             entries.append( |             entries.append( | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ | |||||||
| </head> | </head> | ||||||
|  |  | ||||||
| <body> | <body> | ||||||
|   <div id="root"></div> |   <div id="root">If you see this text there might be an Issue with your update - see <a href="https://docs.inventree.org/en/stable/settings/error_codes/#inve-e1">INVE-E1</a> in the docs for help</div> | ||||||
|   <div id="spa_settings">{% spa_settings %}</div> |   <div id="spa_settings">{% spa_settings %}</div> | ||||||
|   {% if bundle == "NOT_FOUND" %} |   {% if bundle == "NOT_FOUND" %} | ||||||
|   <div id="spa_bundle_error"> |   <div id="spa_bundle_error"> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user