}
catch {};
await this._shift();
- await this._ensurePostsDirectoryExists(join(this.postsDirectory, '0'));
- await this.update(postLocation);
+ const firstDirectory = join(this.postsDirectory, '0');
+ await rm(firstDirectory, { recursive: true, force: true });
+ await this._ensurePostsDirectoryExists(firstDirectory);
+ await this._update(postLocation);
}
/**
await this.syncDown();
}
catch {};
- const metadata = await this._getMetadata();
- await this._ensurePostsDirectoryExists();
- await this._copyPost(postLocation);
- await this._writeMetadata(metadata);
-
- await this._archive(postLocation);
-
- await this.generate();
- try {
- await this.syncUp();
- }
- catch {};
+ const metadata = await this._update();
}
/**
* @instance
*/
async syncDown() {
+ internals.debuglog('Pulling remote state');
await Remote.syncDown(this.remoteConfig, this.blogDirectory)
+ internals.debuglog('Pulled remote state');
}
/**
* @instance
*/
async syncUp() {
+ internals.debuglog('Pushing remote state');
await Remote.syncUp(this.remoteConfig, this.blogDirectory)
+ internals.debuglog('Pushed remote state');
}
+ // Adds the passed path to slot 0, and generates files.
+
+ async _update(postLocation) {
+
+ const metadata = await this._getMetadata();
+ await this._ensurePostsDirectoryExists();
+ await this._copyPost(postLocation);
+ await this._writeMetadata(metadata);
+
+ await this._archive(postLocation);
+
+ await this.generate();
+ try {
+ await this.syncUp();
+ }
+ catch {};
+ }
+
+
// Parses Gemini for each page, copies assets and generates index.
async generate() {
},
async syncUp(remoteConfig, blogDirectory) {
- this._executeMethodOnStrategy(remoteConfig, 'syncUp', blogDirectory);
+ await this._executeMethodOnStrategy(remoteConfig, 'syncUp', blogDirectory);
},
async syncDown(remoteConfig, blogDirectory) {
- this._executeMethodOnStrategy(remoteConfig, 'syncDown', blogDirectory);
+ await this._executeMethodOnStrategy(remoteConfig, 'syncDown', blogDirectory);
},
async _executeMethodOnStrategy(remoteConfig, method, blogDirectory) {
},
async syncUp(remote, blogDirectory) {
- 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`);
+ 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);
},
async syncDown(remote, blogDirectory) {
- 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`);
+ 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);
}
}