summaryrefslogtreecommitdiff
path: root/frontend/src/store.tsx
blob: 10c35406d33acc6a4db851b9acd8f3984ea59d34 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import { ConfirmModal, showModal, staticClasses } from 'decky-frontend-lib';

import { Plugin } from './plugin';

export interface StorePluginVersion {
  name: string;
  hash: string;
}

export interface StorePlugin {
  id: number;
  name: string;
  versions: StorePluginVersion[];
  author: string;
  description: string;
  tags: string[];
  image_url: string;
}

export interface LegacyStorePlugin {
  artifact: string;
  versions: {
    [version: string]: string;
  };
  author: string;
  description: string;
  tags: string[];
}

// name: version
export type PluginUpdateMapping = Map<string, StorePluginVersion>;

export async function getPluginList(): Promise<StorePlugin[]> {
  let version = await window.DeckyPluginLoader.updateVersion();
  return fetch('https://beta.deckbrew.xyz/plugins', {
    method: 'GET',
    headers: {
      'X-Decky-Version': version.current,
    },
  }).then((r) => r.json());
}

export function getLegacyPluginList(): Promise<LegacyStorePlugin[]> {
  return fetch('https://plugins.deckbrew.xyz/get_plugins', {
    method: 'GET',
  }).then((r) => r.json());
}

export async function installFromURL(url: string) {
  const splitURL = url.split('/');
  await window.DeckyPluginLoader.callServerMethod('install_plugin', {
    name: splitURL[splitURL.length - 1].replace('.zip', ''),
    artifact: url,
  });
}

export function requestLegacyPluginInstall(plugin: LegacyStorePlugin, selectedVer: string) {
  showModal(
    <ConfirmModal
      onOK={() => {
        window.DeckyPluginLoader.callServerMethod('install_plugin', {
          name: plugin.artifact,
          artifact: `https://github.com/${plugin.artifact}/archive/refs/tags/${selectedVer}.zip`,
          version: selectedVer,
          hash: plugin.versions[selectedVer],
        });
      }}
      onCancel={() => {
        // do nothing
      }}
    >
      <div className={staticClasses.Title} style={{ flexDirection: 'column', boxShadow: 'unset' }}>
        Using legacy plugins
      </div>
      You are currently installing a <b>legacy</b> plugin. Legacy plugins are no longer supported and may have issues.
      Legacy plugins do not support gamepad input. To interact with a legacy plugin, you will need to use the
      touchscreen.
    </ConfirmModal>,
  );
}

export async function requestPluginInstall(plugin: string, selectedVer: StorePluginVersion) {
  await window.DeckyPluginLoader.callServerMethod('install_plugin', {
    name: plugin,
    artifact: `https://cdn.tzatzikiweeb.moe/file/steam-deck-homebrew/versions/${selectedVer.hash}.zip`,
    version: selectedVer.name,
    hash: selectedVer.hash,
  });
}

export async function checkForUpdates(plugins: Plugin[]): Promise<PluginUpdateMapping> {
  const serverData = await getPluginList();
  const updateMap = new Map<string, StorePluginVersion>();
  for (let plugin of plugins) {
    const remotePlugin = serverData?.find((x) => x.name == plugin.name);
    if (remotePlugin && remotePlugin.versions?.length > 0 && plugin.version != remotePlugin?.versions?.[0]?.name) {
      updateMap.set(plugin.name, remotePlugin.versions[0]);
    }
  }
  return updateMap;
}

export function isLegacyPlugin(plugin: LegacyStorePlugin | StorePlugin): plugin is LegacyStorePlugin {
  return 'artifact' in plugin;
}