#!/usr/bin/env php setViewer(PhabricatorUser::getOmnipotentUser()) ->execute(); foreach ($keys as $key => $ssh_key) { // For now, filter out any keys which don't belong to users. Eventually we // may allow devices to use this channel. if (!($ssh_key->getObject() instanceof PhabricatorUser)) { unset($keys[$key]); continue; } } if (!$keys) { echo pht('No keys found.')."\n"; exit(1); } $bin = $root.'/bin/ssh-exec'; foreach ($keys as $ssh_key) { $user = $ssh_key->getObject()->getUsername(); $key_argv = array(); $key_argv[] = '--phabricator-ssh-user'; $key_argv[] = $user; $cmd = csprintf('%s %Ls', $bin, $key_argv); $instance = PhabricatorEnv::getEnvConfig('cluster.instance'); if (strlen($instance)) { $cmd = csprintf('PHABRICATOR_INSTANCE=%s %C', $instance, $cmd); } // This is additional escaping for the SSH 'command="..."' string. $cmd = addcslashes($cmd, '"\\'); // Strip out newlines and other nonsense from the key type and key body. $type = $ssh_key->getKeyType(); $type = preg_replace('@[\x00-\x20]+@', '', $type); if (!strlen($type)) { continue; } $key = $ssh_key->getKeyBody(); $key = preg_replace('@[\x00-\x20]+@', '', $key); if (!strlen($key)) { continue; } $options = array( 'command="'.$cmd.'"', 'no-port-forwarding', 'no-X11-forwarding', 'no-agent-forwarding', 'no-pty', ); $options = implode(',', $options); $lines[] = $options.' '.$type.' '.$key."\n"; } echo implode('', $lines); exit(0);