當前位置: 首頁>>代碼示例>>Python>>正文


Python SSHCommandClientEndpoint.newConnection方法代碼示例

本文整理匯總了Python中twisted.conch.endpoints.SSHCommandClientEndpoint.newConnection方法的典型用法代碼示例。如果您正苦於以下問題:Python SSHCommandClientEndpoint.newConnection方法的具體用法?Python SSHCommandClientEndpoint.newConnection怎麽用?Python SSHCommandClientEndpoint.newConnection使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在twisted.conch.endpoints.SSHCommandClientEndpoint的用法示例。


在下文中一共展示了SSHCommandClientEndpoint.newConnection方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _get_endpoint

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def _get_endpoint(self):
     """ Creates a generic endpoint connection that doesn't finish
     """
     return SSHCommandClientEndpoint.newConnection(
         reactor, b'/bin/cat', self.username, self.hostname,
         port=self.port, keys=self.keys, password=self.password,
         knownHosts = self.knownHosts)
開發者ID:calston,項目名稱:tensor,代碼行數:9,代碼來源:ssh.py

示例2: test_mismatchedHostKey

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def test_mismatchedHostKey(self):
        """
        If the SSH public key presented by the SSH server does not match the
        previously remembered key, as reported by the L{KnownHostsFile}
        instance use to construct the endpoint, for that server, the
        L{Deferred} returned by L{SSHCommandClientEndpoint.connect} fires with
        a L{Failure} wrapping L{HostKeyChanged}.
        """
        differentKey = Key.fromString(privateDSA_openssh).public()
        knownHosts = KnownHostsFile(self.mktemp())
        knownHosts.addHostKey(self.serverAddress.host, differentKey)
        knownHosts.addHostKey(self.hostname, differentKey)

        # The UI may answer true to any questions asked of it; they should
        # make no difference, since a *mismatched* key is not even optionally
        # allowed to complete a connection.
        ui = FixedResponseUI(True)

        endpoint = SSHCommandClientEndpoint.newConnection(
            self.reactor, b"/bin/ls -l", b"dummy user",
            self.hostname, self.port, password=b"dummy password",
            knownHosts=knownHosts, ui=ui)

        factory = Factory()
        factory.protocol = Protocol
        connected = endpoint.connect(factory)

        server, client, pump = self.connectedServerAndClient(
            self.factory, self.reactor.tcpClients[0][2])

        f = self.failureResultOf(connected)
        f.trap(HostKeyChanged)
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:34,代碼來源:test_endpoints.py

示例3: test_connectionCancelledBeforeSecure

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def test_connectionCancelledBeforeSecure(self):
        """
        If the connection is cancelled before the SSH transport layer has
        finished key exchange (ie, gotten to the point where we may attempt to
        authenticate), the L{Deferred} returned by
        L{SSHCommandClientEndpoint.connect} fires with a L{Failure} wrapping
        L{CancelledError} and the connection is aborted.
        """
        endpoint = SSHCommandClientEndpoint.newConnection(
            self.reactor, b"/bin/ls -l", b"dummy user",
            self.hostname, self.port, knownHosts=self.knownHosts,
            ui=FixedResponseUI(False))

        factory = Factory()
        factory.protocol = Protocol
        d = endpoint.connect(factory)

        transport = AbortableFakeTransport(None, isServer=False)
        factory = self.reactor.tcpClients[0][2]
        client = factory.buildProtocol(None)
        client.makeConnection(transport)
        d.cancel()

        self.failureResultOf(d).trap(CancelledError)
        self.assertTrue(transport.aborted)
        # Make sure the connection closing doesn't result in unexpected
        # behavior when due to cancellation:
        client.connectionLost(Failure(ConnectionDone()))
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:30,代碼來源:test_endpoints.py

示例4: main

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
def main(reactor):
    ep = SSHCommandClientEndpoint.newConnection(
        reactor, b'/bin/cat',
        details['USER'],
        details['HOST'],
        port=details['PORT'],
        password=details['PASSWORD'],
        agentEndpoint=None,
        knownHosts=None)
    factory = Factory()
    factory.protocol = MyProtocol

    d = ep.connect(factory)


    def gotConnection(proto):
        # stdio interface
        stdio_proto = StdinProto(proto.transport.conn)
        stdio.StandardIO(stdio_proto)

        # factory = Factory()
        # factory.protocol = MyProtocol

        # e = SSHCommandClientEndpoint.existingConnection(conn, b"/bin/echo hey")
        # return e.connect(factory).addCallback(lambda proto: proto.finished)
        return stdio_proto.finished

    return d.addCallback(gotConnection)
開發者ID:moldit,項目名稱:mold,代碼行數:30,代碼來源:ssh2.py

