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"
@@ -9,6 +10,7 @@ import (
"satusehat-rssa/internal/constant"
"satusehat-rssa/internal/model"
"satusehat-rssa/pkg/httputil"
"satusehat-rssa/pkg/redis"
)
type ConditionInterface interface {
@@ -105,21 +107,15 @@ func (c *ConditionRepository) CreateCondition(req model.ConditionRequest) (map[s
if err != nil {
return nil, err
}
oauth := model.OauthRequest{
ClientId: c.akses.ClientId,
ClientSecret: c.akses.ClientSecret,
}
OauthInterface := NewOauthRequestRepo(c.akses)
token, err := OauthInterface.GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(c.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)
res, err := client.Do(request)
if err != nil {
@@ -147,20 +143,15 @@ func (c *ConditionRepository) GetConditionByPatient(id string) (map[string]inter
if err != nil {
return nil, err
}
oauth := model.OauthRequest{
ClientId: c.akses.ClientId,
ClientSecret: c.akses.ClientSecret,
}
OauthInterface := NewOauthRequestRepo(c.akses)
token, err := OauthInterface.GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(c.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 {
@@ -207,15 +198,12 @@ func (c *ConditionRepository) UpdateCondition(req model.ConditionRequest) (map[s
}
}
oauth := model.OauthRequest{
ClientId: c.akses.ClientId,
ClientSecret: c.akses.ClientSecret,
}
token, err := NewOauthRequestRepo(c.akses).GenerateToken(oauth)
redisRepo := redis.NewRedisAuth(c.akses)
token, err := redisRepo.GetOrCreateTokenSS(context.Background(), req.Subject.Reference)
if err != nil {
return nil, err
}
if token == nil {
if token == "" {
return nil, errors.New(constant.ErrGenerateToken)
}
@@ -224,7 +212,7 @@ func (c *ConditionRepository) UpdateCondition(req model.ConditionRequest) (map[s
Method: "PUT",
URL: url,
Body: req,
BearerToken: token.AccessToken,
BearerToken: token,
Headers: httputil.DefaultFHIRHeaders(),
})
}