summaryrefslogtreecommitdiff
path: root/frontend/src/store.tsx
blob: 3e9d6823f9599cf656319d76e4bd1d3ef27c00d1 (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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import { ModalRoot, 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[];
}

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

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

export function getPluginList(): Promise<StorePlugin[]> {
  return fetch('https://beta.deckbrew.xyz/plugins', {
    method: 'GET',
  }).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 formData = new FormData();
  const splitURL = url.split('/');
  formData.append('name', splitURL[splitURL.length - 1].replace('.zip', ''));
  formData.append('artifact', url);
  await fetch('http://localhost:1337/browser/install_plugin', {
    method: 'POST',
    body: formData,
    credentials: 'include',
    headers: {
      Authentication: window.deckyAuthToken,
    },
  });
}

export function requestLegacyPluginInstall(plugin: LegacyStorePlugin, selectedVer: string) {
  showModal(
    <ModalRoot
      onOK={() => {
        const formData = new FormData();
        formData.append('name', plugin.artifact);
        formData.append('artifact', `https://github.com/${plugin.artifact}/archive/refs/tags/${selectedVer}.zip`);
        formData.append('version', selectedVer);
        formData.append('hash', plugin.versions[selectedVer]);
        fetch('http://localhost:1337/browser/install_plugin', {
          method: 'POST',
          body: formData,
          credentials: 'include',
          headers: {
            Authentication: window.deckyAuthToken,
          },
        });
      }}
      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.
    </ModalRoot>,
  );
}

export async function requestPluginInstall(plugin: string, selectedVer: StorePluginVersion) {
  const formData = new FormData();
  formData.append('name', plugin);
  formData.append('artifact', `https://cdn.tzatzikiweeb.moe/file/steam-deck-homebrew/versions/${selectedVer.hash}.zip`);
  formData.append('version', selectedVer.name);
  formData.append('hash', selectedVer.hash);
  await fetch('http://localhost:1337/browser/install_plugin', {
    method: 'POST',
    body: formData,
    credentials: 'include',
    headers: {
      Authentication: window.deckyAuthToken,
    },
  });
}

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;
}