From 575192a7f6df216d5f5fbd49f87ae3258b20be90 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=98ydis=20Kind=20Refsum?= Date: Wed, 30 Oct 2024 13:47:09 +0100 Subject: [PATCH] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20Innf=C3=B8rer=20QueryRunne?= =?UTF-8?q?r=20i=20OppgaveApiDao?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Christian Skovborg Gule --- .../spesialist/api/oppgave/OppgaveApiDao.kt | 30 +++++++++---------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/spesialist-api/src/main/kotlin/no/nav/helse/spesialist/api/oppgave/OppgaveApiDao.kt b/spesialist-api/src/main/kotlin/no/nav/helse/spesialist/api/oppgave/OppgaveApiDao.kt index 0c59384a9..ac71f5c4e 100644 --- a/spesialist-api/src/main/kotlin/no/nav/helse/spesialist/api/oppgave/OppgaveApiDao.kt +++ b/spesialist-api/src/main/kotlin/no/nav/helse/spesialist/api/oppgave/OppgaveApiDao.kt @@ -1,10 +1,12 @@ package no.nav.helse.spesialist.api.oppgave -import no.nav.helse.HelseDao +import no.nav.helse.HelseDao.Companion.asSQL +import no.nav.helse.db.MedDataSource +import no.nav.helse.db.QueryRunner import java.util.UUID import javax.sql.DataSource -class OppgaveApiDao(dataSource: DataSource) : HelseDao(dataSource) { +class OppgaveApiDao(dataSource: DataSource) : QueryRunner by MedDataSource(dataSource) { fun finnOppgaveId(fødselsnummer: String) = asSQL( """ @@ -14,7 +16,7 @@ class OppgaveApiDao(dataSource: DataSource) : HelseDao(dataSource) { WHERE p.fodselsnummer = :fodselsnummer AND status = 'AvventerSaksbehandler'::oppgavestatus; """.trimIndent(), "fodselsnummer" to fødselsnummer.toLong(), - ).single { it.long("oppgaveId") } + ).singleOrNull { it.long("oppgaveId") } fun finnPeriodeoppgave(vedtaksperiodeId: UUID) = asSQL( @@ -26,20 +28,18 @@ class OppgaveApiDao(dataSource: DataSource) : HelseDao(dataSource) { AND status = 'AvventerSaksbehandler'::oppgavestatus """.trimIndent(), "vedtaksperiodeId" to vedtaksperiodeId, - ).single { OppgaveForPeriodevisningDto(id = it.string("id"), kanAvvises = it.boolean("kan_avvises")) } + ).singleOrNull { OppgaveForPeriodevisningDto(id = it.string("id"), kanAvvises = it.boolean("kan_avvises")) } fun finnFødselsnummer(oppgaveId: Long) = - requireNotNull( - asSQL( - """ - SELECT fodselsnummer from person - INNER JOIN vedtak v on person.id = v.person_ref - INNER JOIN oppgave o on v.id = o.vedtak_ref - WHERE o.id = :oppgaveId - """.trimIndent(), - "oppgaveId" to oppgaveId, - ).single { it.long("fodselsnummer").toFødselsnummer() }, - ) + asSQL( + """ + SELECT fodselsnummer from person + INNER JOIN vedtak v on person.id = v.person_ref + INNER JOIN oppgave o on v.id = o.vedtak_ref + WHERE o.id = :oppgaveId + """.trimIndent(), + "oppgaveId" to oppgaveId, + ).single { it.long("fodselsnummer").toFødselsnummer() } companion object { private fun Long.toFødselsnummer() = if (this < 10000000000) "0$this" else this.toString()