Versionen im Vergleich

Schlüssel

  • Diese Zeile wurde hinzugefügt.
  • Diese Zeile wurde entfernt.
  • Formatierung wurde geändert.

...

TitelAuftrag (Providerwechsel / Verbundleistung) anlegen
Kurzbeschreibung

Folgender Ablauf beschreibt die typischen API Interaktionen zwischen dem aufnehmenden Auftrageber (EKPauf und TNBauf, aka AGauf), dem Leistungserbringer (LE, aka ANE) und dem abgebenden Auftraggeber (EKPab und TNBab, aka ABab) für die Anwendungsfälle "Auftrag (Providerwechsel / Verbundleistung) anlegen - Schlechtfall Negative RespondProviderChange (RUEM-PV)".

Zu diesen Anwendungsfall sind zwei Sequenzen relevant:

  • Die Vorabstimmung
  • Die Durchführung
Vorbedingung
  • Rahmenverträge und Dienstverträge sind vorhanden
  • Der Auftraggeber hat die Verfügbarkeit des Produktes geprüft
  • der AGab hat sich beim LE für Kündigungen durch den Leistungserbringer registriert (siehe Auftrag (Kündigung durch LE) anlegen)
Auslöser

Der aufnehmende Auftraggeber legt einen Auftrag für den Providerwechsel bzw. die Verbundleistung beim Leistungserbringer (ANE) an.

Schlechtfall: Der abgebende Provider lehnt die Anfrage zum Providerwechsel ab (im Beispiel mit der Begründung: falsche Vorabstimmungs-ID)

Ergebnis

Nach Eingang der negativen RespondProviderChange (RUEM-PV) wird der Auftag wird seitens des Leistungserbringers abgebrochen - Status Failed

Der Leistungserbringer sendet an den aufnehmenden Provider ein StateChangeEvend "Failed" (ABBM)

Der Leistungserbringer sendet an den abgebenden Provider ein StateChangeEvend "Failed" (ABBM-PV), hier nicht dargestellt

Ablauf

Img
src//www.plantuml.com/plantuml/png/dPDFZzem4CNl_XIZFH4Lzj3Zgbjjkeqg15qYO7DtuY59cpYf6TFoxUi_ii22KkqU44diz-OtR-odFN55kkyOrpH8tPUe602mSlW3kHg4hWXMIg22mz33zZX2Ni0aNoLiDCAsQaSk2P3h7V0zt6MB7Epp1zY-V75Fa_IR_K_k8W45GVgImMIP-HsXC4mskaokbr-yPhDbPX4-nWmTyZAoB2zg-dL7LXf40yjB3rZwwkxdcfbzTemFaAyssv248vcCPozpmlvP8IUSGf7EHSBaG0YghHiose8nyE5ycdc_o6f3dFJ-kU6onko0aanNKqYhdtButM6DnWw0F8xhxm6CVRixcX0Ok2-d5GTwc_GhTcX9AyDR3-huwCDCW35sQVO-hs1auuwxzJc9q6Z2p0wRYnLSve8tOhaXJObKMsh2WdVwmiCqSMWjYli-bxjX2e8JnjJ_PybHYbRMyRJJnVTPNlpRoPPJFQTsa6lyfLk5ukIuQx4JEQVcyJpe-pm2NkDUTtJFHzi7xn8M3e4xNM5iPjSuI15BNH7bzFPGdNElNpC73X2XNxKvfH7WmrY4cqlid9OTDbBB6ep1TKCGMbKDBErvVX_06dzWHRuumDlc66l9NzJefkL5s6F3VjjbZYiyeHIwx_u2

Codeblock
languagetext
collapsetrue
@startuml
autonumber
   
box Product Order vom Typ PV (PO)
participant eauf as "EKP auf + TNB auf (AG auf)"
participant tauf as "ANE (LEauf)"
   
box  (Sub)Product Order vom Typ KUE-LE (PO2)
participant leab as "ANE (LEab)"
participant tab as "TNB ab + EKPab (AG ab)"
   
   
eauf -> tauf: POST ProductOrder(productOrderItemCreate, VAId)
note right: PV

  eauf <- tauf: ProductOrderStatusChangeEvent(PO, Acknowleged)
  tauf -> leab: notifyKUE
  leab -> leab: POST  ProductOrder(productOrderItemDelete, category=KUE-LE) 


leab -> leab: POST ProductOrder(productOrderItemDelete, category=KUE-LE)
leab -> tab: ProductOrderCreatedEvent(PO)
tab <- leab: ProductOrderStateChangeEvent(PO, Acknowleged)
tab <- leab: ProductOrderAttributeValueChangeEvent(PO, providerChangeInfo, date)
leab -> tab: ProductOrderStateChangeEvent(PO, Pending)
note right: AKM-PV
leab -> tab: ProductOrderInformationRequiredEvent(PO, fieldPath=productOrder.ProviderChangeResult.approval)

  leab <- tab: POST RespondProviderChange(PO, result)
  note right: RUEM-PV
  leab -> tab: RespondProviderChangeStateChangedEvent(Acknowledged)
  note right: Ablehnung der RespondProviderChange durch LE
    leab -> tab: RespondProviderChangeStateChangedEvent(Rejected)
    leab -> tab: ProductOrderStateChangeEvent(PO, Rejected)
    tauf <- leab: notifyPVRejected

    eauf <- tauf: ProductOrderStatusChangeEvent(PO, Rejected)
@enduml



Beispieldaten (linker Block, TNBauf ↔ ANE)

...