Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 76628a118c | |||
| 364cc7df48 |
12
README.md
Normal file
12
README.md
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
To use the service in your ci, add the following Task:
|
||||||
|
```yaml
|
||||||
|
deploy:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
|
needs: publish
|
||||||
|
steps:
|
||||||
|
- name: Run updater action
|
||||||
|
uses: https://git.leon-hoppe.de/leon.hoppe/ServiceUpdater@main
|
||||||
|
with:
|
||||||
|
service: ${{ inputs.service }}
|
||||||
|
```
|
||||||
@@ -3,6 +3,9 @@
|
|||||||
namespace ServiceUpdater;
|
namespace ServiceUpdater;
|
||||||
|
|
||||||
public sealed class UpdateWorker(UpdaterConfig config) {
|
public sealed class UpdateWorker(UpdaterConfig config) {
|
||||||
|
|
||||||
|
private int LastExitCode { get; set; }
|
||||||
|
|
||||||
public async IAsyncEnumerable<string> UpdateService(string serviceName) {
|
public async IAsyncEnumerable<string> UpdateService(string serviceName) {
|
||||||
yield return $"Starting update for {serviceName}";
|
yield return $"Starting update for {serviceName}";
|
||||||
|
|
||||||
@@ -10,13 +13,14 @@ public sealed class UpdateWorker(UpdaterConfig config) {
|
|||||||
yield return line;
|
yield return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (LastExitCode != 0)
|
||||||
|
yield break;
|
||||||
|
|
||||||
yield return $"Downloaded changes for {serviceName}";
|
yield return $"Downloaded changes for {serviceName}";
|
||||||
|
|
||||||
await foreach (var line in RunProcess(serviceName, "compose up -d --remove-orphans")) {
|
await foreach (var line in RunProcess(serviceName, "compose up -d --remove-orphans")) {
|
||||||
yield return line;
|
yield return line;
|
||||||
}
|
}
|
||||||
|
|
||||||
yield return $"Successfully updated {serviceName}";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private async IAsyncEnumerable<string> RunProcess(string folder, string arguments) {
|
private async IAsyncEnumerable<string> RunProcess(string folder, string arguments) {
|
||||||
@@ -48,11 +52,12 @@ public sealed class UpdateWorker(UpdaterConfig config) {
|
|||||||
else {
|
else {
|
||||||
var line = await error;
|
var line = await error;
|
||||||
if (line == null) break;
|
if (line == null) break;
|
||||||
yield return "[ERR] " + line;
|
yield return line;
|
||||||
error = process.StandardError.ReadLineAsync();
|
error = process.StandardError.ReadLineAsync();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
await process.WaitForExitAsync();
|
await process.WaitForExitAsync();
|
||||||
|
LastExitCode = process.ExitCode;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user