aboutsummaryrefslogtreecommitdiffstats
path: root/python/examples/dev-console.py
diff options
context:
space:
mode:
authorDevendra2014-04-17 00:28:05 +0530
committerDevendra2014-04-17 00:28:05 +0530
commit9dc2555746adf717da0db808f4096af2167a1580 (patch)
tree71b9f309cc123313309dc9d7bbf500822e5c99f1 /python/examples/dev-console.py
parent150ae1566d813acbb773839e919db2c0f467931c (diff)
downloadpubnub-python-9dc2555746adf717da0db808f4096af2167a1580.tar.bz2
adding ver 1 of dev console
Diffstat (limited to 'python/examples/dev-console.py')
-rwxr-xr-xpython/examples/dev-console.py182
1 files changed, 182 insertions, 0 deletions
diff --git a/python/examples/dev-console.py b/python/examples/dev-console.py
new file mode 100755
index 0000000..372599a
--- /dev/null
+++ b/python/examples/dev-console.py
@@ -0,0 +1,182 @@
+## www.pubnub.com - PubNub Real-time push service in the cloud.
+# coding=utf8
+
+## PubNub Real-time Push APIs and Notifications Framework
+## Copyright (c) 2010 Stephen Blum
+## http://www.pubnub.com/
+
+## -----------------------------------
+## PubNub 3.1 Real-time Push Cloud API
+## -----------------------------------
+
+import sys
+from twisted.internet import reactor
+sys.path.append('../')
+sys.path.append('../../')
+from Pubnub import Pubnub
+
+from optparse import OptionParser
+
+
+parser = OptionParser()
+
+parser.add_option("--publish-key",
+ dest="publish_key", default="demo",
+ help="Publish Key ( default : 'demo' )")
+
+parser.add_option("--subscribe-key",
+ dest="subscribe_key", default="demo",
+ help="Subscribe Key ( default : 'demo' )")
+
+parser.add_option("--secret-key",
+ dest="secret_key", default="demo",
+ help="Secret Key ( default : 'demo' )")
+
+parser.add_option("--cipher-key",
+ dest="cipher_key", default="",
+ help="Cipher Key")
+
+parser.add_option("--auth-key",
+ dest="auth_key", default=None,
+ help="Auth Key")
+
+parser.add_option("--origin",
+ dest="origin", default="pubsub.pubnub.com",
+ help="Origin ( default: pubsub.pubnub.com )")
+
+parser.add_option("--ssl-on",
+ action="store_false", dest="ssl", default=False,
+ help="SSL")
+
+(options, args) = parser.parse_args()
+
+print options
+
+pubnub = Pubnub(options.publish_key, options.subscribe_key, options.secret_key, options.cipher_key, options.auth_key, options.ssl)
+
+
+class color:
+ PURPLE = '\033[95m'
+ CYAN = '\033[96m'
+ DARKCYAN = '\033[36m'
+ BLUE = '\033[94m'
+ GREEN = '\033[92m'
+ YELLOW = '\033[93m'
+ RED = '\033[91m'
+ BOLD = '\033[1m'
+ UNDERLINE = '\033[4m'
+ END = '\033[0m'
+
+
+def print_ok(msg):
+ print(color.GREEN + str(msg) + color.END)
+
+def print_error(msg):
+ print(color.RED + color.BOLD + str(msg) + color.END)
+
+def get_input(message, t=None):
+ while True:
+ try:
+ command = raw_input(message)
+ if t is not None:
+ command = t(command)
+ else:
+ command = eval("'" + command + "'")
+ return command
+ except ValueError:
+ print_error("Invalid input : " + command)
+
+
+
+def _publish_command_handler():
+
+ channel = get_input("[PUBLISH] Enter Channel Name ", str)
+ while True:
+ message = get_input("[PUBLISH] Enter Message ( QUIT for exit from publish mode ) ")
+ if message == 'QUIT' or message == 'quit':
+ return
+ def _callback(r):
+ print_ok(r)
+ def _error(r):
+ print_error(r)
+ pubnub.publish({
+ 'channel' : channel,
+ 'message' : message,
+ 'callback' : _callback,
+ 'error' : _error
+ })
+
+
+def _subscribe_command_handler():
+ channel = get_input("[SUBSCRIBE] Enter Channel Name ", str)
+ def _callback(r):
+ print_ok(r)
+ def _error(r):
+ print_error(r)
+ pubnub.subscribe({
+ 'channel' : channel,
+ 'callback' : _callback,
+ 'error' : _error
+ })
+
+def _grant_command_handler():
+ pass
+
+def _revoke_command_handler():
+ pass
+
+def _audit_command_handler():
+ pass
+
+def _history_command_handler():
+ pass
+
+def _here_now_command_handler():
+ pass
+
+
+
+import threading
+
+def kill_all_threads():
+ for thread in threading.enumerate():
+ if thread.isAlive():
+ try:
+ thread._Thread__stop()
+ except:
+ print(str(thread.getName()) + ' could not be terminated')
+
+
+commands = []
+commands.append({"command" : "publish", "handler" : _publish_command_handler})
+commands.append({"command" : "subscribe", "handler" : _subscribe_command_handler})
+'''
+commands.append({"command" : "here_now", "handler" : _here_now_command_handler})
+commands.append({"command" : "history", "handler" : _history_command_handler})
+commands.append({"command" : "grant", "handler" : _grant_command_handler})
+commands.append({"command" : "revoke", "handler" : _revoke_command_handler})
+commands.append({"command" : "audit", "handler" : _audit_command_handler})
+'''
+# last command is quit. add new commands before this line
+commands.append({"command" : "QUIT"})
+
+def get_help():
+ help = ""
+ for i,v in enumerate(commands):
+ help += "Enter " + str(i) + " for " + v['command'] + "\n"
+ return help
+
+
+while True:
+ command = get_input(color.BLUE + get_help(), int)
+
+ if command == len(commands) - 1:
+ kill_all_threads()
+ break
+ if command >= len(commands):
+ print_error("Invalid input " + str(command))
+ continue
+
+ commands[command]['handler']()
+
+#pubnub.start()