# limitations under the License.
# ==================================================================================
import json
-from ricxappframe.xapp_frame import RMRXapp
+from ricxappframe.xapp_frame import RMRXapp, rmr
-# Note, this is an OOP pattern for this that I find slightly more natural
-# The problem is we want the client xapp to be able to call methods defined in the RMRXapp
-# Another exactly equivelent way would have been to use Closures like
-# def consume(summary, sbuf):
-# xapp.rts()
-# xapp = RMRXapp(consume)
-# However, the subclass looks slightly more natural. Open to the alternative.
+def post_init(_self):
+ """post init"""
+ print("pong xapp could do some useful stuff here!")
-class MyXapp(RMRXapp):
- def consume(self, summary, sbuf):
- """callbnack called for each new message"""
- print(summary)
- jpay = json.loads(summary["payload"])
- self.rmr_rts(sbuf, new_payload=json.dumps({"ACK": jpay["test_send"]}).encode(), new_mtype=60001, retries=100)
- self.rmr_free(sbuf)
+def sixtyh(self, summary, sbuf):
+ """callback for 60000"""
+ self.logger.info("pong registered 60000 handler called!")
+ # see comment in ping about this; bytes does not work with the ric mdc logger currently
+ print("pong 60000 handler received: {0}".format(summary))
+ jpay = json.loads(summary[rmr.RMR_MS_PAYLOAD])
+ self.rmr_rts(sbuf, new_payload=json.dumps({"ACK": jpay["test_send"]}).encode(), new_mtype=60001, retries=100)
+ self.rmr_free(sbuf)
-xapp = MyXapp(use_fake_sdl=True)
-xapp.run()
+def defh(self, summary, sbuf):
+ """default callback"""
+ self.logger.info("pong default handler called!")
+ print("pong default handler received: {0}".format(summary))
+ self.rmr_free(sbuf)
+
+
+xapp = RMRXapp(default_handler=defh, post_init=post_init, use_fake_sdl=True)
+xapp.register_callback(sixtyh, 60000)
+xapp.run() # will not thread by default