public async Task <IEnumerable <IPayload> > DecryptAndExtractPayloads(Task <Stream> encryptedZipStream) { var payloads = new List <StreamPayload>(); using (var stream = await Decrypt(encryptedZipStream).ConfigureAwait(false)) { var asiceReader = new AsiceReader().Read(stream); foreach (var entry in asiceReader.Entries) { using (var entryStream = entry.OpenStream()) { var memoryStream = new MemoryStream(); await entryStream.CopyToAsync(memoryStream).ConfigureAwait(false); var payload = new StreamPayload(memoryStream, entry.FileName); payloads.Add(payload); } } } return(payloads); }
private static List <List <string> > ValidatePayload(MottattMeldingArgs mottatt, string meldingsType) { var errorMessages = new List <List <string> >() { new(), new() }; IAsicReader reader = new AsiceReader(); using (var inputStream = mottatt.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { if (asiceReadEntry.FileName.Contains(".json")) { errorMessages = ValidateJsonFile(new StreamReader(entryStream).ReadToEnd(), Path.Combine("Schema", $"{meldingsType}.schema.json")); } else { Log.Information($"Mottatt vedlegg: {asiceReadEntry.FileName}"); } } } } return(errorMessages); }
private static void HandleRequestWithoutReturnPayload(MottattMeldingArgs mottatt, string jsonSchemaName, string returnMeldingstype) { Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); if (mottatt.Melding.HasPayload) { // Verify that message has payload List <List <string> > errorMessages = new List <List <string> >() { new List <string>(), new List <string>() }; IAsicReader reader = new AsiceReader(); using (var inputStream = mottatt.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { if (asiceReadEntry.FileName.Contains("payload.json")) { errorMessages = ValidateJsonFile(new StreamReader(entryStream).ReadToEnd(), Path.Combine("Schema", jsonSchemaName + ".schema.json")); } else { Console.WriteLine("Mottatt vedlegg: " + asiceReadEntry.FileName); } } } } if (errorMessages[0].Count == 0) { var svarmsg = mottatt.SvarSender.Svar(returnMeldingstype).Result; Console.WriteLine("Svarmelding " + svarmsg.MeldingId + " " + svarmsg.MeldingType + " sendt..."); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } else { Console.WriteLine("Feil i validering med jsonschema: ", jsonSchemaName); mottatt.SvarSender.Svar(FeilmeldingType.Ugyldigforespørsel, String.Join("\n ", errorMessages[0]), "feil.txt"); Console.WriteLine(String.Join("\n ", errorMessages[0])); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } } else { var svarmsg = mottatt.SvarSender.Svar(FeilmeldingType.Ugyldigforespørsel, "Meldingen mangler innhold", "feil.txt").Result; Console.WriteLine("Svarmelding " + svarmsg.MeldingId + " " + svarmsg.MeldingType + " Meldingen mangler innhold"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } }
public void ReadAndValidateAsice() { IAsicReader reader = new AsiceReader(); using (var inputStream = TestDataUtil.ReadValidAsiceCadesFromResource()) using (var asice = reader.Read(inputStream)) { asice.Should().NotBeNull(); foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) using (var bufferStream = new MemoryStream()) { entryStream.CopyTo(bufferStream); bufferStream.ToArray().Count().Should().BeGreaterThan(0); } } asice.DigestVerifier.Verification().AllValid.Should().BeTrue(); } }
private void OnReceivedMelding(object sender, MottattMeldingArgs mottatt) { //Se oversikt over meldingstyper på https://github.com/ks-no/fiks-io-meldingstype-katalog/tree/test/schema // Process the message var arkivmeldingXmlSchemaSet = new XmlSchemaSet(); arkivmeldingXmlSchemaSet.Add("http://www.arkivverket.no/standarder/noark5/arkivmelding/v2", Path.Combine("Schema", "arkivmelding.xsd")); arkivmeldingXmlSchemaSet.Add("http://www.arkivverket.no/standarder/noark5/metadatakatalog/v2", Path.Combine("Schema", "metadatakatalog.xsd")); var sokXmlSchemaSet = new XmlSchemaSet(); sokXmlSchemaSet.Add("http://www.arkivverket.no/standarder/noark5/sok", Path.Combine("Schema", "sok.xsd")); var xmlValidationErrorOccured = false; if (ArkivintegrasjonMeldingTypeV1.IsBasis(mottatt.Melding.MeldingType)) { var validationResult = new List <List <string> >(); var deserializedArkivmelding = new arkivmelding(); Console.WriteLine($"Melding {mottatt.Melding.MeldingId} {mottatt.Melding.MeldingType} mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet if (mottatt.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = mottatt.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { if (asiceReadEntry.FileName.Contains(".xml")) //TODO regel på navning? alltid arkivmelding.xml? { //TODO validere arkivmelding og evt sende feil om den ikke er ok for arkivering validationResult = new XmlValidation().ValidateXml( entryStream, arkivmeldingXmlSchemaSet ); if (validationResult[0].Count > 0) { xmlValidationErrorOccured = true; } var newEntryStream = asiceReadEntry.OpenStream(); StreamReader reader1 = new StreamReader(newEntryStream); string text = reader1.ReadToEnd(); deserializedArkivmelding = ArkivmeldingSerializeHelper.DeSerialize(text); Console.WriteLine(text); } else { Console.WriteLine($"Mottatt vedlegg: {asiceReadEntry.FileName}"); } } } // Check that all digests declared in the manifest are valid if (asice.DigestVerifier.Verification().AllValid) { // Do something } else { // Handle error } } if (xmlValidationErrorOccured) // Ugyldig forespørsel { var ugyldigforespørsel = new Ugyldigforespørsel { ErrorId = Guid.NewGuid().ToString(), Feilmelding = "Feilmelding:\n" + string.Join("\n ", validationResult[0]), CorrelationId = Guid.NewGuid().ToString() }; mottatt.SvarSender.Ack(); // Ack message to remove it from the queue var errorMessage = mottatt.SvarSender.Svar(FeilmeldingMeldingTypeV1.Ugyldigforespørsel, JsonConvert.SerializeObject(ugyldigforespørsel), "ugyldigforespørsel.json").Result; Console.WriteLine($"Svarmelding {errorMessage.MeldingId} {errorMessage.MeldingType} sendt"); } else { mottatt.SvarSender.Ack(); // Ack message to remove it from the queue var svarmsg = mottatt.SvarSender.Svar(ArkivintegrasjonMeldingTypeV1.Mottatt).Result; Console.WriteLine($"Svarmelding {svarmsg.MeldingId} {svarmsg.MeldingType} sendt..."); Console.WriteLine("Melding er mottatt i arkiv ok ......"); } } else // Ugyldig forespørsel { var ugyldigforespørsel = new Ugyldigforespørsel { ErrorId = Guid.NewGuid().ToString(), Feilmelding = "Meldingen mangler innhold", CorrelationId = Guid.NewGuid().ToString() }; mottatt.SvarSender.Ack(); // Ack message to remove it from the queue var svarmsg = mottatt.SvarSender.Svar(FeilmeldingMeldingTypeV1.Ugyldigforespørsel, JsonConvert.SerializeObject(ugyldigforespørsel), "ugyldigforespørsel.json").Result; Console.WriteLine($"Svarmelding {svarmsg.MeldingId} {svarmsg.MeldingType} sendt"); } if (!xmlValidationErrorOccured) { var kvittering = new arkivmelding(); kvittering.tidspunkt = DateTime.Now; var type = deserializedArkivmelding?.Items?[0]?.GetType(); if (type == typeof(saksmappe)) { var mp = new saksmappe(); mp.systemID = new systemID(); mp.systemID.Value = Guid.NewGuid().ToString(); mp.saksaar = DateTime.Now.Year.ToString(); mp.sakssekvensnummer = new Random().Next().ToString(); kvittering.Items = new List <saksmappe>() { mp }.ToArray(); } else if (type == typeof(journalpost)) { var jp = new journalpost(); jp.systemID = new systemID(); jp.systemID.Value = Guid.NewGuid().ToString(); jp.journalaar = DateTime.Now.Year.ToString(); jp.journalsekvensnummer = new Random().Next().ToString(); jp.journalpostnummer = new Random().Next(1, 100).ToString(); kvittering.Items = new List <journalpost>() { jp }.ToArray(); } //TODO simulerer at arkivet arkiverer og nøkler skal returneres string payload = ArkivmeldingSerializeHelper.Serialize(kvittering); var svarmsg2 = mottatt.SvarSender.Svar(ArkivintegrasjonMeldingTypeV1.Kvittering, payload, "arkivmelding.xml").Result; Console.WriteLine("$Svarmelding {svarmsg2.MeldingId} {svarmsg2.MeldingType} sendt..."); Console.WriteLine("Arkivering er ok ......"); } } else if (ArkivintegrasjonMeldingTypeV1.IsSok(mottatt.Melding.MeldingType)) { var validationResult = new List <List <string> >(); Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet if (mottatt.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = mottatt.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { if (asiceReadEntry.FileName.Contains(".xml")) //TODO regel på navning? alltid arkivmelding.xml? { validationResult = new XmlValidation().ValidateXml( entryStream, sokXmlSchemaSet ); if (validationResult[0].Count > 0) { xmlValidationErrorOccured = true; } var reader1 = new StreamReader(entryStream); var text = reader1.ReadToEnd(); Console.WriteLine("Søker etter: " + text); } else { Console.WriteLine("Mottatt vedlegg: " + asiceReadEntry.FileName); } } } } if (xmlValidationErrorOccured) { var ugyldigforespørsel = new Ugyldigforespørsel { ErrorId = Guid.NewGuid().ToString(), Feilmelding = "Feilmelding:\n" + string.Join("\n ", validationResult[0]), CorrelationId = Guid.NewGuid().ToString() }; var errorMessage = mottatt.SvarSender.Svar(FeilmeldingMeldingTypeV1.Ugyldigforespørsel, JsonConvert.SerializeObject(ugyldigforespørsel), "ugyldigforespørsel.json").Result; Console.WriteLine($"Svarmelding {errorMessage.MeldingId} {errorMessage.MeldingType} sendt"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } } //Konverterer til arkivmelding xml var simulertSokeresultat = MessageSamples.GetForenkletArkivmeldingInngåendeMedSaksreferanse(); var arkivmelding = ArkivmeldingFactory.GetArkivmelding(simulertSokeresultat); var payload = ArkivmeldingSerializeHelper.Serialize(arkivmelding); //Lager FIKS IO melding List <IPayload> payloads = new List <IPayload>(); payloads.Add(new StringPayload(payload, "arkivmelding.xml")); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue var svarmsg = mottatt.SvarSender.Svar(ArkivintegrasjonMeldingTypeV1.InnsynSokResultat, payloads).Result; Console.WriteLine("Svarmelding " + svarmsg.MeldingId + " " + svarmsg.MeldingType + " sendt..."); Console.WriteLine("Melding er håndtert i arkiv ok ......"); } else if (ArkivintegrasjonMeldingTypeV1.IsAvansert(mottatt.Melding.MeldingType)) { Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet Console.WriteLine("Melding er håndtert i arkiv ok ......"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } else { Console.WriteLine("Ukjent melding i køen som avvises " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType); mottatt.SvarSender.Nack(); // Nack message to remove it from the queue } }
static void OnReceivedMelding(object sender, MottattMeldingArgs fileArgs) { //Se oversikt over meldingstyper på https://github.com/ks-no/fiks-io-meldingstype-katalog/tree/test/schema // Process the message if (fileArgs.Melding.MeldingType == "no.ks.fiks.gi.arkivintegrasjon.mottatt.v1") { Console.WriteLine("(Svar på " + fileArgs.Melding.SvarPaMelding + ") Melding " + fileArgs.Melding.MeldingId + " " + fileArgs.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet if (fileArgs.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = fileArgs.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { StreamReader reader1 = new StreamReader(entryStream); string text = reader1.ReadToEnd(); Console.WriteLine(text); } } } } Console.WriteLine("Melding er håndtert i fagsystem ok ......"); fileArgs.SvarSender.Ack(); // Ack message to remove it from the queue } else if (fileArgs.Melding.MeldingType == "no.ks.fiks.gi.arkivintegrasjon.kvittering.v1") { Console.WriteLine("(Svar på " + fileArgs.Melding.SvarPaMelding + ") Melding " + fileArgs.Melding.MeldingId + " " + fileArgs.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet if (fileArgs.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = fileArgs.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { StreamReader reader1 = new StreamReader(entryStream); string text = reader1.ReadToEnd(); Console.WriteLine(text); } } } } Console.WriteLine("Melding er håndtert i fagsystem ok ......"); fileArgs.SvarSender.Ack(); // Ack message to remove it from the queue } else if (fileArgs.Melding.MeldingType == "no.ks.fiks.gi.arkivintegrasjon.feil.v1") { Console.WriteLine("(Svar på " + fileArgs.Melding.SvarPaMelding + ") Melding " + fileArgs.Melding.MeldingId + " " + fileArgs.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet if (fileArgs.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = fileArgs.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { StreamReader reader1 = new StreamReader(entryStream); string text = reader1.ReadToEnd(); Console.WriteLine(text); } } } } Console.WriteLine("Melding er håndtert i fagsystem ok ......"); fileArgs.SvarSender.Ack(); // Ack message to remove it from the queue } else if (fileArgs.Melding.MeldingType == "no.ks.fiks.gi.arkivintegrasjon.innsyn.sok.resultat.v1") { Console.WriteLine("(Svar på " + fileArgs.Melding.SvarPaMelding + ") Melding " + fileArgs.Melding.MeldingId + " " + fileArgs.Melding.MeldingType + " mottas..."); if (fileArgs.Melding.HasPayload) { // Verify that message has payload IAsicReader reader = new AsiceReader(); using (var inputStream = fileArgs.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { StreamReader reader1 = new StreamReader(entryStream); string text = reader1.ReadToEnd(); Console.WriteLine(text); } } // Check that all digests declared in the manifest are valid if (asice.DigestVerifier.Verification().AllValid) { // Do something } else { // Handle error } } } Console.WriteLine("Melding er håndtert i fagsystem ok ......"); fileArgs.SvarSender.Ack(); // Ack message to remove it from the queue } else { Console.WriteLine("Ubehandlet melding i køen " + fileArgs.Melding.MeldingId + " " + fileArgs.Melding.MeldingType); //fileArgs.SvarSender.Ack(); // Ack message to remove it from the queue } }
static void OnReceivedMelding(object sender, MottattMeldingArgs mottatt) { //Se oversikt over meldingstyper på https://github.com/ks-no/fiks-io-meldingstype-katalog/tree/test/schema // Process the message if (mottatt.Melding.MeldingType == "no.ks.fiks.politisk.behandling.tjener.resultatmøteplan.v1") { Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet Console.WriteLine("Melding er håndtert ok ......"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } else if (mottatt.Melding.MeldingType == "no.ks.fiks.politisk.behandling.tjener.sendvedtakfrautvalg.v1") { Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); if (mottatt.Melding.HasPayload) { List <List <string> > errorMessages = new List <List <string> >() { new List <string>(), new List <string>() }; IAsicReader reader = new AsiceReader(); using (var inputStream = mottatt.Melding.DecryptedStream.Result) using (var asice = reader.Read(inputStream)) { foreach (var asiceReadEntry in asice.Entries) { using (var entryStream = asiceReadEntry.OpenStream()) { if (asiceReadEntry.FileName.Contains(".json")) { errorMessages = ValidateJsonFile(new StreamReader(entryStream).ReadToEnd(), Path.Combine("schema", "no.ks.fiks.politisk.behandling.sendvedtakfrautvalg.v1.schema.json")); } else { Console.WriteLine("Mottatt vedlegg: " + asiceReadEntry.FileName); } } } } if (errorMessages[0].Count == 0) { var svarmsg2 = mottatt.SvarSender.Svar("no.ks.fiks.politisk.behandling.mottatt.v1").Result; Console.WriteLine("Svarmelding " + svarmsg2.MeldingId + " " + svarmsg2.MeldingType + " sendt..."); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } else { Console.WriteLine("Feil i validering av sendvedtakfrautvalg"); var errorMessage = mottatt.SvarSender.Svar("no.ks.fiks.kvittering.ugyldigforespørsel.v1", String.Join("\n ", errorMessages[0]), "feil.txt").Result; Console.WriteLine(String.Join("\n ", errorMessages[0])); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } } else { var svarmsg = mottatt.SvarSender.Svar("no.ks.fiks.kvittering.ugyldigforespørsel.v1", "Meldingen mangler innhold", "feil.txt").Result; Console.WriteLine("Svarmelding " + svarmsg.MeldingId + " " + svarmsg.MeldingType + " Meldingen mangler innhold"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } } else if (mottatt.Melding.MeldingType == "no.ks.geointegrasjon.ok.v1") { Console.WriteLine("Melding " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType + " mottas..."); //TODO håndtere meldingen med ønsket funksjonalitet Console.WriteLine("Melding er håndtert ok ......"); mottatt.SvarSender.Ack(); // Ack message to remove it from the queue } else { Console.WriteLine("Ubehandlet melding i køen " + mottatt.Melding.MeldingId + " " + mottatt.Melding.MeldingType); } }
private async void OnMottattMelding(object sender, MottattMeldingArgs mottattMeldingArgs) { Logger.Information("Henter melding med MeldingId: {MeldingId}", mottattMeldingArgs.Melding.MeldingId); var payloads = new List <FiksPayload>(); if (mottattMeldingArgs.Melding.HasPayload) { try { // Verify that message has payload IAsicReader reader = new AsiceReader(); await using var inputStream = mottattMeldingArgs.Melding.DecryptedStream.Result; using var asice = reader.Read(inputStream); foreach (var asiceReadEntry in asice.Entries) { await using var entryStream = asiceReadEntry.OpenStream(); byte[] fileAsBytes; using (MemoryStream ms = new MemoryStream()) { entryStream.CopyTo(ms); fileAsBytes = ms.ToArray(); } payloads.Add(new FiksPayload() { Filename = asiceReadEntry.FileName, Payload = fileAsBytes }); } } catch (Exception e) { Logger.Error("Klarte ikke hente payload og melding blir dermed ikke parset. MeldingId: {MeldingId}, Error: {Message}", mottattMeldingArgs.Melding?.MeldingId, e.Message); mottattMeldingArgs.SvarSender?.Ack(); return; } } try { using var scope = _scopeFactory.CreateScope(); var context = scope.ServiceProvider.GetRequiredService <FiksIOMessageDBContext>(); var testSession = context.TestSessions.Include(t => t.FiksRequests).FirstOrDefaultAsync(t => t.FiksRequests.Any(r => r.MessageGuid.Equals(mottattMeldingArgs.Melding.SvarPaMelding))).Result; // Ikke optimalt? Det er gjort slik fordi man ikke vet om databasen har rukket å skrive før man får svar. var timesTried = 1; while (testSession == null && timesTried <= 5) { Thread.Sleep(1000); testSession = context.TestSessions.Include(t => t.FiksRequests).FirstOrDefault(t => t.FiksRequests.Any(r => r.MessageGuid.Equals(mottattMeldingArgs.Melding.SvarPaMelding))); timesTried++; } if (testSession != null) { var fiksRequest = testSession.FiksRequests.Find(r => r.MessageGuid.Equals(mottattMeldingArgs.Melding.SvarPaMelding)); var responseMessage = new FiksResponse { ReceivedAt = DateTime.Now, Type = mottattMeldingArgs.Melding.MeldingType, FiksPayloads = payloads }; if (fiksRequest == null) { mottattMeldingArgs.SvarSender?.Ack(); Logger.Error("Klarte ikke å matche svar-melding fra FIKS med en eksisterende forespørsel. Testsession med id {TestSessionId} funnet. Svarmelding forkastes. SvarPaMelding id: {Id}", testSession.Id, mottattMeldingArgs.Melding.SvarPaMelding); return; } fiksRequest.FiksResponses ??= new List <FiksResponse>(); fiksRequest.FiksResponses.Add(responseMessage); context.Entry(testSession).State = EntityState.Modified; await context.SaveChangesAsync(); } else { Logger.Error("Klarte ikke å matche svar-melding fra FIKS med en eksisterende testsesjon. Testsession ikke funnet. Svarmelding forkastes. SvarPaMelding id: {Id}", mottattMeldingArgs.Melding.SvarPaMelding); } } finally { mottattMeldingArgs.SvarSender?.Ack(); } }