Newer
Older
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Logging;
public static async Task Run(IConfiguration config, ILogger logger) {
var clientId = config["FitConnect:Subscriber:ClientId"];
var clientSecret = config["FitConnect:Subscriber:ClientSecret"];
var privateKeyDecryption = config["FitConnect:Subscriber:PrivateKeyDecryption"];
var privateKeySigning = config["FitConnect:Subscriber:PrivateKeySigning"];
if (clientId == null || clientSecret == null || privateKeyDecryption == null ||
privateKeySigning == null) {

Klaus Fischer
committed
logger.LogError("Missing configuration values");
return;
}
var subscriber = ClientFactory.GetSubscriberClient(FitConnectEnvironment.Testing, clientId,
new List<string>() { await File.ReadAllTextAsync(privateKeyDecryption) },
var submissionForPickups = await subscriber.GetAvailableSubmissionsAsync(Guid.Parse(config["FitConnect:Subscriber:DestinationId"]!));
var outputDirectory = Directory.CreateDirectory(
Path.Combine(".", "submissions", $"{submission.SubmissionId}", "attachments"));
var receivedSubmission =
await subscriber.RequestSubmissionAsync(submission.SubmissionId);
logger.LogInformation("Fachdaten:\r\n\tMimeType: {mimeType}\r\n\t{Data}",
receivedSubmission.GetDataMimeType(), receivedSubmission.GetData());
// receivedSubmission.GetDataSchemaUri();
var metadata = receivedSubmission.Metadata;
var attachments = await receivedSubmission.GetAttachmentsAsync();
foreach (var attachment in attachments)
await File.WriteAllBytesAsync(
outputDirectory.FullName + "/" + (attachment.Filename ?? "temp.dat"),
logger.LogError(e, "Fehler beim Abrufen der Einreichung");
}