示例5: connect

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
def connect(sdata, command, username, host, port=22, key_file=None, password=None):
    """
    Connect to an SSH host (as it happens, persistently).
    """
    sdata.set_conn_state('connecting')

    try:
        keys = [Key.fromFile(key_file)] if key_file else None
    except exceptions.IOError as e:
        print('### key load error:', str(e))
        push_failure_message(str(e), sdata)
        return

    endpoint = SSHCommandClientEndpoint.newConnection(
                    reactor, command, username, host, port=int(port),
                    keys=keys, password=password, ui=None,
                    knownHosts=PermissiveKnownHosts())

    factory = Factory()
    factory.protocol = LineProtocol
    factory.sdata = sdata

    d = endpoint.connect(factory)

    # Very small race condition between here and the replacement
    # in connectionMade() above, but I've never managed to hit it.
    def disconnect():
        sdata.log('Disconnecting while still attempting to connect, by request')
        d.cancel()
    sdata.transport_drop_cb = disconnect

    d.addErrback(lambda reason: push_failure_message(reason, sdata))
    return d
開發者ID:cisco,項目名稱:xr-telemetry-m2m-web,代碼行數:35,代碼來源:ssh.py

示例6: execute

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def execute(self):
        """Execute the CLI command"""

        cmd = " ".join(self.cmd)
        LOGGER.debug('Executing {0}'.format(cmd))
        endpoint = SSHCommandClientEndpoint.newConnection(reactor,
            b"{0}".format(cmd), self.config.get('username'),
            self.config.get('host'),
            port=self.config.get('port', 22),
            password=self.config.get('passsword'),
            agentEndpoint=self.agent_endpoint,
            keys=self.keys,
            knownHosts=self.known_hosts)
        factory = protocol.Factory()
        factory.protocol = AsteriskRemoteProtocol

        def _nominal(param):
            self.exitcode = 0
            self.output = param.output
            self.err = self.output
            LOGGER.debug('Remote Asterisk process completed successfully')
            return self

        def _error(param):
            self.exitcode = -1
            self.output = param.value.output
            self.err = self.output
            LOGGER.warning('Remote Asterisk process failed: {0}'.format(self.err))
            return Failure(self)

        deferred = endpoint.connect(factory)
        deferred.addCallback(lambda proto: proto.finished)
        deferred.addCallbacks(_nominal, _error)
        return deferred
開發者ID:colinsung,項目名稱:testsuite,代碼行數:36,代碼來源:asterisk.py

示例7: test_passwordAuthenticationFailure

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def test_passwordAuthenticationFailure(self):
        """
        If the SSH server rejects the password presented during authentication,
        the L{Deferred} returned by L{SSHCommandClientEndpoint.connect} fires
        with a L{Failure} wrapping L{AuthenticationFailed}.
        """
        endpoint = SSHCommandClientEndpoint.newConnection(
            self.reactor, b"/bin/ls -l", b"dummy user",
            self.hostname, self.port,  password=b"dummy password",
            knownHosts=self.knownHosts, ui=FixedResponseUI(False))

        factory = Factory()
        factory.protocol = Protocol
        connected = endpoint.connect(factory)

        server, client, pump = self.connectedServerAndClient(
            self.factory, self.reactor.tcpClients[0][2])

        # For security, the server delays password authentication failure
        # response.  Advance the simulation clock so the client sees the
        # failure.
        self.reactor.advance(server.service.passwordDelay)

        # Let the failure response traverse the "network"
        pump.flush()

        f = self.failureResultOf(connected)
        f.trap(AuthenticationFailed)
        # XXX Should assert something specific about the arguments of the
        # exception

        self.assertClientTransportState(client, False)
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:34,代碼來源:test_endpoints.py

示例8: test_publicKeyAuthenticationFailure

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def test_publicKeyAuthenticationFailure(self):
        """
        If the SSH server rejects the key pair presented during authentication,
        the L{Deferred} returned by L{SSHCommandClientEndpoint.connect} fires
        with a L{Failure} wrapping L{AuthenticationFailed}.
        """
        badKey = Key.fromString(privateRSA_openssh)
        self.setupKeyChecker(self.portal, {self.user: privateDSA_openssh})

        endpoint = SSHCommandClientEndpoint.newConnection(
            self.reactor, b"/bin/ls -l", self.user,
            self.hostname, self.port, keys=[badKey],
            knownHosts=self.knownHosts, ui=FixedResponseUI(False))

        factory = Factory()
        factory.protocol = Protocol
        connected = endpoint.connect(factory)

        server, client, pump = self.connectedServerAndClient(
            self.factory, self.reactor.tcpClients[0][2])

        f = self.failureResultOf(connected)
        f.trap(AuthenticationFailed)
        # XXX Should assert something specific about the arguments of the
        # exception

        # Nothing useful can be done with the connection at this point, so the
        # endpoint should close it.
        self.assertTrue(client.transport.disconnecting)
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:31,代碼來源:test_endpoints.py

