示例#1
0
文件: frontend.py 项目: qsdj/grr
    def __init__(self,
                 server_address,
                 handler,
                 frontend=None,
                 *args,
                 **kwargs):
        stats.STATS.SetGaugeValue("frontend_max_active_count",
                                  self.request_queue_size)

        if frontend:
            self.frontend = frontend
        else:
            self.frontend = frontend_lib.FrontEndServer(
                certificate=config.CONFIG["Frontend.certificate"],
                private_key=config.CONFIG["PrivateKeys.server_key"],
                max_queue_size=config.CONFIG["Frontend.max_queue_size"],
                message_expiry_time=config.
                CONFIG["Frontend.message_expiry_time"],
                max_retransmission_time=config.
                CONFIG["Frontend.max_retransmission_time"])
        self.server_cert = config.CONFIG["Frontend.certificate"]

        (address, _) = server_address
        version = ipaddr.IPAddress(address).version
        if version == 4:
            self.address_family = socket.AF_INET
        elif version == 6:
            self.address_family = socket.AF_INET6

        logging.info("Will attempt to listen on %s", server_address)
        BaseHTTPServer.HTTPServer.__init__(self, server_address, handler,
                                           *args, **kwargs)
示例#2
0
 def __init__(self):
     self.frontend = frontend_lib.FrontEndServer(
         certificate=config.CONFIG["Frontend.certificate"],
         private_key=config.CONFIG["PrivateKeys.server_key"],
         max_queue_size=config.CONFIG["Frontend.max_queue_size"],
         message_expiry_time=config.CONFIG["Frontend.message_expiry_time"],
         max_retransmission_time=config.
         CONFIG["Frontend.max_retransmission_time"])
示例#3
0
    def testEqualTimestampNotifications(self):
        frontend_server = frontend_lib.FrontEndServer(
            certificate=config.CONFIG["Frontend.certificate"],
            private_key=config.CONFIG["PrivateKeys.server_key"],
            message_expiry_time=100,
            threadpool_prefix="notification-test")

        # This schedules 10 requests.
        session_id = flow.GRRFlow.StartFlow(client_id=self.client_id,
                                            flow_name="WorkerSendingTestFlow",
                                            token=self.token)

        # We pretend that the client processed all the 10 requests at once and
        # sends the replies in a single http poll.
        messages = [
            rdf_flows.GrrMessage(
                request_id=i,
                response_id=1,
                session_id=session_id,
                payload=rdf_protodict.DataBlob(string="test%s" % i),
                auth_state="AUTHENTICATED",
                generate_task_id=True) for i in range(1, 11)
        ]
        status = rdf_flows.GrrStatus(
            status=rdf_flows.GrrStatus.ReturnedStatus.OK)
        statuses = [
            rdf_flows.GrrMessage(request_id=i,
                                 response_id=2,
                                 session_id=session_id,
                                 payload=status,
                                 type=rdf_flows.GrrMessage.Type.STATUS,
                                 auth_state="AUTHENTICATED",
                                 generate_task_id=True) for i in range(1, 11)
        ]

        frontend_server.ReceiveMessages(self.client_id, messages + statuses)

        with queue_manager.QueueManager(token=self.token) as q:
            all_notifications = q.GetNotificationsByPriorityForAllShards(
                rdfvalue.RDFURN("aff4:/F"))
            medium_priority = rdf_flows.GrrNotification.Priority.MEDIUM_PRIORITY
            medium_notifications = all_notifications[medium_priority]
            my_notifications = [
                n for n in medium_notifications if n.session_id == session_id
            ]
            # There must not be more than one notification.
            self.assertEqual(len(my_notifications), 1)
            notification = my_notifications[0]
            self.assertEqual(notification.first_queued, notification.timestamp)
            self.assertEqual(notification.last_status, 10)
示例#4
0
 def InitTestServer(self):
     self.server = frontend_lib.FrontEndServer(
         certificate=config.CONFIG["Frontend.certificate"],
         private_key=config.CONFIG["PrivateKeys.server_key"],
         message_expiry_time=self.MESSAGE_EXPIRY_TIME,
         threadpool_prefix="pool-%s" % self._testMethodName)