api.py 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. """This script automates the generation of the QMK API data.
  2. """
  3. from pathlib import Path
  4. from shutil import copyfile
  5. import json
  6. from milc import cli
  7. from qmk.datetime import current_datetime
  8. from qmk.info import info_json
  9. from qmk.info_json_encoder import InfoJSONEncoder
  10. from qmk.json_schema import json_load
  11. from qmk.keyboard import list_keyboards
  12. @cli.subcommand('Creates a new keymap for the keyboard of your choosing', hidden=False if cli.config.user.developer else True)
  13. def generate_api(cli):
  14. """Generates the QMK API data.
  15. """
  16. api_data_dir = Path('api_data')
  17. v1_dir = api_data_dir / 'v1'
  18. keyboard_all_file = v1_dir / 'keyboards.json' # A massive JSON containing everything
  19. keyboard_list_file = v1_dir / 'keyboard_list.json' # A simple list of keyboard targets
  20. keyboard_aliases_file = v1_dir / 'keyboard_aliases.json' # A list of historical keyboard names and their new name
  21. keyboard_metadata_file = v1_dir / 'keyboard_metadata.json' # All the data configurator/via needs for initialization
  22. usb_file = v1_dir / 'usb.json' # A mapping of USB VID/PID -> keyboard target
  23. if not api_data_dir.exists():
  24. api_data_dir.mkdir()
  25. kb_all = {}
  26. usb_list = {}
  27. # Generate and write keyboard specific JSON files
  28. for keyboard_name in list_keyboards():
  29. kb_all[keyboard_name] = info_json(keyboard_name)
  30. keyboard_dir = v1_dir / 'keyboards' / keyboard_name
  31. keyboard_info = keyboard_dir / 'info.json'
  32. keyboard_readme = keyboard_dir / 'readme.md'
  33. keyboard_readme_src = Path('keyboards') / keyboard_name / 'readme.md'
  34. keyboard_dir.mkdir(parents=True, exist_ok=True)
  35. keyboard_info.write_text(json.dumps({'last_updated': current_datetime(), 'keyboards': {keyboard_name: kb_all[keyboard_name]}}))
  36. if keyboard_readme_src.exists():
  37. copyfile(keyboard_readme_src, keyboard_readme)
  38. if 'usb' in kb_all[keyboard_name]:
  39. usb = kb_all[keyboard_name]['usb']
  40. if 'vid' in usb and usb['vid'] not in usb_list:
  41. usb_list[usb['vid']] = {}
  42. if 'pid' in usb and usb['pid'] not in usb_list[usb['vid']]:
  43. usb_list[usb['vid']][usb['pid']] = {}
  44. if 'vid' in usb and 'pid' in usb:
  45. usb_list[usb['vid']][usb['pid']][keyboard_name] = usb
  46. # Write the global JSON files
  47. keyboard_all_file.write_text(json.dumps({'last_updated': current_datetime(), 'keyboards': kb_all}, cls=InfoJSONEncoder))
  48. usb_file.write_text(json.dumps({'last_updated': current_datetime(), 'usb': usb_list}, cls=InfoJSONEncoder))
  49. keyboard_list = sorted(kb_all)
  50. keyboard_list_file.write_text(json.dumps({'last_updated': current_datetime(), 'keyboards': keyboard_list}, cls=InfoJSONEncoder))
  51. keyboard_aliases = json_load(Path('data/mappings/keyboard_aliases.json'))
  52. keyboard_aliases_file.write_text(json.dumps({'last_updated': current_datetime(), 'keyboard_aliases': keyboard_aliases}, cls=InfoJSONEncoder))
  53. keyboard_metadata = {
  54. 'last_updated': current_datetime(),
  55. 'keyboards': keyboard_list,
  56. 'keyboard_aliases': keyboard_aliases,
  57. 'usb': usb_list
  58. }
  59. keyboard_metadata_file.write_text(json.dumps(keyboard_metadata, cls=InfoJSONEncoder))