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


Python layers.get_channel_layer方法代碼示例

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


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

示例1: test_saves_reply_channel

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def test_saves_reply_channel(self):
        async with Communicator() as communicator:
            user = await AsyncUserFactory()
            communicator.scope['user'] = user
            await communicator.connect()
            subscription = (await get_subscription(user=user))[0]
            assert subscription.reply_channel is not None
            await get_channel_layer().send(
                subscription.reply_channel, {
                    'type': 'message.send',
                    'text': json.dumps({
                        'message': 'hey! whaatsup?',
                    }),
                }
            )
            response = await communicator.receive_json_from()
            assert response == {'message': 'hey! whaatsup?'} 
開發者ID:yunity,項目名稱:karrot-backend,代碼行數:19,代碼來源:test_consumers.py

示例2: taillog

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def taillog(request, hostname, port, username, password, private, tail):
    """
    執行 tail log 接口
    """
    channel_layer = get_channel_layer()
    user = request.user.username
    os.environ["".format(user)] = "true"
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    if password:
        ssh.connect(hostname=hostname, port=port, username=username, password=decrypt_p(password))
    else:
        pkey = paramiko.RSAKey.from_private_key_file("{0}".format(private))
        ssh.connect(hostname=hostname, port=port, username=username, pkey=pkey)
    cmd = "tail " + tail
    stdin, stdout, stderr = ssh.exec_command(cmd, get_pty=True)
    for line in iter(stdout.readline, ""):
        if os.environ.get("".format(user)) == 'false':
            break
        result = {"status": 0, 'data': line}
        result_all = json.dumps(result)
        async_to_sync(channel_layer.group_send)(user, {"type": "user.message", 'text': result_all}) 
開發者ID:hequan2017,項目名稱:chain,代碼行數:24,代碼來源:views.py

示例3: push_update

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def push_update(task_id):
        if WEBSOCKETS_AVAILABLE:
            try:
                channel_layer = get_channel_layer()
                async_to_sync(channel_layer.group_send)(
                    task_id,
                    {'type': 'update_task_progress', 'data': {**Progress(task_id).get_info()}}
                )
            except AttributeError:  # No channel layer to send to, so ignore it
                pass
        else:
            logger.info(
                'Tried to use websocket progress bar, but dependencies were not installed / configured. '
                'Use pip install celery-progress[websockets] and setup channels to enable this feature.'
                'See: https://channels.readthedocs.io/en/latest/ for more details.'
            ) 
開發者ID:czue,項目名稱:celery-progress,代碼行數:18,代碼來源:backend.py

示例4: _send_to_users

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def _send_to_users(self, qs_users: QuerySet, message_obj: ChannelMessage):
        """
        Send the message to the users returned by the specified Django query set.

        This is an async method made private for calling it from the sync public method.
        :param qs_users: Django query set returning User models. Pk field will be requested via values_list(..).
        :param message_obj: Message to send.
        :return:
        """
        connected_user_ids = self.get_connected_users()
        if not connected_user_ids:
            return

        # A workaround for "connection already closed" problem.
        # Looks like this code is being executed in a way that
        # the "connection" object it accesses is re-used for a long time and appears broken after some long delay.
        connection.close()

        layer = get_channel_layer()  # type: RedisChannelLayer
        msg = {'type': 'send_to_client', 'message': message_obj.to_dict()}
        coros = list()
        for user_id in qs_users.filter(pk__in=connected_user_ids).values_list('pk', flat=True):
            send_to_user_coro = layer.group_send(self.user_id_to_group_name(user_id), msg)
            coros.append(send_to_user_coro)
        await asyncio.gather(*coros) 
開發者ID:LexPredict,項目名稱:lexpredict-contraxsuite,代碼行數:27,代碼來源:websockets.py

示例5: test_poll_observer

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def test_poll_observer():
    main = ApplicationCommunicator(
        MainConsumer, {'type': 'channel', 'channel': CHANNEL_MAIN}
    )
    await main.send_input({'type': TYPE_POLL, 'observer': 'test', 'interval': 2})
    channel_layer = get_channel_layer()

    # Nothing should be received in the first second.
    with pytest.raises(asyncio.TimeoutError):
        async with async_timeout.timeout(1):
            await channel_layer.receive(CHANNEL_WORKER)
            assert False

    # Then after another second we should get a notification.
    async with async_timeout.timeout(2):
        notify = await channel_layer.receive(CHANNEL_WORKER)
        assert notify['type'] == TYPE_EVALUATE
        assert notify['observer'] == 'test' 
開發者ID:genialis,項目名稱:django-rest-framework-reactive,代碼行數:20,代碼來源:test_consumers.py

示例6: send_state_event

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def send_state_event(state: Dict[str, Any]) -> None:
    """Sends the given dictionary as a state update to all connected clients."""
    data = {
        "type": "state_update",
        "state": state,
    }
    channel_layer = get_channel_layer()
    async_to_sync(channel_layer.group_send)("state", data) 
開發者ID:raveberry,項目名稱:raveberry,代碼行數:10,代碼來源:state_handler.py

