Skip to content

Commit

Permalink
MLPAB-1637 Fix sending bad fields to lpastore (#934)
Browse files Browse the repository at this point in the history
* Create valid attorney decisions in donor fixtures
* Send correct decisions/step in options to lpastore
  • Loading branch information
hawx authored Dec 19, 2023
1 parent 02bd73f commit 1c37a1d
Show file tree
Hide file tree
Showing 3 changed files with 242 additions and 178 deletions.
41 changes: 25 additions & 16 deletions internal/lpastore/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,13 +58,13 @@ type lpaRequest struct {
Attorneys []lpaRequestAttorney `json:"attorneys"`
TrustCorporations []lpaRequestTrustCorporation `json:"trustCorporations,omitempty"`
CertificateProvider lpaRequestCertificateProvider `json:"certificateProvider"`
PeopleToNotify []lpaRequestPersonToNotify `json:"peopleToNotify"`
HowAttorneysMakeDecisions actor.AttorneysAct `json:"howAttorneysMakeDecisions"`
HowAttorneysMakeDecisionsDetails string `json:"howAttorneysMakeDecisionsDetails"`
HowReplacementAttorneysMakeDecisions actor.AttorneysAct `json:"howReplacementAttorneysMakeDecisions"`
HowReplacementAttorneysMakeDecisionsDetails string `json:"howReplacementAttorneysMakeDecisionsDetails"`
HowReplacementAttorneysStepIn actor.ReplacementAttorneysStepIn `json:"howReplacementAttorneysStepIn"`
HowReplacementAttorneysStepInDetails string `json:"howReplacementAttorneysStepInDetails"`
PeopleToNotify []lpaRequestPersonToNotify `json:"peopleToNotify,omitempty"`
HowAttorneysMakeDecisions actor.AttorneysAct `json:"howAttorneysMakeDecisions,omitempty"`
HowAttorneysMakeDecisionsDetails string `json:"howAttorneysMakeDecisionsDetails,omitempty"`
HowReplacementAttorneysMakeDecisions actor.AttorneysAct `json:"howReplacementAttorneysMakeDecisions,omitempty"`
HowReplacementAttorneysMakeDecisionsDetails string `json:"howReplacementAttorneysMakeDecisionsDetails,omitempty"`
HowReplacementAttorneysStepIn actor.ReplacementAttorneysStepIn `json:"howReplacementAttorneysStepIn,omitempty"`
HowReplacementAttorneysStepInDetails string `json:"howReplacementAttorneysStepInDetails,omitempty"`
Restrictions string `json:"restrictions"`
WhenTheLpaCanBeUsed actor.CanBeUsedWhen `json:"whenTheLpaCanBeUsed,omitempty"`
LifeSustainingTreatmentOption actor.LifeSustainingTreatment `json:"lifeSustainingTreatmentOption,omitempty"`
Expand Down Expand Up @@ -100,7 +100,7 @@ type lpaRequestTrustCorporation struct {
type lpaRequestCertificateProvider struct {
FirstNames string `json:"firstNames"`
LastName string `json:"lastName"`
Email string `json:"email"`
Email string `json:"email,omitempty"`
Address place.Address `json:"address"`
Channel actor.CertificateProviderCarryOutBy `json:"channel"`
}
Expand Down Expand Up @@ -129,14 +129,8 @@ func (c *Client) SendLpa(ctx context.Context, donor *actor.DonorProvidedDetails)
Address: donor.CertificateProvider.Address,
Channel: donor.CertificateProvider.CarryOutBy,
},
HowAttorneysMakeDecisions: donor.AttorneyDecisions.How,
HowAttorneysMakeDecisionsDetails: donor.AttorneyDecisions.Details,
HowReplacementAttorneysMakeDecisions: donor.ReplacementAttorneyDecisions.How,
HowReplacementAttorneysMakeDecisionsDetails: donor.ReplacementAttorneyDecisions.Details,
HowReplacementAttorneysStepIn: donor.HowShouldReplacementAttorneysStepIn,
HowReplacementAttorneysStepInDetails: donor.HowShouldReplacementAttorneysStepInDetails,
Restrictions: donor.Restrictions,
SignedAt: donor.SignedAt,
Restrictions: donor.Restrictions,
SignedAt: donor.SignedAt,
}

switch donor.Type {
Expand All @@ -146,6 +140,21 @@ func (c *Client) SendLpa(ctx context.Context, donor *actor.DonorProvidedDetails)
body.LifeSustainingTreatmentOption = donor.LifeSustainingTreatmentOption
}

if donor.Attorneys.Len() > 1 {
body.HowAttorneysMakeDecisions = donor.AttorneyDecisions.How
body.HowAttorneysMakeDecisionsDetails = donor.AttorneyDecisions.Details
}

if donor.ReplacementAttorneys.Len() > 0 && donor.AttorneyDecisions.How.IsJointlyAndSeverally() {
body.HowReplacementAttorneysStepIn = donor.HowShouldReplacementAttorneysStepIn
body.HowReplacementAttorneysStepInDetails = donor.HowShouldReplacementAttorneysStepInDetails
}

if donor.ReplacementAttorneys.Len() > 1 && (donor.HowShouldReplacementAttorneysStepIn.IsWhenAllCanNoLongerAct() || !donor.AttorneyDecisions.How.IsJointlyAndSeverally()) {
body.HowReplacementAttorneysMakeDecisions = donor.ReplacementAttorneyDecisions.How
body.HowReplacementAttorneysMakeDecisionsDetails = donor.ReplacementAttorneyDecisions.Details
}

for _, attorney := range donor.Attorneys.Attorneys {
body.Attorneys = append(body.Attorneys, lpaRequestAttorney{
FirstNames: attorney.FirstNames,
Expand Down
Loading

0 comments on commit 1c37a1d

Please sign in to comment.