namespace app\Controller\Github;
use app\Controller\Github;
+use app\Github\API;
+use app\Model\Accounts;
+use app\Session;
+use app\Web;
+use http\Cookie;
class Callback extends Github
{
+ /**
+ * @var Accounts
+ */
+ private $accounts;
+
+ function __construct(Web $app, API $github, Session $session, Accounts $accounts) {
+ parent::__construct($app, $github, $session);
+ $this->accounts = $accounts;
+ }
+
function __invoke(array $args = null) {
if ($this->app->getRequest()->getQuery("error")) {
$this->app->getView()->addData([
"error" => $this->app->getRequest()->getQuery("error_description")
]);
} else {
- try {
- $this->github->fetchToken(
- $this->app->getRequest()->getQuery("code"),
- $this->app->getRequest()->getQuery("state"),
- function($json) {
- $this->github->setToken($json->access_token);
- $this->github->fetchUser(function($user) {
- $this->session->github = $user;
- });
- })->send();
- if (isset($this->session->returnto)) {
- $this->app->redirect($this->session->returnto);
- } else {
- $this->app->redirect(
- $this->app->getBaseUrl()->mod("./github"));
- }
- } catch (\app\Github\Exception $exception) {
- $this->app->getView()->addData(compact("exception"));
+ $this->validateUser();
+
+ if (isset($this->session->returnto)) {
+ $returnto = $this->session->returnto;
+ unset($this->session->returnto);
+ $this->app->redirect($returnto);
+ } else {
+ $this->app->redirect(
+ $this->app->getBaseUrl()->mod("./github"));
}
}
$this->app->display("github/callback");
}
+
+ private function validateUser() {
+ $this->github->fetchToken(
+ $this->app->getRequest()->getQuery("code"),
+ $this->app->getRequest()->getQuery("state")
+ )->then(function($result) {
+ list($oauth) = $result;
+ $this->github->setToken($oauth->access_token);
+ return $this->github->readAuthUser()->then(function($result) use($oauth) {
+ list($user) = $result;
+ return $this->persistUser($oauth, $user);
+ });
+ })->done(function($result) {
+ $this->login(...$result);
+ });
+
+ $this->github->getClient()->send();
+ }
+
+ private function persistUser($oauth, $user) {
+ $tx = $this->accounts->getConnection()->startTransaction();
+
+ if (($cookie = $this->app->getRequest()->getCookie("account"))) {
+ $account = $this->accounts->find(["account=" => $cookie])->current();
+ } elseif (!($account = $this->accounts->byOAuth("github", $oauth->access_token, $user->login))) {
+ $account = $this->accounts->createOAuthAccount("github", $oauth->access_token, $user->login);
+ }
+ $token = $account->updateToken("github", $oauth->access_token, $oauth);
+ $owner = $account->updateOwner("github", $user->login, $user);
+
+ $tx->commit();
+
+ return [$account, $token, $owner];
+ }
}