mirror of
https://github.com/laurent22/joplin.git
synced 2025-04-01 21:24:45 +02:00
All: Improved Joplin Server configuration check to better handle disabled accounts
This commit is contained in:
parent
2db886a4db
commit
72c12354dc
@ -7,6 +7,8 @@ import BaseSyncTarget from './BaseSyncTarget';
|
|||||||
import { FileApi } from './file-api';
|
import { FileApi } from './file-api';
|
||||||
import Logger from './Logger';
|
import Logger from './Logger';
|
||||||
|
|
||||||
|
const staticLogger = Logger.create('SyncTargetJoplinServer');
|
||||||
|
|
||||||
interface FileApiOptions {
|
interface FileApiOptions {
|
||||||
path(): string;
|
path(): string;
|
||||||
userContentPath(): string;
|
userContentPath(): string;
|
||||||
@ -75,10 +77,42 @@ export default class SyncTargetJoplinServer extends BaseSyncTarget {
|
|||||||
|
|
||||||
syncTargetId = syncTargetId === null ? SyncTargetJoplinServer.id() : syncTargetId;
|
syncTargetId = syncTargetId === null ? SyncTargetJoplinServer.id() : syncTargetId;
|
||||||
|
|
||||||
|
let fileApi = null;
|
||||||
try {
|
try {
|
||||||
const fileApi = await newFileApi(syncTargetId, options);
|
fileApi = await newFileApi(syncTargetId, options);
|
||||||
fileApi.requestRepeatCount_ = 0;
|
fileApi.requestRepeatCount_ = 0;
|
||||||
|
} catch (error) {
|
||||||
|
// If there's an error it's probably an application error, but we
|
||||||
|
// can't proceed anyway, so exit.
|
||||||
|
output.errorMessage = error.message;
|
||||||
|
if (error.code) output.errorMessage += ` (Code ${error.code})`;
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
||||||
|
// First we try to fetch info.json. It may not be present if it's a new
|
||||||
|
// sync target but otherwise, if it is, and it's valid, we know the
|
||||||
|
// credentials are valid. We do this test first because it will work
|
||||||
|
// even if account upload is disabled. And we need such account to
|
||||||
|
// successfully login so that they can fix it by deleting extraneous
|
||||||
|
// notes or resources.
|
||||||
|
try {
|
||||||
|
const r = await fileApi.get('info.json');
|
||||||
|
if (r) {
|
||||||
|
const parsed = JSON.parse(r);
|
||||||
|
if (parsed) {
|
||||||
|
output.ok = true;
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
// Ignore because we'll use the next test to check for sure if it
|
||||||
|
// works or not.
|
||||||
|
staticLogger.warn('Could not fetch or parse info.json:', error);
|
||||||
|
}
|
||||||
|
|
||||||
|
// This is a more generic test, which writes a file and tries to read it
|
||||||
|
// back.
|
||||||
|
try {
|
||||||
await fileApi.put('testing.txt', 'testing');
|
await fileApi.put('testing.txt', 'testing');
|
||||||
const result = await fileApi.get('testing.txt');
|
const result = await fileApi.get('testing.txt');
|
||||||
if (result !== 'testing') throw new Error(`Could not access data on server "${options.path()}"`);
|
if (result !== 'testing') throw new Error(`Could not access data on server "${options.path()}"`);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user