public void Importer(OrgUnitData unit) { log.Debug("Attempting Importer on OrganisationEnhed with uuid " + unit.Uuid); // create ShortKey if not supplied EnsureKeys(unit); // create timestamp object to be used on all registrations, properties and relations VirkningType virkning = helper.GetVirkning(unit.Timestamp); // setup registration RegistreringType1 registration = helper.CreateRegistration(unit, LivscyklusKodeType.Importeret); // add properties helper.AddProperties(unit.ShortKey, unit.Name, virkning, registration); // add relationships helper.AddAddressReferences(unit.Addresses, virkning, registration); helper.AddOrganisationRelation(StubUtil.GetMunicipalityOrganisationUUID(), virkning, registration); helper.AddOverordnetEnhed(unit.ParentOrgUnitUuid, virkning, registration); helper.AddTilknyttedeFunktioner(unit.OrgFunctionUuids, virkning, registration); // set Tilstand to Active helper.SetTilstandToActive(virkning, registration, unit.Timestamp); // wire everything together OrganisationEnhedType organisationEnhedType = helper.GetOrganisationEnhedType(unit.Uuid, registration); ImportInputType importInput = new ImportInputType(); importInput.OrganisationEnhed = organisationEnhedType; // construct request importerRequest request = new importerRequest(); request.ImporterRequest1 = new ImporterRequestType(); request.ImporterRequest1.ImportInput = importInput; request.ImporterRequest1.AuthorityContext = new AuthorityContextType(); request.ImporterRequest1.AuthorityContext.MunicipalityCVR = OrganisationRegistryProperties.GetMunicipality(); // send request OrganisationEnhedPortType channel = StubUtil.CreateChannel <OrganisationEnhedPortType>(OrganisationEnhedStubHelper.SERVICE, "Importer", helper.CreatePort()); try { importerResponse result = channel.importer(request); int statusCode = Int32.Parse(result.ImporterResponse1.ImportOutput.StandardRetur.StatusKode); if (statusCode != 20) { string message = StubUtil.ConstructSoapErrorMessage(statusCode, "Import", OrganisationEnhedStubHelper.SERVICE, result.ImporterResponse1.ImportOutput.StandardRetur.FejlbeskedTekst); log.Error(message); throw new SoapServiceException(message); } log.Debug("Importer successful on OrganisationEnhed with uuid " + unit.Uuid); } catch (Exception ex) when(ex is CommunicationException || ex is IOException || ex is TimeoutException || ex is WebException) { throw new ServiceNotFoundException("Failed to establish connection to the Importer service on OrganisationEnhed", ex); } }
internal OrganisationEnhedType GetOrganisationEnhedType(string uuid, RegistreringType1 registration) { OrganisationEnhedType organisationType = new OrganisationEnhedType(); organisationType.UUIDIdentifikator = uuid; RegistreringType1[] registreringTypes = new RegistreringType1[1]; registreringTypes[0] = registration; organisationType.Registrering = registreringTypes; return(organisationType); }