Skip to content

Mottaksapplikasjon for søknad om stønad til enslig forsørger

License

Notifications You must be signed in to change notification settings

navikt/familie-ef-mottak

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

familie-ef-mottak

Mottaksapplikasjon for søknader om overgangsstønad.

Kjøre appen

ApplicationLocal launcher appen med Spring-profil local og appen blir tilgjengelig på port 8092.

Hent ut token lokal: http://localhost:8092/local/cookie?issuerId=tokenx&audience=aud-localhost&subject=[fnr]

Kommunisere med ef-sak lokalt

Dersom man ønsker å sende søknader til ef-sak, må man sette opp noen miljøvariabler fordi ef-sak krever preprod-autentisering også lokalt. Følgende miljøvariabler må hentes fra azure secrets injectet i pod, og secrets-filen med navn familie-ef-mottak i dev-gcp:

  • AZURE_APP_CLIENT_ID
  • AZURE_APP_CLIENT_SECRET
  • EF_SAK_SCOPE

Variablene legges inn under ApplicationLocal -> Edit Configurations -> Environment Variables.

Kafka

Lokalt må man kjøre serveren sammen med navkafka-docker-compose. Topicene vi lytter på og publiserer til må da opprettes via deres api med følgende data:

{
  "topics": [
    {
      "topicName": "aapen-brukernotifikasjon-nyBeskjed-v1",
      "members": [
        {"member":"srvc01", "role":"PRODUCER"}
      ],
      "numPartitions": 3
    },
    {
      "topicName": "aapen-dok-journalfoering-v1",
      "members": [
        {"member":"srvc01", "role":"CONSUMER"}
      ],
      "numPartitions": 3
    },
  ]
}

Dette kan enkelt gjøres via følgende kommandoer:

curl -X POST "http://igroup:itest@localhost:8840/api/v1/topics" -H "Accept: application/json" -H "Content-Type: application/json" --data "{"name": "aapen-brukernotifikasjon-nyBeskjed-v1", "members": [{ "member": "srvc01", "role": "PRODUCER" }], "numPartitions": 3 }"

curl -X POST "http://igroup:itest@localhost:8840/api/v1/topics" -H "Accept: application/json" -H "Content-Type: application/json" --data "{"name": "aapen-dok-journalfoering-v1", "members": [{ "member": "srvc01", "role": "CONSUMER" }], "numPartitions": 3 }"

Se README i navkafka-docker-compose for mer info om hvordan man kjører den og kaller apiet.

Database

For å sette opp Postgres-database lokalt med Docker:

docker run --name familie-ef-mottak -e POSTGRES_PASSWORD=<PASSWORD> -d -p 5432:5432 postgres
docker ps (finn container id)
docker exec -it <container_id> bash
psql -U postgres
CREATE DATABASE "familie-ef-mottak";

For å starte en container som ikke kjører lenger:

docker ps -a (lister ut alle)
docker start <container id>

For å kjøre med denne lokalt må følgende miljøvariabler settes i application-local.yml:

spring.datasource.url=jdbc:postgresql://<HOST>:<PORT>/familie-ef-mottak
spring.datasource.username=<USERNAME>
spring.datasource.password=<PASSWORD>

f.eks.

spring.datasource.url=jdbc:postgresql://0.0.0.0:5432/familie-ef-mottak
spring.datasource.username=postgres
spring.datasource.password=test

Les mer om postgres på nav her. For å hente credentials manuelt, se her.

Swagger

f.eks. http://localhost:8092/swagger-ui.html

Kode generert av GitHub Copilot

Dette repoet bruker GitHub Copilot til å generere kode.