Пример #1
0
}
echo phutil_console_wrap(phutil_console_format('This script will test that you have configured valid credentials for ' . 'access to a repository, so the Phabricator daemons can pull from it. ' . 'You should run this as the **same user you will run the daemons as**, ' . 'from the **same machine they will run from**. Doing this will help ' . 'detect various problems with your configuration, such as SSH issues.'));
list($whoami) = execx('whoami');
$whoami = trim($whoami);
$ok = phutil_console_confirm("Do you want to continue as '{$whoami}'?");
if (!$ok) {
    die(1);
}
$callsign = $argv[1];
echo "Loading '{$callsign}' repository...\n";
$repository = id(new PhabricatorRepository())->loadOneWhere('callsign = %s', $argv[1]);
if (!$repository) {
    throw new Exception("No such repository exists!");
}
$vcs = $repository->getVersionControlSystem();
PhutilServiceProfiler::installEchoListener();
echo "Trying to connect to the remote...\n";
switch ($vcs) {
    case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
        $err = $repository->passthruRemoteCommand('--limit 1 log %s', $repository->getRemoteURI());
        break;
    case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
        // Do an ls-remote on a nonexistent ref, which we expect to just return
        // nothing.
        $err = $repository->passthruRemoteCommand('ls-remote %s %s', $repository->getRemoteURI(), 'just-testing');
        break;
    default:
        throw new Exception("Unsupported repository type.");
}
if ($err) {
    echo phutil_console_format("<bg:red>** FAIL **</bg> Connection failed. The credentials for this " . "repository appear to be incorrectly configured.\n");
 /**
  * Parse "standard" arguments and apply their effects:
  *
  *    --trace             Enable service call tracing.
  *    --no-ansi           Disable ANSI color/style sequences.
  *    --xprofile <file>   Write out an XHProf profile.
  *    --help              Show help.
  *
  * @return this
  *
  * @phutil-external-symbol function xhprof_enable
  */
 public function parseStandardArguments()
 {
     try {
         $this->parsePartial(array(array('name' => 'trace', 'help' => pht('Trace command execution and show service calls.'), 'standard' => true), array('name' => 'no-ansi', 'help' => pht('Disable ANSI terminal codes, printing plain text with ' . 'no color or style.'), 'conflicts' => array('ansi' => null), 'standard' => true), array('name' => 'ansi', 'help' => pht("Use formatting even in environments which probably " . "don't support it."), 'standard' => true), array('name' => 'xprofile', 'param' => 'profile', 'help' => pht('Profile script execution and write results to a file.'), 'standard' => true), array('name' => 'help', 'short' => 'h', 'help' => pht('Show this help.'), 'standard' => true), array('name' => 'show-standard-options', 'help' => pht('Show every option, including standard options like this one.'), 'standard' => true), array('name' => 'recon', 'help' => pht('Start in remote console mode.'), 'standard' => true)));
     } catch (PhutilArgumentUsageException $ex) {
         $this->printUsageException($ex);
         exit(self::PARSE_ERROR_CODE);
     }
     if ($this->getArg('trace')) {
         PhutilServiceProfiler::installEchoListener();
     }
     if ($this->getArg('no-ansi')) {
         PhutilConsoleFormatter::disableANSI(true);
     }
     if ($this->getArg('ansi')) {
         PhutilConsoleFormatter::disableANSI(false);
     }
     if ($this->getArg('help')) {
         $this->showHelp = true;
     }
     $xprofile = $this->getArg('xprofile');
     if ($xprofile) {
         if (!function_exists('xhprof_enable')) {
             throw new Exception(pht("To use '%s', you must install XHProf.", '--xprofile'));
         }
         xhprof_enable(0);
         register_shutdown_function(array($this, 'shutdownProfiler'));
     }
     $recon = $this->getArg('recon');
     if ($recon) {
         $remote_console = PhutilConsole::newRemoteConsole();
         $remote_console->beginRedirectOut();
         PhutilConsole::setConsole($remote_console);
     } else {
         if ($this->getArg('trace')) {
             $server = new PhutilConsoleServer();
             $server->setEnableLog(true);
             $console = PhutilConsole::newConsoleForServer($server);
             PhutilConsole::setConsole($console);
         }
     }
     return $this;
 }
Пример #3
0
 public final function setTraceMode()
 {
     $this->traceMode = true;
     PhutilServiceProfiler::installEchoListener();
     PhutilConsole::getConsole()->getServer()->setEnableLog(true);
     $this->didSetTraceMode();
     return $this;
 }
Пример #4
0
 public final function setTraceMode()
 {
     $this->traceMode = true;
     PhutilServiceProfiler::installEchoListener();
     $this->didSetTraceMode();
     return $this;
 }