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
@@ -1,6 +1,7 @@
package integration
import (
"context"
"encoding/json"
"errors"
"fmt"
@@ -10,6 +11,7 @@ import (
"satusehat-rssa/internal/model"
"satusehat-rssa/pkg/common"
"satusehat-rssa/pkg/httputil"
"satusehat-rssa/pkg/redis"
)
type MedicationRequestInterface interface {
@@ -43,18 +45,15 @@ func (c *MedicationRequestRepository) GetMedicationRequestByPatient(id string, c
if err != nil {
return nil, err
}
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(), id)
if err != nil {
return nil, err
}
if token == nil {
if token == "" {
return nil, errors.New(constant.ErrGenerateToken)
}
request.Header.Add("Authorization", "Bearer "+token.AccessToken)
request.Header.Add("Authorization", "Bearer "+token)
request.Header.Set("Content-Type", constant.ContentTypeFHIRJSON)
request.Header.Set("Accept", constant.ContentTypeFHIRJSON)
res, err := client.Do(request)
@@ -127,15 +126,12 @@ func (c *MedicationRequestRepository) CreateMedicationRequest(req model.Medicati
// return nil, err
// }
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)
}
@@ -144,7 +140,7 @@ func (c *MedicationRequestRepository) CreateMedicationRequest(req model.Medicati
Method: "POST",
URL: url,
Body: req,
BearerToken: token.AccessToken,
BearerToken: token,
Headers: httputil.DefaultFHIRHeaders(),
})
}
@@ -171,15 +167,12 @@ func (c *MedicationRequestRepository) UpdateMedicationRequest(req model.Medicati
// return nil, err
// }
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)
}
@@ -188,7 +181,7 @@ func (c *MedicationRequestRepository) UpdateMedicationRequest(req model.Medicati
Method: "PUT",
URL: url,
Body: req,
BearerToken: token.AccessToken,
BearerToken: token,
Headers: httputil.DefaultFHIRHeaders(),
})
}