Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[FIX] Manifest URL #14

Merged
merged 10 commits into from
Jun 25, 2024
15 changes: 9 additions & 6 deletions src/modals/PluginDataModal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,18 +62,21 @@ export class PluginDataModal extends Modal {
new Notice('Github <username>/<repository> do not match the pattern!');
return;
}
// Check a manifest could be fetched
const manifest = await fetchManifest(repo);
if (!manifest) {
new Notice('Github repository could not be found!');
return;
}
// check there are releases for the repo
const releases = await fetchReleases(repo);
if (!releases || releases.length <= 0) {
new Notice('No releases found for this plugin. May it do not have any.');
return;
}
// Check a manifest could be fetched
const manifest =
await fetchManifest(undefined,undefined,releases[0]) ||
await fetchManifest(repo, releases[0].tag_name) ||
await fetchManifest(repo);
if (!manifest) {
new Notice('Plugin manifest could not be found in releases, tag ref, or default branch!');
4Source marked this conversation as resolved.
Show resolved Hide resolved
return;
}
// Combine data
const pluginInfo = Object.assign({}, manifest, { repo, releases }) as PluginInfo;
pluginInfo.targetVersion = pluginInfo.version;
Expand Down
43 changes: 22 additions & 21 deletions src/modals/PluginTroubleshootingModal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { Modal, PluginManifest, Setting, debounce } from 'obsidian';
import { ICON_ACCEPT, ICON_DENY } from 'src/constants';
import VarePlugin from 'src/main';
import { PluginInfo } from 'src/settings/SettingsInterface';
import { Release, fetchManifest, fetchReleases, repositoryRegEx } from 'src/util/GitHub';
import { /* Release, */ fetchManifest, fetchReleases, repositoryRegEx } from 'src/util/GitHub';
4Source marked this conversation as resolved.
Show resolved Hide resolved

export class PluginTroubleshootingModal extends Modal {
plugin: VarePlugin;
Expand All @@ -23,7 +23,7 @@ export class PluginTroubleshootingModal extends Modal {
let repository = this.pluginInfo.repo.split('/').at(1) || '';
let manifest: PluginManifest | undefined;
let hasManifest = false;
let releases: Partial<Release>[] | undefined;
// let releases: Partial<Release>[] | undefined;
anonhostpi marked this conversation as resolved.
Show resolved Hide resolved
4Source marked this conversation as resolved.
Show resolved Hide resolved
let hasReleases = false;

// Debonce text input
Expand Down Expand Up @@ -67,13 +67,29 @@ export class PluginTroubleshootingModal extends Modal {
.onClick(() => {
this.update();
}));

const releases = await fetchReleases(this.pluginInfo.repo);
hasReleases = releases !== undefined && (releases.length > 0);
new Setting(contentEl)
.setName('Test releases')
.setDesc(hasReleases ? '' : 'Could not find releases on GitHub. May this plugin did not have any.')
.addExtraButton(button => button
.setIcon(hasReleases ? ICON_ACCEPT : ICON_DENY)
.setTooltip(hasReleases ? '' : 'Try again?')
.setDisabled(hasReleases)
.onClick(() => {
this.update();
}));
4Source marked this conversation as resolved.
Show resolved Hide resolved

if (repositoryRegEx.test(this.pluginInfo.repo)) {
manifest = await fetchManifest(this.pluginInfo.repo);
if (repositoryRegEx.test(this.pluginInfo.repo) || hasReleases) {
const last_release = releases ? releases[0] : undefined;
manifest =
await fetchManifest(undefined,undefined,last_release) ||
await fetchManifest(this.pluginInfo.repo);
hasManifest = manifest !== undefined;
new Setting(contentEl)
.setName('Test connection')
.setDesc(hasManifest ? '' : 'Repo could not be found on GitHub. Is everything typed correctly?')
.setName('Test manifest')
.setDesc(hasManifest ? '' : 'Manifest could not be found on GitHub. Is everything including the repo typed correctly?')
anonhostpi marked this conversation as resolved.
Show resolved Hide resolved
.addExtraButton(button => button
.setIcon(hasManifest ? ICON_ACCEPT : ICON_DENY)
.setTooltip(hasManifest ? '' : 'Try again?')
Expand All @@ -83,21 +99,6 @@ export class PluginTroubleshootingModal extends Modal {
}));
}

if (hasManifest) {
releases = await fetchReleases(this.pluginInfo.repo);
hasReleases = releases !== undefined && (releases.length > 0);
new Setting(contentEl)
.setName('Test releases')
.setDesc(hasReleases ? '' : 'Could not find releases on GitHub. May this plugin did not have any.')
.addExtraButton(button => button
.setIcon(hasReleases ? ICON_ACCEPT : ICON_DENY)
.setTooltip(hasReleases ? '' : 'Try again?')
.setDisabled(hasReleases)
.onClick(() => {
this.update();
}));
}

new Setting(contentEl)
.addButton(button => button
.setButtonText('Save')
Expand Down
6 changes: 5 additions & 1 deletion src/settings/SettingsTab.ts
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,11 @@ export class VareSettingTab extends PluginSettingTab {
.onClick(async () => {
try {
// Fetch the manifest from GitHub
const manifest = await fetchManifest(plugin.repo, plugin.targetVersion);
const release = plugin.releases.find(release => release.tag_name === plugin.targetVersion);
const manifest =
await fetchManifest(undefined,undefined,release) ||
await fetchManifest(plugin.repo, plugin.targetVersion) ||
await fetchManifest(plugin.repo);
if (!manifest) {
throw Error('No manifest found for this plugin!');
}
Expand Down
11 changes: 7 additions & 4 deletions src/util/GitHub.ts
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ export async function fetchReleases(repository: string): Promise<Partial<Release
return {
tag_name: value.tag_name,
prerelease: value.prerelease,
assets: value.assets,
};
});
return releases;
Expand All @@ -99,16 +100,18 @@ export async function fetchReleases(repository: string): Promise<Partial<Release
* Fetch the manifest for a plugin
* @param repository The <user>/<repo> of the plugin
* @param tag_name The name of the tag associated with a release. Required if a specific manifest version is needed.
* @param release The release object of the plugin. Used to replicate Obsidian's behavior of fetching the manifest for the plugin.
* @returns The plugin manifest object
*/
export async function fetchManifest(repository: string, tag_name?: string): Promise<PluginManifest | undefined> {
const URL = `https://raw.githubusercontent.com/${repository}/${tag_name ? tag_name : 'HEAD'}/manifest.json`;
export async function fetchManifest(repository?: string, tag_name?: string, release?: Partial<Release>): Promise<PluginManifest | undefined> {
const download_url: string | undefined = release?.assets?.find((asset: Asset) => asset.name === 'manifest.json')?.browser_download_url;
const url: string = download_url ? download_url : `https://raw.githubusercontent.com/${repository}/${tag_name ? tag_name : 'HEAD'}/manifest.json`;
4Source marked this conversation as resolved.
Show resolved Hide resolved
try {
if (!repositoryRegEx.test(repository)) {
if (repository && !repositoryRegEx.test(repository)) {
throw Error('Repository string do not match the pattern!');
}
// Do a request to the url
const response = await request({ url: URL });
const response = await request({ url });

// Process the response
return (await JSON.parse(response)) as PluginManifest;
Expand Down