Moduły Python App Engine i usługa kanału

Korzystam z modułów App Engine w moim projekcie Pythona. (https://developers.google.com/appengine/docs/python/modules/#Python_Background_threads)

Używam również kanałów w projekcie m:https://developers.google.com/appengine/docs/python/channel/

Chcę kierować połączone / rozłączone wiadomości („/ _ah / channel / connected /”, „/ _ah / channel / disconnected /”) do mojego modułu interfejsu API. W tej chwili nie mogę ich zmusić do pokazania się w żadnym module (domyślnym lub api)

app.yaml

    api_version: 1
    application: integrate
    version: 1-0-0
    runtime: python27
    threadsafe: true

    builtins:
      - deferred: on

    libraries:
      - name: pycrypto
      version: "2.6"

    handlers:
      - url: /favicon\.ico
      static_files: static/favicon.ico
      upload: static/favicon\.ico

      - url: /admin/.+
      script: src.default.main.app
      login: admin

      - url: /.*
      script: src.default.main.app

api.yaml

    api_version: 1
    application: integrate
    module: api
    version: 1-0-0
    runtime: python27
    threadsafe: true

    inbound_services:
      - channel_presence

    builtins:
      - deferred: on

    libraries:
      - name: pycrypto
      version: "2.6"

    handlers:
      - url: /admin/.+
      script: src.api.main.app
      login: admin

      - url: /.*
      script: src.api.main.app

dispatch.yaml

    application: integrate

    dispatch:
       - url: "*/_ah/channel/*"
       module: api

Uwaga: Aby było jasne, wszystko działa lokalnie w trybie dev.

api.main.app

    app = webapp2.WSGIApplication(debug=True)
    _routes = [
        :
        ChannelDisconnectedHandler.mapping(),
        ChannelConnectHandler.mapping()
    ]

    for r in self._routes:
        app.router.add(r)

ChannelDisconnectHandler

    CHANNEL_DISCONNECTED_URL_PATTERN = '/_ah/channel/disconnected/'


    class ChannelDisconnectedHandler(RequestHandler):

        @classmethod
        def mapping(cls):
            return CHANNEL_DISCONNECTED_URL_PATTERN, cls

        def post(self):
            """
            Channel Presence handler. Will be called when a client disconnects.
            """
            channel_id = self.request.get('from')
            logging.info("Channel Disconnect. Id: %s" % channel_id)

ChannelConnectHandler

    CHANNEL_CONNECT_URL_PATTERN = '/_ah/channel/connected/'

    class ChannelConnectHandler(RequestHandler):

        @classmethod
        def mapping(cls):
            return CHANNEL_CONNECT_URL_PATTERN, cls

        def post(self):
            """
            Channel Presence handler. Will be called when a client connects.
            """
            channel_id = self.request.get('from')
            logging.info("Channel Connect. Id: %s" % channel_id)

Więc mój klient (napisany w javascript) pisze do mojego modułu API i otwiera kanał.

    var open_channel = function(tokenResponse) {
        console.log("Open Channel. token Response: " + tokenResponse)
        token = tokenResponse.token;
        var channel = new goog.appengine.Channel(token);
        if (socket != null) {
            socket.close();
        }
        socket = channel.open();
        socket.onopen = onOpened;
        socket.onmessage = onMessage;
        socket.onerror = onError;
        socket.onclose = onClose;
    };

    onOpened = function() {
        console.info("Channel API Connection is open.");
    };

    onError = function(e) {
        console.info("CHANNEL Error. Code: " + e.code + ", Description: " + e.description);
    };

    onClose = function() {
        console.info("Close Channel");
    };

    onMessage = function(msg) {
       console.info("Message Received: " + msg + ", Data: " + msg.data);
    };

Ta funkcja zwrotna jest osiągnięta przy użyciu ważnego tokena. Tworzę gniazdo pomyślnie i wykonuję tę funkcję zgodnie z oczekiwaniami. W moim systemie lokalnym wywoływana jest funkcja onOpened i odbieram wiadomości z serwera. W produkcji na otworzone nigdy nie jest wywoływany i nigdy nie otrzymuję żadnych wiadomości. / _Ah / channel / connected / jest również nigdy nie wywoływany.

Czy usługa Channel nie jest obsługiwana przez moduły? Jakieś myśli co do tego, czego brakuje?

questionAnswers(3)

yourAnswerToTheQuestion