module.exports = {
async add(remoteConfig, remote) {
+
await writeFile(remoteConfig, remote);
},
async remove(remoteConfig) {
+
await rm(remoteConfig, { force: true })
},
async syncUp(remoteConfig, blogDirectory) {
+
await this._executeMethodOnStrategy(remoteConfig, 'syncUp', blogDirectory);
},
async syncDown(remoteConfig, blogDirectory) {
+
await this._executeMethodOnStrategy(remoteConfig, 'syncDown', blogDirectory);
},
async _executeMethodOnStrategy(remoteConfig, method, blogDirectory) {
+
const remote = await this._ensureConfiguration(remoteConfig);
for (const strategy of internals.strategies) {
},
async _ensureConfiguration(remoteConfig) {
+
try {
const configuration = await readFile(remoteConfig, { encoding: 'utf8' });
return configuration;
const { exec } = require('child_process');
-const { debuglog, promisify } = require('util');
+const { promisify } = require('util');
const internals = {
// Promisified functions
exec: promisify(exec),
-
- debuglog: debuglog('blog'),
};
module.exports = {
canHandle() {
+
// For the future: actually check if it's a valid git url
return true;
},
async syncUp(remote, blogDirectory) {
- let output = null;
-
- output = await internals.exec(`cd ${blogDirectory} && git init`);
- internals.debuglog(output.stderr);
-
- output = await internals.exec(`cd ${blogDirectory} && git add .`);
- internals.debuglog(output.stderr);
- output = await internals.exec(`cd ${blogDirectory} && git commit --allow-empty -m blog-sync-up-${Date.now()}`);
- internals.debuglog(output.stderr);
-
- output = await internals.exec(`cd ${blogDirectory} && git push ${remote} main --force`);
- internals.debuglog(output.stderr);
+ await internals.exec(`cd ${blogDirectory} && git init`);
+ await internals.exec(`cd ${blogDirectory} && git add .`);
+ await internals.exec(`cd ${blogDirectory} && git commit --allow-empty -m blog-sync-up-${Date.now()}`);
+ await internals.exec(`cd ${blogDirectory} && git push ${remote} main --force`);
},
async syncDown(remote, blogDirectory) {
- let output = null;
-
- output = await internals.exec(`cd ${blogDirectory} && git init`);
- internals.debuglog(output.stderr);
-
- output = await internals.exec(`cd ${blogDirectory} && git checkout .`);
- internals.debuglog(output.stderr);
-
- output = await internals.exec(`cd ${blogDirectory} && git clean . -f`);
- internals.debuglog(output.stderr);
- output = await internals.exec(`cd ${blogDirectory} && git pull ${remote} main`);
- internals.debuglog(output.stderr);
+ await internals.exec(`cd ${blogDirectory} && git init`);
+ await internals.exec(`cd ${blogDirectory} && git checkout .`);
+ await internals.exec(`cd ${blogDirectory} && git clean . -f`);
+ await internals.exec(`cd ${blogDirectory} && git pull ${remote} main`);
}
}