2026-03-28 16:22:15 +01:00
|
|
|
const fs = require("fs");
|
|
|
|
|
const path = require("path");
|
2026-05-17 22:11:17 +02:00
|
|
|
const { getObHome } = require("./ob-cli");
|
2026-03-28 16:22:15 +01:00
|
|
|
|
2026-05-17 22:11:17 +02:00
|
|
|
function getObAuthFile(dataDir) {
|
2026-03-28 16:22:15 +01:00
|
|
|
return path.join(
|
2026-05-17 22:11:17 +02:00
|
|
|
getObHome(dataDir),
|
2026-03-28 16:22:15 +01:00
|
|
|
".config",
|
|
|
|
|
"obsidian-headless",
|
|
|
|
|
"auth_token",
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getInternalTokenFile(dataDir) {
|
|
|
|
|
return path.join(dataDir, "auth-token.json");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function loadToken(dataDir) {
|
|
|
|
|
const internalFile = getInternalTokenFile(dataDir);
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(internalFile)) {
|
|
|
|
|
const data = JSON.parse(fs.readFileSync(internalFile, "utf-8"));
|
|
|
|
|
|
|
|
|
|
if (data && data.token) {
|
2026-05-17 22:11:17 +02:00
|
|
|
syncToObCli(dataDir, data.token);
|
2026-03-28 16:22:15 +01:00
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
|
|
|
|
|
// Fall back to ob CLI's own auth file
|
2026-05-17 22:11:17 +02:00
|
|
|
const obAuthFile = getObAuthFile(dataDir);
|
2026-03-28 16:22:15 +01:00
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(obAuthFile)) {
|
|
|
|
|
const token = fs.readFileSync(obAuthFile, "utf-8").trim();
|
|
|
|
|
|
|
|
|
|
if (token) {
|
|
|
|
|
const data = { token };
|
|
|
|
|
saveInternal(dataDir, data);
|
|
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function saveToken(dataDir, tokenData) {
|
|
|
|
|
saveInternal(dataDir, tokenData);
|
2026-05-17 22:11:17 +02:00
|
|
|
syncToObCli(dataDir, tokenData.token);
|
2026-03-28 16:22:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function clearToken(dataDir) {
|
|
|
|
|
const internalFile = getInternalTokenFile(dataDir);
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(internalFile)) {
|
|
|
|
|
fs.unlinkSync(internalFile);
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
|
2026-05-17 22:11:17 +02:00
|
|
|
const obAuthFile = getObAuthFile(dataDir);
|
2026-03-28 16:22:15 +01:00
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(obAuthFile)) {
|
|
|
|
|
fs.unlinkSync(obAuthFile);
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function isAuthenticated(dataDir) {
|
|
|
|
|
const internalFile = getInternalTokenFile(dataDir);
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(internalFile)) {
|
|
|
|
|
const data = JSON.parse(fs.readFileSync(internalFile, "utf-8"));
|
|
|
|
|
return !!(data && data.token);
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2026-06-02 17:42:47 +02:00
|
|
|
function writeSecret(file, contents) {
|
|
|
|
|
fs.writeFileSync(file, contents, { encoding: "utf-8", mode: 0o600 });
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
fs.chmodSync(file, 0o600);
|
|
|
|
|
} catch {}
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-28 16:22:15 +01:00
|
|
|
function saveInternal(dataDir, tokenData) {
|
|
|
|
|
const internalFile = getInternalTokenFile(dataDir);
|
|
|
|
|
const dir = path.dirname(internalFile);
|
|
|
|
|
|
|
|
|
|
if (!fs.existsSync(dir)) {
|
2026-06-02 17:42:47 +02:00
|
|
|
fs.mkdirSync(dir, { recursive: true, mode: 0o700 });
|
2026-03-28 16:22:15 +01:00
|
|
|
}
|
|
|
|
|
|
2026-06-02 17:42:47 +02:00
|
|
|
writeSecret(internalFile, JSON.stringify(tokenData, null, 2));
|
2026-03-28 16:22:15 +01:00
|
|
|
}
|
|
|
|
|
|
2026-05-17 22:11:17 +02:00
|
|
|
function syncToObCli(dataDir, token) {
|
|
|
|
|
const obAuthFile = getObAuthFile(dataDir);
|
2026-03-28 16:22:15 +01:00
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
const dir = path.dirname(obAuthFile);
|
|
|
|
|
|
|
|
|
|
if (!fs.existsSync(dir)) {
|
2026-06-02 17:42:47 +02:00
|
|
|
fs.mkdirSync(dir, { recursive: true, mode: 0o700 });
|
2026-03-28 16:22:15 +01:00
|
|
|
}
|
|
|
|
|
|
2026-06-02 17:42:47 +02:00
|
|
|
writeSecret(obAuthFile, token);
|
2026-03-28 16:22:15 +01:00
|
|
|
} catch {}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getTokenInfo(dataDir) {
|
|
|
|
|
const internalFile = getInternalTokenFile(dataDir);
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
if (fs.existsSync(internalFile)) {
|
|
|
|
|
const data = JSON.parse(fs.readFileSync(internalFile, "utf-8"));
|
|
|
|
|
|
|
|
|
|
if (data && data.token) {
|
|
|
|
|
return { email: data.email || null, name: data.name || null };
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} catch {}
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2026-05-17 22:11:17 +02:00
|
|
|
module.exports = {
|
|
|
|
|
loadToken,
|
|
|
|
|
saveToken,
|
|
|
|
|
clearToken,
|
|
|
|
|
isAuthenticated,
|
|
|
|
|
getTokenInfo,
|
|
|
|
|
};
|