示例9: test_interface

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def test_interface(self):
     """
     L{SSHCommandClientEndpoint} instances provide L{IStreamClientEndpoint}.
     """
     endpoint = SSHCommandClientEndpoint.newConnection(
         self.reactor, b"dummy command", b"dummy user",
         self.hostname, self.port)
     self.assertTrue(verifyObject(IStreamClientEndpoint, endpoint))
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:10,代碼來源:test_endpoints.py

示例10: create

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def create(self):
     """
     Create and return a new L{SSHCommandClientEndpoint} using the
     C{newConnection} constructor.
     """
     return SSHCommandClientEndpoint.newConnection(
         self.reactor, b"/bin/ls -l", self.user, self.hostname, self.port,
         password=self.password, knownHosts=self.knownHosts,
         ui=FixedResponseUI(False))
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:11,代碼來源:test_endpoints.py

示例11: _endpoint_for_command

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def _endpoint_for_command(self, command):
     return SSHCommandClientEndpoint.newConnection(
         self.reactor, command, self.username, self.host,
         port=self.port,
         password=self.password,
         keys=self.keys,
         agentEndpoint=self.agent,
         knownHosts=self.knownHosts,
         ui=self.ui
     )
開發者ID:gcgirish-radisys,項目名稱:voltha,代碼行數:12,代碼來源:rcmd.py

示例12: connectionMade

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def connectionMade(self):
     script_dir = os.getcwd()
     rel_path = "hostkeys"
     abs_file_path = os.path.join(script_dir, rel_path)
     knownHosts = KnownHostsFile.fromPath(abs_file_path)
     self.point = SSHCommandClientEndpoint.newConnection(reactor, 'cmd', 'user', '127.0.0.1', port=5122,
                                                         password='password', knownHosts=PermissiveKnownHosts())
     self.sshSide = FzSSHClient()
     self.sshSide.tcpSide = self
     connectProtocol(self.point, self.sshSide)
開發者ID:matanmaz,項目名稱:SshTelnetProxy,代碼行數:12,代碼來源:TcpSshConverter.py

示例13: _connect

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def _connect(self, params):
     ep = SSHCommandClientEndpoint.newConnection(
             reactor,
             b'/bin/cat',
             params['username'],
             params['hostname'],
             port=params['port'],
             password=params['password'],
             agentEndpoint=None,
             knownHosts=EveryoneIsAKnownHostsFile())
     factory = Factory()
     factory.protocol = _PersistentProtocol
     return ep.connect(factory).addCallback(self._connected)
開發者ID:moldit,項目名稱:mold,代碼行數:15,代碼來源:ssh.py

示例14: _connect

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
 def _connect(self, host, port, user, password, private_key_file):
     keys = [Key.fromFile(private_key_file)]
     ep = SSHCommandClientEndpoint.newConnection(
             reactor,
             b'/bin/cat',
             user,
             host,
             port=port,
             password=password,
             keys=keys,
             agentEndpoint=None,
             knownHosts=EveryoneIsAKnownHostsFile())
     factory = Factory()
     factory.protocol = _PersistentProtocol
     return ep.connect(factory).addCallback(self._connected)
開發者ID:iffy,項目名稱:ansible,代碼行數:17,代碼來源:tx.py

示例15: test_connectionCancelledBeforeConnected

# 需要導入模塊: from twisted.conch.endpoints import SSHCommandClientEndpoint [as 別名]
# 或者: from twisted.conch.endpoints.SSHCommandClientEndpoint import newConnection [as 別名]
    def test_connectionCancelledBeforeConnected(self):
        """
        If the connection is cancelled before it finishes connecting, the
        connection attempt is stopped.
        """
        endpoint = SSHCommandClientEndpoint.newConnection(
            self.reactor, b"/bin/ls -l", b"dummy user",
            self.hostname, self.port, knownHosts=self.knownHosts,
            ui=FixedResponseUI(False))

        factory = Factory()
        factory.protocol = Protocol
        d = endpoint.connect(factory)
        d.cancel()
        self.failureResultOf(d).trap(ConnectingCancelledError)
        self.assertTrue(self.reactor.connectors[0].stoppedConnecting)
開發者ID:AlexanderHerlan,項目名稱:syncpy,代碼行數:18,代碼來源:test_endpoints.py


注:本文中的twisted.conch.endpoints.SSHCommandClientEndpoint.newConnection方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。