read by token all source

This commit is contained in:
gigihshs
2026-04-21 15:17:12 +07:00
parent 6dfc474924
commit 6b9954c735
24 changed files with 345 additions and 529 deletions
+14 -26
View File
@@ -2,6 +2,7 @@ package integration
import (
"bytes"
"context"
"encoding/json"
"errors"
"fmt"
@@ -10,6 +11,7 @@ import (
"satusehat-rssa/internal/constant"
"satusehat-rssa/internal/model"
"satusehat-rssa/pkg/httputil"
"satusehat-rssa/pkg/redis"
"time"
)
@@ -75,20 +77,15 @@ func (e *EncounterRepository) GetEncounterByPatient(id string) (map[string]inter
if err != nil {
return nil, err
}
oauth := model.OauthRequest{
ClientId: e.akses.ClientId,
ClientSecret: e.akses.ClientSecret,
}
OauthInterface := NewOauthRequestRepo(e.akses)
token, err := OauthInterface.GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(e.akses)
token, err := redisRepo.GetOrCreateTokenSS(context.Background(), id)
if err != nil {
return nil, err
}
if token != nil {
request.Header.Add("Authorization", "Bearer "+token.AccessToken)
} else {
if token == "" {
return nil, errors.New(constant.ErrGenerateToken)
}
request.Header.Add("Authorization", "Bearer "+token)
request.Header.Set("Content-Type", constant.ContentTypeFHIRJSON)
res, err := client.Do(request)
if err != nil {
@@ -138,21 +135,15 @@ func (e *EncounterRepository) CreateEncounter(req model.EncounterRequest) (map[s
if err != nil {
return nil, err
}
oauth := model.OauthRequest{
ClientId: e.akses.ClientId,
ClientSecret: e.akses.ClientSecret,
}
OauthInterface := NewOauthRequestRepo(e.akses)
token, err := OauthInterface.GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(e.akses)
token, err := redisRepo.GetOrCreateTokenSS(context.Background(), req.Subject.Reference)
if err != nil {
return nil, err
}
if token != nil {
request.Header.Add("Authorization", "Bearer "+token.AccessToken)
} else {
if token == "" {
return nil, errors.New(constant.ErrGenerateToken)
}
request.Header.Add("Authorization", "Bearer "+token)
request.Header.Set("Content-Type", constant.ContentTypeFHIRJSON)
request.Header.Set("Accept", constant.ContentTypeFHIRJSON)
@@ -172,15 +163,12 @@ func (e *EncounterRepository) CreateEncounter(req model.EncounterRequest) (map[s
// UpdateEncounter implements EncounterInterface.
func (e *EncounterRepository) UpdateEncounter(req model.EncounterUpdateRequest) (map[string]interface{}, error) {
oauth := model.OauthRequest{
ClientId: e.akses.ClientId,
ClientSecret: e.akses.ClientSecret,
}
token, err := NewOauthRequestRepo(e.akses).GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(e.akses)
token, err := redisRepo.GetOrCreateTokenSS(context.Background(), "")
if err != nil {
return nil, err
}
if token == nil {
if token == "" {
return nil, errors.New(constant.ErrGenerateToken)
}
@@ -189,7 +177,7 @@ func (e *EncounterRepository) UpdateEncounter(req model.EncounterUpdateRequest)
Method: "PUT",
URL: url,
Body: req,
BearerToken: token.AccessToken,
BearerToken: token,
Headers: httputil.DefaultFHIRHeaders(),
})
}