Files
caliverse_server/BrokerApiTest/DocQuery/DataExample.cs
2025-05-01 07:20:41 +09:00

178 lines
7.5 KiB
C#

using PlatformTest.DbQuery;
using ServerCommon;
using ServerCore; using ServerBase;
using USER_GUID = System.String;
// public class DBQUserTest : QueryExecutorBase
// {
// private string m_combination_key_for_pk = string.Empty;
// private string m_combination_key_for_sk = string.Empty;
// private UserTestEntity? m_user_test;
// private DynamoDbClient m_dynamoDbClient;
//
// public DBQUserTest(string combinationKeyForPK, string combinationKeyForSK, DynamoDbClient dynamoDbClient)
// : base(nameof(DBQUserTest))
// {
// m_combination_key_for_pk = combinationKeyForPK;
// m_combination_key_for_sk = combinationKeyForSK;
// m_dynamoDbClient = dynamoDbClient;
// }
//
// //===================================================================================================
// // DB 쿼리 직전에 준비해야 할 로직들을 작성한다.
// //===================================================================================================
// public override async Task<Result> onPrepareQuery()
// {
// var result = new Result();
//
// var user_test = getOwner();
// NullReferenceCheckHelper.throwIfNull(user_test, () => "user is null !!!");
//
// var query_batch = getQueryBatch();
// NullReferenceCheckHelper.throwIfNull(query_batch,
// () => $"query_batch is null !!! - {user_test.toBasicString()}");
//
// var db_connector = query_batch.getDynamoDbConnector();
// NullReferenceCheckHelper.throwIfNull(db_connector,
// () => $"db_connector is null !!! - {user_test.toBasicString()}");
//
// await DynamoDBDocBaseHelper.makePrimaryKey<UserTestDoc>(m_combination_key_for_pk, m_combination_key_for_sk);
//
// // var ctxs = new List<DynamoDbDocumentQueryContext>();
// //
// // (result, var user_doc) = await m_user_test.onCopyToDocument();
//
//
// return Task.FromResult(result);
// }
//
// //===================================================================================================
// // onPrepareQuery()를 성공할 경우 호출된다.
// //===================================================================================================
// public override async Task<Result> onQuery()
// {
// var result = new Result();
// var err_msg = string.Empty;
//
// var user = getOwner();
// NullReferenceCheckHelper.throwIfNull(user, () => "user is null !!!");
//
// var query_batch = getQueryBatch();
// NullReferenceCheckHelper.throwIfNull(query_batch, () => $"query_batch is null !!! - {user.toBasicString()}");
//
// var db_connector = query_batch.getDynamoDbConnector();
//
// var user_doc = new UserTestDoc(m_combination_key_for_pk, m_combination_key_for_sk);
// var user_test_base = new UserTestEntity(EntityType.None);
// var user_test_base_attrib = user_test_base.getEntityAttribute<UserTestEntityAttribute>();
// NullReferenceCheckHelper.throwIfNull(user_test_base_attrib, () => $"user_test_base_attrib is null !!!");
//
// user_test_base_attrib.UserId = m_combination_key_for_pk;
// user_test_base_attrib.Name = m_combination_key_for_sk;
//
// var user_test_base_action = user_test_base.getEntityAction<UserTestInsertAction>();
// NullReferenceCheckHelper.throwIfNull(user_test_base_action, () => $"user_test_base_action is null !!!");
//
// result = await user_test_base_action.tryInsertUser(m_combination_key_for_pk, m_combination_key_for_sk);
// if (result.isFail())
// {
// return result;
// }
//
// var query_context = new DynamoDbDocumentQueryContext(user_doc, QueryType.Insert);
// await query_batch.addQuery(new QueryExecutorBase("InsertUser")
// {
// onPrepareQuery = () => Task.FromResult(new Result()),
// onQuery = () => Task.FromResult(new Result()),
// onQueryResponseCommit = () => Task.CompletedTask,
// onQueryResponseRollback = (errorResult) => Task.CompletedTask
// });
//
// var result = await QueryHelper.sendQueryAndBusinessLog(query_batch);
// if (result.isFail())
// {
// return result;
// }
//
// return result;
// }
//
// //===================================================================================================
// // DB 쿼리를 성공하고, doFnCommit()가 QueryResultType.NotCalledQueryFunc를 반환할 경우 호출된다.
// //===================================================================================================
// public override Task onQueryResponseCommit()
// {
// return Task.CompletedTask;
// }
//
// //===================================================================================================
// // DB 쿼리를 실패하고, doFnRollback()가 QueryResultType.NotCalledQueryFunc를 반환할 경우 호출된다.
// //===================================================================================================
// public override Task onQueryResponseRollback(Result errorResult)
// {
// return Task.CompletedTask;
// }
// }
public class UserTestActorLog : ILogActor
{
}
// EntityBase를 상속 받은 Entity는 EntityAttributeBase와 EntityActionBase를 상속받아 자동으로 만들어진 Attribute들과 Action들을 가지고 있습니다.
// 위 내용은 onInit()에서 직접 생성해서 초기화 한다.
public class DynamoDbExample
{
private readonly DynamoDbClient m_dynamo_db_client;
private readonly UserTestEntity m_user_entity;
public DynamoDbExample(DynamoDbClient dynamoDbClient)
{
m_dynamo_db_client = dynamoDbClient;
m_user_entity = new UserTestEntity();
}
public async Task<(Result, UserTestDoc?)> insertUser(string userId, string name)
{
await m_user_entity.onInit();
var action = m_user_entity.getEntityAction<UserTestInsertAction>();
NullReferenceCheckHelper.throwIfNull(action,
() => $"UserTestInsertAction is null !!! - {m_user_entity.toBasicString()}");
var (result, user_test_doc) = await action.tryInsertUser(userId, name, m_dynamo_db_client);
return (result, user_test_doc);
}
public async Task<(Result, UserTestDoc?)> findUserOne(string userId)
{
await m_user_entity.onInit();
var action = m_user_entity.getEntityAction<UserTestFindOneAction>();
NullReferenceCheckHelper.throwIfNull(action,
() => $"UserTestInsertAction is null !!! - {m_user_entity.toBasicString()}");
return await action.findUserOne(userId, m_dynamo_db_client);
}
public async Task<(Result, UserTestDoc?)> updateUser(string userId, string newName)
{
await m_user_entity.onInit();
var action = m_user_entity.getEntityAction<UserTestUpdateOneAction>();
NullReferenceCheckHelper.throwIfNull(action,
() => $"UserTestUpdateOneAction is null !!! - {m_user_entity.toBasicString()}");
return await action.updateOne(userId, newName, m_dynamo_db_client);
}
public async Task<Result> DeleteUserOne(string userId)
{
await m_user_entity.onInit();
var action = m_user_entity.getEntityAction<UserTestDeleteOneAction>();
NullReferenceCheckHelper.throwIfNull(action,
() => $"UserTestDeleteOneAction is null !!! - {m_user_entity.toBasicString()}");
return await action.deleteOne(userId, m_dynamo_db_client);
}
}