CompanyWithUserController.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. namespace Controllers;
  3. use Libs\BashExecutor;
  4. use Libs\ResponseLib;
  5. use Models\CompanyModel;
  6. use Models\UserModel;
  7. use Psr\Http\Message\ServerRequestInterface;
  8. class CompanyWithUserController
  9. {
  10. public function __invoke(ServerRequestInterface $request)
  11. {
  12. $body = json_decode((string)$request->getBody(), true) ?? [];
  13. $required = [
  14. 'company_name',
  15. 'username','email','password','phone','address','city','state','zip','country',
  16. 'kyc','birthdate','cpf'
  17. ];
  18. foreach ($required as $field) {
  19. if (!isset($body[$field]) || $body[$field] === '') {
  20. return ResponseLib::sendFail("Missing field: $field", [], "E_VALIDATE")->withStatus(400);
  21. }
  22. }
  23. if (!filter_var($body['email'], FILTER_VALIDATE_EMAIL)) {
  24. return ResponseLib::sendFail("Invalid email format", [], "E_VALIDATE")->withStatus(400);
  25. }
  26. if (strlen($body['password']) < 8) {
  27. return ResponseLib::sendFail("Password must be at least 8 characters", [], "E_VALIDATE")->withStatus(400);
  28. }
  29. try {
  30. $pdo = $GLOBALS['pdo'];
  31. $pdo->beginTransaction();
  32. $companyModel = new CompanyModel();
  33. $companyId = $companyModel->createCompany($body['company_name'], 'a');
  34. $roleId = 1;
  35. $chk = $pdo->prepare('SELECT 1 FROM "role" WHERE role_id = :rid');
  36. $chk->execute(['rid' => $roleId]);
  37. if (!$chk->fetchColumn()) {
  38. $pdo->rollBack();
  39. return ResponseLib::sendFail('Default role_id 1 not found', [], 'E_DATABASE')->withStatus(500);
  40. }
  41. $userModel = new UserModel();
  42. $userPayload = [
  43. 'username' => $body['username'],
  44. 'email' => $body['email'],
  45. 'password' => $body['password'],
  46. 'phone' => $body['phone'],
  47. 'address' => $body['address'],
  48. 'city' => $body['city'],
  49. 'state' => $body['state'],
  50. 'zip' => $body['zip'],
  51. 'country' => $body['country'],
  52. 'kyc' => (int)$body['kyc'],
  53. 'birthdate' => (int)$body['birthdate'],
  54. 'cpf' => $body['cpf'],
  55. 'company_id' => $companyId,
  56. 'role_id' => $roleId
  57. ];
  58. $userData = $userModel->createUser($userPayload);
  59. if (!$userData) {
  60. $pdo->rollBack();
  61. return ResponseLib::sendFail("Email already exists or creation failed", [], "E_VALIDATE")->withStatus(400);
  62. }
  63. $bin = dirname(__DIR__) . '/bin/easycli';
  64. $result = BashExecutor::run($bin . ' polygon create-new-address');
  65. if (($result['exitCode'] ?? 1) !== 0) {
  66. $pdo->rollBack();
  67. return ResponseLib::sendFail("Wallet generation failed", ['error' => $result['error'] ?? ''], "E_INTERNAL")->withStatus(500);
  68. }
  69. $output = trim((string)($result['output'] ?? ''));
  70. $parsed = [];
  71. foreach (preg_split('/\r?\n/', $output) as $line) {
  72. $line = trim($line);
  73. if ($line === '' || strpos($line, '=') === false) { continue; }
  74. [$k, $v] = explode('=', $line, 2);
  75. $parsed[trim($k)] = trim($v);
  76. }
  77. if (!isset($parsed['privateKey'], $parsed['publicKey'], $parsed['address'])) {
  78. $pdo->rollBack();
  79. return ResponseLib::sendFail("Wallet parsing failed", ['raw' => $output], "E_INTERNAL")->withStatus(500);
  80. }
  81. $stmt = $pdo->prepare('SELECT chain_id FROM "chain" WHERE chain_name = :name');
  82. $stmt->execute(['name' => 'primalchain']);
  83. $chainId = $stmt->fetchColumn();
  84. if (!$chainId) {
  85. $pdo->rollBack();
  86. return ResponseLib::sendFail("Chain not found", [], "E_DATABASE")->withStatus(500);
  87. }
  88. $stmt = $pdo->prepare('INSERT INTO "wallet" (company_id, wallet_public_key, wallet_address, wallet_private_key, wallet_flag, chain_id) VALUES (:company_id, :public_key, :address, :private_key, :flag, :chain_id) RETURNING wallet_id');
  89. $stmt->execute([
  90. 'company_id' => $companyId,
  91. 'public_key' => $parsed['publicKey'],
  92. 'address' => $parsed['address'],
  93. 'private_key' => $parsed['privateKey'],
  94. 'flag' => 'a',
  95. 'chain_id' => (int)$chainId
  96. ]);
  97. $walletId = (int)$stmt->fetchColumn();
  98. $pdo->commit();
  99. return ResponseLib::sendOk([
  100. 'company_id' => $companyId,
  101. 'role_id' => $roleId,
  102. 'user' => $userData,
  103. 'wallet_id' => $walletId,
  104. 'wallet_address' => $parsed['address']
  105. ], 'S_CREATED');
  106. } catch (\Throwable $e) {
  107. if (isset($pdo) && $pdo->inTransaction()) { $pdo->rollBack(); }
  108. return ResponseLib::sendFail($e->getMessage(), [], 'E_DATABASE')->withStatus(500);
  109. }
  110. }
  111. }