mirror of
https://github.com/inventree/InvenTree.git
synced 2025-04-28 11:36:44 +00:00
* Squashed commit of the following: commit 52d7ff0f650bbcfa2d93ac96562b44269d3812a7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 23:03:20 2024 +0100 fixed lookup commit 0d076eaea89dce24f08af247479b3b4dff1b4df3 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 23:03:08 2024 +0100 switched to pathlib for lookup commit 473e75eda205793769946e923748356ffd7e5b4b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:52:30 2024 +0100 fix wrong url response commit fd74f8d703399c19cb3616ea3b2656a50cd7a6e5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 21:14:38 2024 +0100 switched to ruff for import sorting commit f83fedbbb8de261ff8c706e179519e58e7a91064 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 21:03:14 2024 +0100 switched to single quotes everywhere commit a92442e60e23be0ff5dcf42d222b0d95823ecb9b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:58:23 2024 +0100 added autofixes commit cc66c93136fcae8a701810a4f4f38ef3b570be61 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:56:47 2024 +0100 enable autoformat commit 1f343606ec1f2a99acf8a37b9900d78a8fb37282 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:42:14 2024 +0100 Squashed commit of the following: commit f5cf7b2e7872fc19633321713965763d1890b495 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:36:57 2024 +0100 fixed reqs commit 9d845bee98befa4e53c2ac3c783bd704369e3ad2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:32:35 2024 +0100 disable autofix/format commit aff5f271484c3500df7ddde043767c008ce4af21 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:50 2024 +0100 adjust checks commit 47271cf1efa848ec8374a0d83b5646d06fffa6e7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:22 2024 +0100 reorder order of operations commit e1bf178b40b3f0d2d59ba92209156c43095959d2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:01:09 2024 +0100 adapted ruff settings to better fit code base commit ad7d88a6f4f15c9552522131c4e207256fc2bbf6 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:59:45 2024 +0100 auto fixed docstring commit a2e54a760e17932dbbc2de0dec23906107f2cda9 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:46:35 2024 +0100 fix getattr useage commit cb80c73bc6c0be7f5d2ed3cc9b2ac03fdefd5c41 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:25:09 2024 +0100 fix requirements file commit b7780bbd21a32007f3b0ce495b519bf59bb19bf5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:42:28 2024 +0100 fix removed sections commit 71f1681f55c15f62c16c1d7f30a745adc496db97 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:41:21 2024 +0100 fix djlint syntax commit a0bcf1bccef8a8ffd482f38e2063bc9066e1d759 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:35:28 2024 +0100 remove flake8 from code base commit 22475b31cc06919785be046e007915e43f356793 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:34:56 2024 +0100 remove flake8 from code base commit 0413350f14773ac6161473e0cfb069713c13c691 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:39 2024 +0100 moved ruff section commit d90c48a0bf98befdfacbbb093ee56cdb28afb40d Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:24 2024 +0100 move djlint config to pyproject commit c5ce55d5119bf2e35e429986f62f875c86178ae1 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:20:39 2024 +0100 added isort again commit 42a41d23afc280d4ee6f0e640148abc6f460f05a Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:19:02 2024 +0100 move config section commit 85692331816348cb1145570340d1f6488a8265cc Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:17:52 2024 +0100 fix codespell error commit 2897c6704d1311a800ce5aa47878d96d6980b377 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 17:29:21 2024 +0100 replaced flake8 with ruff mostly for speed improvements * enable docstring checks * fix docstrings * fixed D417 Missing argument description * Squashed commit of the following: commit d3b795824b5d6d1c0eda67150b45b5cd672b3f6b Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:56:17 2024 +0100 fixed source path commit 0bac0c19b88897a19d5c995e4ff50427718b827e Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:47:53 2024 +0100 fixed req commit 9f61f01d9cc01f1fb7123102f3658c890469b8ce Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 22:45:18 2024 +0100 added missing toml req commit 91b71ed24a6761b629768d0ad8829fec2819a966 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:49:50 2024 +0100 moved isort config commit 12460b04196b12d0272d40552402476d5492fea5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:43:22 2024 +0100 remove flake8 section from setup.cfg commit f5cf7b2e7872fc19633321713965763d1890b495 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:36:57 2024 +0100 fixed reqs commit 9d845bee98befa4e53c2ac3c783bd704369e3ad2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:32:35 2024 +0100 disable autofix/format commit aff5f271484c3500df7ddde043767c008ce4af21 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:50 2024 +0100 adjust checks commit 47271cf1efa848ec8374a0d83b5646d06fffa6e7 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:28:22 2024 +0100 reorder order of operations commit e1bf178b40b3f0d2d59ba92209156c43095959d2 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 20:01:09 2024 +0100 adapted ruff settings to better fit code base commit ad7d88a6f4f15c9552522131c4e207256fc2bbf6 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:59:45 2024 +0100 auto fixed docstring commit a2e54a760e17932dbbc2de0dec23906107f2cda9 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:46:35 2024 +0100 fix getattr useage commit cb80c73bc6c0be7f5d2ed3cc9b2ac03fdefd5c41 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 19:25:09 2024 +0100 fix requirements file commit b7780bbd21a32007f3b0ce495b519bf59bb19bf5 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:42:28 2024 +0100 fix removed sections commit 71f1681f55c15f62c16c1d7f30a745adc496db97 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:41:21 2024 +0100 fix djlint syntax commit a0bcf1bccef8a8ffd482f38e2063bc9066e1d759 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:35:28 2024 +0100 remove flake8 from code base commit 22475b31cc06919785be046e007915e43f356793 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:34:56 2024 +0100 remove flake8 from code base commit 0413350f14773ac6161473e0cfb069713c13c691 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:39 2024 +0100 moved ruff section commit d90c48a0bf98befdfacbbb093ee56cdb28afb40d Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:24:24 2024 +0100 move djlint config to pyproject commit c5ce55d5119bf2e35e429986f62f875c86178ae1 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:20:39 2024 +0100 added isort again commit 42a41d23afc280d4ee6f0e640148abc6f460f05a Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:19:02 2024 +0100 move config section commit 85692331816348cb1145570340d1f6488a8265cc Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 18:17:52 2024 +0100 fix codespell error commit 2897c6704d1311a800ce5aa47878d96d6980b377 Author: Matthias Mair <code@mjmair.com> Date: Sun Jan 7 17:29:21 2024 +0100 replaced flake8 with ruff mostly for speed improvements * fix pyproject * make docstrings more uniform * auto-format * fix order * revert url change
247 lines
7.2 KiB
Python
247 lines
7.2 KiB
Python
"""Custom mkdocs hooks, using the mkdocs-simple-hooks plugin."""
|
|
|
|
import json
|
|
import os
|
|
import re
|
|
from datetime import datetime
|
|
from distutils.version import StrictVersion
|
|
|
|
import requests
|
|
|
|
|
|
def fetch_rtd_versions():
|
|
"""Get a list of RTD docs versions to build the version selector."""
|
|
print('Fetching documentation versions from ReadTheDocs')
|
|
|
|
versions = []
|
|
|
|
def make_request(url, headers):
|
|
"""Make a single request to the RTD API."""
|
|
response = requests.get(url, headers=headers)
|
|
|
|
if response.status_code != 200:
|
|
print(f'Error fetching RTD versions: {response.status_code}')
|
|
return
|
|
|
|
data = json.loads(response.text)
|
|
|
|
for entry in data['results']:
|
|
slug = entry['slug']
|
|
ref = entry['ref']
|
|
url = entry['urls']['documentation']
|
|
aliases = []
|
|
|
|
if ref is not None:
|
|
aliases.append(slug)
|
|
|
|
version = ref or slug
|
|
|
|
if version == 'latest':
|
|
continue
|
|
|
|
versions.append({'version': version, 'title': version, 'aliases': aliases})
|
|
|
|
if data['next']:
|
|
make_request(data['next'], headers)
|
|
|
|
# Fetch the list of versions from the RTD API
|
|
token = os.environ.get('RTD_TOKEN', None)
|
|
if token:
|
|
headers = {'Authorization': f'Token {token}'}
|
|
url = 'https://readthedocs.org/api/v3/projects/inventree/versions/?active=true&limit=50'
|
|
make_request(url, headers)
|
|
else:
|
|
print('No RTD token found - skipping RTD version fetch')
|
|
|
|
# Sort versions by version number
|
|
versions = sorted(versions, key=lambda x: StrictVersion(x['version']), reverse=True)
|
|
|
|
# Add "latest" version first
|
|
if not any((x['title'] == 'latest' for x in versions)):
|
|
versions.insert(
|
|
0,
|
|
{
|
|
'title': 'Development',
|
|
'version': 'latest',
|
|
'aliases': ['main', 'latest', 'development'],
|
|
},
|
|
)
|
|
|
|
# Ensure we have the 'latest' version
|
|
current_version = os.environ.get('READTHEDOCS_VERSION', None)
|
|
|
|
if current_version and not any((x['title'] == current_version for x in versions)):
|
|
versions.append({
|
|
'version': current_version,
|
|
'title': current_version,
|
|
'aliases': [],
|
|
})
|
|
|
|
output_filename = os.path.join(os.path.dirname(__file__), 'versions.json')
|
|
|
|
print('Discovered the following versions:')
|
|
print(versions)
|
|
|
|
with open(output_filename, 'w') as file:
|
|
json.dump(versions, file, indent=2)
|
|
|
|
|
|
def get_release_data():
|
|
"""Return InvenTree release information.
|
|
|
|
- First look to see if 'releases.json' file exists
|
|
- If data does not exist in this file, request via the github API
|
|
"""
|
|
json_file = os.path.join(os.path.dirname(__file__), 'releases.json')
|
|
|
|
releases = []
|
|
|
|
if os.path.exists(json_file):
|
|
# Release information has been cached to file
|
|
|
|
print("Loading release information from 'releases.json'")
|
|
with open(json_file) as f:
|
|
return json.loads(f.read())
|
|
|
|
# Download release information via the GitHub API
|
|
print('Fetching InvenTree release information from api.github.com:')
|
|
releases = []
|
|
|
|
# Keep making API requests until we run out of results
|
|
page = 1
|
|
|
|
while 1:
|
|
url = f'https://api.github.com/repos/inventree/inventree/releases?page={page}&per_page=150'
|
|
|
|
response = requests.get(url, timeout=30)
|
|
assert response.status_code == 200
|
|
|
|
data = json.loads(response.text)
|
|
|
|
if len(data) == 0:
|
|
break
|
|
|
|
for item in data:
|
|
releases.append(item)
|
|
|
|
page += 1
|
|
|
|
# Cache these results to file
|
|
with open(json_file, 'w') as f:
|
|
print("Saving release information to 'releases.json'")
|
|
f.write(json.dumps(releases))
|
|
|
|
return releases
|
|
|
|
|
|
def on_config(config, *args, **kwargs):
|
|
"""Run when the mkdocs config is loaded.
|
|
|
|
We want to be able to provide a *dynamic* config.site_url parameter to mkdocs,
|
|
which tells it the base url, e.g.
|
|
|
|
- https://readthedocs.io/en/latest
|
|
- https://readthedocs.io/de/0.5.1
|
|
|
|
Further, we need to know if we are building on readthedocs at all!
|
|
|
|
readthedocs provides some environment variables:
|
|
- https://docs.readthedocs.io/en/stable/builds.html#build-environment
|
|
|
|
We can use these to determine (at run time) where we are hosting
|
|
"""
|
|
rtd = os.environ.get('READTHEDOCS', False)
|
|
|
|
# Check for 'versions.json' file
|
|
# If it does not exist, we need to fetch it from the RTD API
|
|
if os.path.exists(os.path.join(os.path.dirname(__file__), 'versions.json')):
|
|
print("Found 'versions.json' file")
|
|
else:
|
|
fetch_rtd_versions()
|
|
|
|
if rtd:
|
|
rtd_version = os.environ['READTHEDOCS_VERSION']
|
|
rtd_language = os.environ['READTHEDOCS_LANGUAGE']
|
|
|
|
site_url = f'https://docs.inventree.org/{rtd_language}/{rtd_version}'
|
|
assets_dir = f'/{rtd_language}/{rtd_version}/assets'
|
|
|
|
print('Building within READTHEDOCS environment!')
|
|
print(f' - Version: {rtd_version}')
|
|
print(f' - Language: {rtd_language}')
|
|
|
|
# Add *all* readthedocs related keys
|
|
readthedocs = {}
|
|
|
|
for key in os.environ.keys():
|
|
if key.startswith('READTHEDOCS_'):
|
|
k = key.replace('READTHEDOCS_', '').lower()
|
|
readthedocs[k] = os.environ[key]
|
|
|
|
# Supply this to the context
|
|
config['readthedocs'] = readthedocs
|
|
|
|
# Determine if we want to display a 'version' banner
|
|
# Basically we do, *unless* we are displaying the "stable" version
|
|
config['version_banner'] = rtd_version != 'stable'
|
|
|
|
else:
|
|
print("'READTHEDOCS' environment variable not found")
|
|
print('Building for localhost configuration!')
|
|
|
|
assets_dir = '/assets'
|
|
site_url = config['site_url']
|
|
|
|
config['readthedocs'] = False
|
|
|
|
config['assets_dir'] = assets_dir
|
|
config['site_url'] = site_url
|
|
|
|
print(f"config.site_url = '{site_url}'")
|
|
print(f"config.assets_dir = '{assets_dir}'")
|
|
|
|
release_data = get_release_data()
|
|
|
|
releases = []
|
|
|
|
for item in release_data:
|
|
# Ignore draft releases
|
|
if item['draft']:
|
|
continue
|
|
|
|
tag = item['tag_name']
|
|
|
|
# Check that the tag is formatted correctly
|
|
re.match(r'^\d+\.\d+\.\d+$', tag)
|
|
|
|
if not re.match:
|
|
print(f'Found badly formatted release: {tag}')
|
|
continue
|
|
|
|
# Check if there is a local file with release information
|
|
local_path = os.path.join(os.path.dirname(__file__), 'releases', f'{tag}.md')
|
|
|
|
if os.path.exists(local_path):
|
|
item['local_path'] = local_path
|
|
|
|
# Extract the date
|
|
item['date'] = item['published_at'].split('T')[0]
|
|
|
|
date = datetime.fromisoformat(item['date'])
|
|
|
|
# First tagged docker release was 2021-04-18
|
|
if date > datetime(year=2021, month=4, day=17):
|
|
item['docker'] = True
|
|
|
|
# Add a "prefix" so we can split by sub version
|
|
item['prefix'] = '.'.join(tag.split('.')[:-1])
|
|
|
|
releases.append(item)
|
|
|
|
print(f'- found {len(releases)} releases.')
|
|
|
|
# Sort releases by descending date
|
|
config['releases'] = sorted(releases, key=lambda it: it['date'], reverse=True)
|
|
|
|
return config
|