示例7: send_event

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def send_event(message):
    """Construct a Channels event packet with the given message.

    :param message: The message to send to the manager workers.
    """
    packet = {
        "type": "control_event",  # This is used as the method name in the consumer.
        "content": message,
    }
    await get_channel_layer().send(state.MANAGER_CONTROL_CHANNEL, packet) 
開發者ID:genialis,項目名稱:resolwe,代碼行數:12,代碼來源:consumer.py

示例8: run_consumer

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def run_consumer(timeout=None, dry_run=False):
    """Run the consumer until it finishes processing.

    :param timeout: Set maximum execution time before cancellation, or
        ``None`` (default) for unlimited.
    :param dry_run: If ``True``, don't actually dispatch messages, just
        dequeue them. Defaults to ``False``.
    """
    channel = state.MANAGER_CONTROL_CHANNEL
    scope = {
        "type": "control_event",
        "channel": channel,
    }

    app = ApplicationCommunicator(ManagerConsumer, scope)

    channel_layer = get_channel_layer()

    async def _consume_loop():
        """Run a loop to consume messages off the channels layer."""
        while True:
            message = await channel_layer.receive(channel)
            if dry_run:
                continue
            if message.get("type", {}) == "_resolwe_manager_quit":
                break
            message.update(scope)
            await app.send_input(message)

    if timeout is None:
        await _consume_loop()
    try:
        # A further grace period to catch late messages.
        async with async_timeout.timeout(timeout or 1):
            await _consume_loop()
    except asyncio.TimeoutError:
        pass

    await app.wait()
    # Shouldn't flush channels here in case there are more processes
    # using the same Redis, since flushing is global. 
開發者ID:genialis,項目名稱:resolwe,代碼行數:43,代碼來源:consumer.py

示例9: exit_consumer

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def exit_consumer():
    """Cause the synchronous consumer to exit cleanly."""
    packet = {
        "type": "_resolwe_manager_quit",
    }
    await get_channel_layer().send(state.MANAGER_CONTROL_CHANNEL, packet) 
開發者ID:genialis,項目名稱:resolwe,代碼行數:8,代碼來源:consumer.py

示例10: data_post_delete_handler

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def data_post_delete_handler(sender, instance: Data, using, **kwargs):
    """Remove files referenced by deleted object."""
    channel_layer = get_channel_layer()
    channel_data = {"type": TYPE_STORAGE_CLEANUP_RUN}
    try:
        if instance.location_id is not None:
            channel_data["file_storage_id"] = instance.location_id
        async_to_sync(channel_layer.send)(CHANNEL_STORAGE_CLEANUP_WORKER, channel_data)
    except ChannelFull:
        logger.warning("Cannot trigger storage manager run because channel is full.",) 
開發者ID:genialis,項目名稱:resolwe,代碼行數:12,代碼來源:signals.py

示例11: handle

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def handle(self, *args, **options):
        """Command handle."""
        channel_layer = get_channel_layer()
        try:
            async_to_sync(channel_layer.send)(
                CHANNEL_STORAGE_MANAGER_WORKER, {"type": TYPE_STORAGE_MANAGER_RUN,},
            )
        except ChannelFull:
            logger.warning(
                "Cannot trigger storage manager run because channel is full.",
            ) 
開發者ID:genialis,項目名稱:resolwe,代碼行數:13,代碼來源:runstoragemanager.py

示例12: push

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def push(username, event):
    channel_layer = get_channel_layer()
    async_to_sync(channel_layer.group_send)(
        username,
        {
            "type": "push.message",
            "event": event
        }
    ) 
開發者ID:michwh,項目名稱:onehome-server,代碼行數:11,代碼來源:consumers.py

示例13: notify_ws_clients

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def notify_ws_clients(self):
        """
        Inform client there is a new message.
        """
        notification = {
            'type': 'recieve_group_message',
            'message': '{}'.format(self.id)
        }

        channel_layer = get_channel_layer()
        print("user.id {}".format(self.user.id))
        print("user.id {}".format(self.recipient.id))

        async_to_sync(channel_layer.group_send)("{}".format(self.user.id), notification)
        async_to_sync(channel_layer.group_send)("{}".format(self.recipient.id), notification) 
開發者ID:narrowfail,項目名稱:django-channels-chat,代碼行數:17,代碼來源:models.py

示例14: handle

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def handle(self, signal, *args, **kwargs):
        message = self.serialize(signal, *args, **kwargs)
        channel_layer = get_channel_layer()
        for group_name in self.group_names_for_signal(*args, message=message, **kwargs):
            async_to_sync(channel_layer.group_send)(group_name, message) 
開發者ID:hishnash,項目名稱:djangochannelsrestframework,代碼行數:7,代碼來源:observer.py

示例15: send_messages

# 需要導入模塊: from channels import layers [as 別名]
# 或者: from channels.layers import get_channel_layer [as 別名]
def send_messages(
        self, instance: Model, group_names: Set[str], action: Action, **kwargs
    ):
        if not group_names:
            return
        message = self.serialize(instance, action, **kwargs)
        channel_layer = get_channel_layer()
        for group_name in group_names:
            async_to_sync(channel_layer.group_send)(group_name, message) 
開發者ID:hishnash,項目名稱:djangochannelsrestframework,代碼行數:11,代碼來源:model_observer.py


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