Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(action): update mission action #452

Merged
merged 9 commits into from
Dec 25, 2024
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,23 @@ abstract class BaseControlEntity {
open val observations: String? = null
open val hasBeenDone: Boolean? = null
abstract fun shouldToggleOnUnitHasConfirmed(): Boolean


override fun hashCode(): Int {
var result = id.hashCode()
result = 31 * result + actionControlId.hashCode()
result = 31 * result + (observations?.hashCode() ?: 0)
result = 31 * result + (hasBeenDone?.hashCode() ?: 0)
return result
}

override fun equals(other: Any?): Boolean {
if (this === other) return true
if (javaClass != other?.javaClass) return false
other as BaseControlEntity
return (id == other.id
&& hasBeenDone == other.hasBeenDone
&& observations == other.observations
&& actionControlId == other.actionControlId)
}
Comment on lines +17 to +33
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Par curiosité, ca fait quoi ça ?
Je suis toujours pas clair avec ces hashCode et equals

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Je vais checker que les controls sont identiques. s'ils le sont je ne les update pas.
du coup pour vérifier l'égalité == vérifie qu'on à la même adresse dans la heap (la mémoire)
a.equals(b) qu'on a le même contenu
mais quand tu modifies (override) la méthode equals tu dois modifé la méthode hascode
Pourquoi?
hashCode et un méthode de calcul du clé de crypto (le hash)
on a 2 objets: a, b

  • si a.hashcode != b.hashcode alors A et B ne peuvent pas être égaux, c'est le premier check ca ne sert à rien de de faire appel à la méthode equals.
  • si a.hashcode == b.hashcode ca ne veut pas dire qu'ils sont égaux.. mais ca veut dire on peut passer à la suite du check.

}
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ data class ControlAdministrativeEntity(
val compliantSecurityDocuments: ControlResult? = null,
override val observations: String? = null,
override val hasBeenDone: Boolean? = null,
override val infractions: List<InfractionEntity>? = null
override var infractions: List<InfractionEntity>? = null
) : BaseControlEntity() {
override fun shouldToggleOnUnitHasConfirmed(): Boolean =
unitShouldConfirm == true &&
Expand All @@ -26,4 +26,23 @@ data class ControlAdministrativeEntity(
infractions?.isNotEmpty() == true ||
observations != null
)

override fun hashCode(): Int {
var result = missionId.hashCode()
result = 31 * result + amountOfControls
result = 31 * result + (compliantOperatingPermit?.hashCode() ?: 0)
result = 31 * result + (upToDateNavigationPermit?.hashCode() ?: 0)
result = 31 * result + (compliantSecurityDocuments?.hashCode() ?: 0)
return super.hashCode() + result
}

override fun equals(other: Any?): Boolean {
if (!super.equals(other)) return false
other as ControlAdministrativeEntity
return (missionId == other.missionId
&& amountOfControls == other.amountOfControls
&& compliantOperatingPermit == other.compliantOperatingPermit
&& upToDateNavigationPermit == other.upToDateNavigationPermit
&& compliantSecurityDocuments == other.compliantSecurityDocuments)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ data class ControlGensDeMerEntity(
val knowledgeOfFrenchLawAndLanguage: ControlResult? = null,
override val observations: String? = null,
override val hasBeenDone: Boolean? = null,
override val infractions: List<InfractionEntity>? = null
override var infractions: List<InfractionEntity>? = null
) : BaseControlEntity() {
override fun shouldToggleOnUnitHasConfirmed(): Boolean =
unitShouldConfirm == true &&
Expand All @@ -26,4 +26,23 @@ data class ControlGensDeMerEntity(
infractions?.isNotEmpty() == true ||
observations != null
)

override fun hashCode(): Int {
var result = missionId.hashCode()
result = 31 * result + amountOfControls
result = 31 * result + (staffOutnumbered?.hashCode() ?: 0)
result = 31 * result + (upToDateMedicalCheck?.hashCode() ?: 0)
result = 31 * result + (knowledgeOfFrenchLawAndLanguage?.hashCode() ?: 0)
return super.hashCode() + result
}

override fun equals(other: Any?): Boolean {
if (!super.equals(other)) return false
other as ControlGensDeMerEntity
return (missionId == other.missionId
&& amountOfControls == other.amountOfControls
&& staffOutnumbered == other.staffOutnumbered
&& upToDateMedicalCheck == other.upToDateMedicalCheck
&& knowledgeOfFrenchLawAndLanguage == other.knowledgeOfFrenchLawAndLanguage)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ data class ControlNavigationEntity(
override var unitHasConfirmed: Boolean? = null,
override val observations: String? = null,
override val hasBeenDone: Boolean? = null,
override val infractions: List<InfractionEntity>? = null
override var infractions: List<InfractionEntity>? = null
) : BaseControlEntity() {
override fun shouldToggleOnUnitHasConfirmed(): Boolean =
unitShouldConfirm == true &&
Expand All @@ -21,4 +21,17 @@ data class ControlNavigationEntity(
infractions?.isNotEmpty() == true ||
observations != null
)

override fun hashCode(): Int {
var result = missionId.hashCode()
result = 31 * result + amountOfControls
return super.hashCode() + result
}

override fun equals(other: Any?): Boolean {
if (!super.equals(other)) return false
other as ControlNavigationEntity
return (missionId == other.missionId
&& amountOfControls == other.amountOfControls)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ data class ControlSecurityEntity(
override var unitHasConfirmed: Boolean? = null,
override val observations: String? = null,
override val hasBeenDone: Boolean? = null,
override val infractions: List<InfractionEntity>? = null
override var infractions: List<InfractionEntity>? = null
) : BaseControlEntity() {
override fun shouldToggleOnUnitHasConfirmed(): Boolean =
unitShouldConfirm == true &&
Expand All @@ -21,4 +21,17 @@ data class ControlSecurityEntity(
infractions?.isNotEmpty() == true ||
observations != null
)

override fun hashCode(): Int {
var result = missionId.hashCode()
result = 31 * result + amountOfControls
return super.hashCode() + result
}

override fun equals(other: Any?): Boolean {
if (!super.equals(other)) return false
other as ControlSecurityEntity
return (missionId == other.missionId
&& amountOfControls == other.amountOfControls)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,34 @@ import fr.gouv.dgampa.rapportnav.domain.entities.mission.nav.control.ControlAdmi
import fr.gouv.dgampa.rapportnav.domain.entities.mission.nav.control.ControlGensDeMerEntity
import fr.gouv.dgampa.rapportnav.domain.entities.mission.nav.control.ControlNavigationEntity
import fr.gouv.dgampa.rapportnav.domain.entities.mission.nav.control.ControlSecurityEntity
import fr.gouv.dgampa.rapportnav.domain.entities.mission.nav.infraction.InfractionEntity

data class ActionControlEntity(
var controlAdministrative: ControlAdministrativeEntity? = null,
var controlGensDeMer: ControlGensDeMerEntity? = null,
var controlSecurity: ControlSecurityEntity? = null,
var controlNavigation: ControlNavigationEntity? = null
) {

fun computeInfractionControlId() {
controlSecurity?.infractions?.forEach { it.controlId = controlSecurity?.id }
controlGensDeMer?.infractions?.forEach { it.controlId = controlGensDeMer?.id }
controlNavigation?.infractions?.forEach { it.controlId = controlNavigation?.id }
controlAdministrative?.infractions?.forEach { it.controlId = controlAdministrative?.id }
}

fun getControlInfractions(): List<InfractionEntity> {
val genDeMerInfractions = controlGensDeMer?.infractions ?: listOf()
val securityInfractions = controlSecurity?.infractions ?: listOf()
val navigationInfractions = controlNavigation?.infractions ?: listOf()
val administrativeInfractions = controlAdministrative?.infractions ?: listOf()
return genDeMerInfractions + securityInfractions + navigationInfractions + administrativeInfractions
}

fun processInfractions(infractions: List<InfractionEntity>?) {
controlSecurity?.infractions = infractions?.filter { it.controlId == controlSecurity?.id }
controlGensDeMer?.infractions = infractions?.filter { it.controlId == controlGensDeMer?.id }
controlNavigation?.infractions = infractions?.filter { it.controlId == controlNavigation?.id }
controlAdministrative?.infractions = infractions?.filter { it.controlId == controlAdministrative?.id }
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,33 +13,33 @@ interface BaseMissionFishAction {
val internalReferenceNumber: String?
val externalReferenceNumber: String?
val ircs: String?
val flagState: CountryCode
val flagState: CountryCode?
val districtCode: String?
val faoAreas: List<String>
val faoAreas: List<String>?
val fishActionType: MissionActionType
val actionDatetimeUtc: Instant
val actionDatetimeUtc: Instant?
val actionEndDatetimeUtc: Instant?
val emitsVms: ControlCheck?
val emitsAis: ControlCheck?
val flightGoals: List<FlightGoal>
val flightGoals: List<FlightGoal>?
val logbookMatchesActivity: ControlCheck?
val licencesMatchActivity: ControlCheck?
val speciesWeightControlled: Boolean?
val speciesSizeControlled: Boolean?
val separateStowageOfPreservedSpecies: ControlCheck?
val logbookInfractions: List<LogbookInfraction>
val logbookInfractions: List<LogbookInfraction>?
val licencesAndLogbookObservations: String?
val gearInfractions: List<GearInfraction>
val speciesInfractions: List<SpeciesInfraction>
val gearInfractions: List<GearInfraction>?
val speciesInfractions: List<SpeciesInfraction>?
val speciesObservations: String?
val seizureAndDiversion: Boolean?
val otherInfractions: List<OtherInfraction>
val otherInfractions: List<OtherInfraction>?
val numberOfVesselsFlownOver: Int?
val unitWithoutOmegaGauge: Boolean?
val controlQualityComments: String?
val feedbackSheetRequired: Boolean?
val userTrigram: String
val segments: List<FleetSegment>
val userTrigram: String?
val segments: List<FleetSegment>?
val facade: String?
val longitude: Double?
val latitude: Double?
Expand All @@ -49,19 +49,19 @@ interface BaseMissionFishAction {
val vesselTargeted: ControlCheck?
val seizureAndDiversionComments: String?
val otherComments: String?
val gearOnboard: List<GearControl>
val speciesOnboard: List<SpeciesControl>
val isFromPoseidon: Boolean
val gearOnboard: List<GearControl>?
val speciesOnboard: List<SpeciesControl>?
val isFromPoseidon: Boolean?
/**
* This field is only used by the `GetVesselControls` use-case.
* /!\ Do not use it to get `controlUnits` as the field will be empty be default.
*/
var controlUnits: List<ControlUnit>
val isDeleted: Boolean
val hasSomeGearsSeized: Boolean
val hasSomeSpeciesSeized: Boolean
var controlUnits: List<ControlUnit>?
val isDeleted: Boolean?
val hasSomeGearsSeized: Boolean?
val hasSomeSpeciesSeized: Boolean?
val completedBy: String?
val completion: Completion
val completion: Completion?
var observationsByUnit: String?
var speciesQuantitySeized: Int ?
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,61 +14,61 @@ data class FishInfraction(val natinf: Int?, val infractionType: InfractionType?)
class MissionFishActionEntity(
override val id: Int?,
override val missionId: Int,
override val vesselId: Int?,
override val vesselName: String?,
override val internalReferenceNumber: String?,
override val externalReferenceNumber: String?,
override val ircs: String?,
override val flagState: CountryCode,
override val districtCode: String?,
override val faoAreas: List<String>,
override val vesselId: Int? = null,
override val vesselName: String? = null,
override val internalReferenceNumber: String? = null,
override val externalReferenceNumber: String? = null,
override val ircs: String? = null,
override val flagState: CountryCode? = null,
override val districtCode: String? = null,
override val faoAreas: List<String>? = null,
override val fishActionType: MissionActionType,
override val actionDatetimeUtc: Instant,
override val actionEndDatetimeUtc: Instant?,
override val emitsVms: ControlCheck?,
override val emitsAis: ControlCheck?,
override val flightGoals: List<FlightGoal>,
override val logbookMatchesActivity: ControlCheck?,
override val licencesMatchActivity: ControlCheck?,
override val speciesWeightControlled: Boolean?,
override val speciesSizeControlled: Boolean?,
override val separateStowageOfPreservedSpecies: ControlCheck?,
override val logbookInfractions: List<LogbookInfraction>,
override val licencesAndLogbookObservations: String?,
override val gearInfractions: List<GearInfraction>,
override val speciesInfractions: List<SpeciesInfraction>,
override val speciesObservations: String?,
override val seizureAndDiversion: Boolean?,
override val otherInfractions: List<OtherInfraction>,
override val numberOfVesselsFlownOver: Int?,
override val unitWithoutOmegaGauge: Boolean?,
override val controlQualityComments: String?,
override val feedbackSheetRequired: Boolean?,
override val userTrigram: String,
override val segments: List<FleetSegment>,
override val facade: String?,
override val longitude: Double?,
override val latitude: Double?,
override val portLocode: String?,
override var portName: String?,
override val vesselTargeted: ControlCheck?,
override val seizureAndDiversionComments: String?,
override val otherComments: String?,
override val gearOnboard: List<GearControl>,
override val speciesOnboard: List<SpeciesControl>,
override val isFromPoseidon: Boolean,
override var controlUnits: List<ControlUnit>,
override val isDeleted: Boolean,
override val hasSomeGearsSeized: Boolean,
override val hasSomeSpeciesSeized: Boolean,
override val completedBy: String?,
override val completion: Completion,
override val isAdministrativeControl: Boolean?,
override val isComplianceWithWaterRegulationsControl: Boolean?,
override val isSafetyEquipmentAndStandardsComplianceControl: Boolean?,
override val isSeafarersControl: Boolean?,
override var observationsByUnit: String?,
override var speciesQuantitySeized: Int?,
override val actionDatetimeUtc: Instant? = null,
override val actionEndDatetimeUtc: Instant? = null,
override val emitsVms: ControlCheck? = null,
override val emitsAis: ControlCheck? = null,
override val flightGoals: List<FlightGoal>? = listOf(),
override val logbookMatchesActivity: ControlCheck? = null,
override val licencesMatchActivity: ControlCheck? = null,
override val speciesWeightControlled: Boolean? = null,
override val speciesSizeControlled: Boolean? = null,
override val separateStowageOfPreservedSpecies: ControlCheck? = null,
override val logbookInfractions: List<LogbookInfraction>? = listOf(),
override val licencesAndLogbookObservations: String? = null,
override val gearInfractions: List<GearInfraction>? = listOf(),
override val speciesInfractions: List<SpeciesInfraction>? = listOf(),
override val speciesObservations: String? = null,
override val seizureAndDiversion: Boolean? = null,
override val otherInfractions: List<OtherInfraction>? = listOf(),
override val numberOfVesselsFlownOver: Int? = null,
override val unitWithoutOmegaGauge: Boolean? = null,
override val controlQualityComments: String? = null,
override val feedbackSheetRequired: Boolean? = null,
override val userTrigram: String? = null,
override val segments: List<FleetSegment>? = listOf(),
override val facade: String? = null,
override val longitude: Double? = null,
override val latitude: Double? = null,
override val portLocode: String? = null,
override var portName: String? = null,
override val vesselTargeted: ControlCheck? = null,
override val seizureAndDiversionComments: String? = null,
override val otherComments: String? = null,
override val gearOnboard: List<GearControl>? = listOf(),
override val speciesOnboard: List<SpeciesControl>? = listOf(),
override val isFromPoseidon: Boolean? = null,
override var controlUnits: List<ControlUnit>? = listOf(),
override val isDeleted: Boolean? = null,
override val hasSomeGearsSeized: Boolean? = null,
override val hasSomeSpeciesSeized: Boolean? = null,
override val completedBy: String? = null,
override val completion: Completion? = null,
override val isAdministrativeControl: Boolean? = null,
override val isComplianceWithWaterRegulationsControl: Boolean? = null,
override val isSafetyEquipmentAndStandardsComplianceControl: Boolean? = null,
override val isSeafarersControl: Boolean? = null,
override var observationsByUnit: String? = null,
override var speciesQuantitySeized: Int? = null,
) : MissionActionEntity(
missionId = missionId,
actionType = ActionType.CONTROL,
Expand All @@ -89,11 +89,11 @@ class MissionFishActionEntity(
override fun computeSummaryTags() {
val navInfractions = this.getControlInfractions()
val fishInfractions: List<FishInfraction> = listOf(
this.gearInfractions.map { FishInfraction(it.natinf, it.infractionType) },
this.logbookInfractions.map { FishInfraction(it.natinf, it.infractionType) },
this.speciesInfractions.map { FishInfraction(it.natinf, it.infractionType) },
this.otherInfractions.map { FishInfraction(it.natinf, it.infractionType) }
).flatten()
this.gearInfractions?.map { FishInfraction(it.natinf, it.infractionType) },
this.logbookInfractions?.map { FishInfraction(it.natinf, it.infractionType) },
this.speciesInfractions?.map { FishInfraction(it.natinf, it.infractionType) },
this.otherInfractions?.map { FishInfraction(it.natinf, it.infractionType) }
).filterNotNull().flatten()

val fishWithReport = fishInfractions.count { it.infractionType == InfractionType.WITH_RECORD }
val navWithReport = navInfractions.count { it.infractionType == InfractionTypeEnum.WITH_REPORT }
Expand Down
Loading
Loading