2018-07-11 07:35:22 +00:00
|
|
|
'''
|
2019-06-20 07:59:32 +00:00
|
|
|
Onionr - Private P2P Communication
|
2018-07-11 07:35:22 +00:00
|
|
|
|
|
|
|
This default plugin handles "flow" messages (global chatroom style communication)
|
|
|
|
'''
|
|
|
|
'''
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
'''
|
|
|
|
|
|
|
|
# Imports some useful libraries
|
2019-04-27 15:43:16 +00:00
|
|
|
import threading, time, locale, sys, os
|
2018-07-11 07:35:22 +00:00
|
|
|
from onionrblockapi import Block
|
2019-04-27 15:43:16 +00:00
|
|
|
import logger, config
|
2019-06-25 23:07:35 +00:00
|
|
|
from onionrutils import escapeansi, epoch
|
2019-04-27 15:43:16 +00:00
|
|
|
locale.setlocale(locale.LC_ALL, '')
|
|
|
|
|
|
|
|
sys.path.insert(0, os.path.dirname(os.path.realpath(__file__)))
|
|
|
|
import flowapi # import after path insert
|
|
|
|
flask_blueprint = flowapi.flask_blueprint
|
2018-07-11 07:35:22 +00:00
|
|
|
|
|
|
|
plugin_name = 'flow'
|
2019-04-27 15:43:16 +00:00
|
|
|
PLUGIN_VERSION = '0.0.1'
|
2018-07-11 07:35:22 +00:00
|
|
|
|
|
|
|
class OnionrFlow:
|
|
|
|
def __init__(self):
|
2018-07-12 07:37:10 +00:00
|
|
|
self.myCore = pluginapi.get_core()
|
|
|
|
self.alreadyOutputed = []
|
|
|
|
self.flowRunning = False
|
2018-12-09 17:29:39 +00:00
|
|
|
self.channel = None
|
2018-07-11 07:35:22 +00:00
|
|
|
return
|
|
|
|
|
2018-07-12 07:37:10 +00:00
|
|
|
def start(self):
|
2019-06-19 20:29:27 +00:00
|
|
|
logger.warn("Please note: everything said here is public, even if a random channel name is used.", terminal=True)
|
2018-07-12 07:37:10 +00:00
|
|
|
message = ""
|
|
|
|
self.flowRunning = True
|
2019-06-25 23:07:35 +00:00
|
|
|
newThread = threading.Thread(target=self.showOutput, daemon=True)
|
2018-07-12 07:37:10 +00:00
|
|
|
newThread.start()
|
2018-12-09 17:29:39 +00:00
|
|
|
try:
|
|
|
|
self.channel = logger.readline("Enter a channel name or none for default:")
|
|
|
|
except (KeyboardInterrupt, EOFError) as e:
|
|
|
|
self.flowRunning = False
|
2018-07-12 07:37:10 +00:00
|
|
|
while self.flowRunning:
|
|
|
|
try:
|
|
|
|
message = logger.readline('\nInsert message into flow:').strip().replace('\n', '\\n').replace('\r', '\\r')
|
|
|
|
except EOFError:
|
|
|
|
pass
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
self.flowRunning = False
|
2018-12-09 17:29:39 +00:00
|
|
|
else:
|
|
|
|
if message == "q":
|
|
|
|
self.flowRunning = False
|
2019-06-25 23:07:35 +00:00
|
|
|
expireTime = epoch.get_epoch() + 43200
|
2018-12-09 17:29:39 +00:00
|
|
|
if len(message) > 0:
|
2019-06-22 21:16:12 +00:00
|
|
|
logger.info('Inserting message as block...', terminal=True)
|
2019-02-02 03:49:11 +00:00
|
|
|
self.myCore.insertBlock(message, header='txt', expire=expireTime, meta={'ch': self.channel})
|
2018-07-12 07:37:10 +00:00
|
|
|
|
2019-06-19 20:29:27 +00:00
|
|
|
logger.info("Flow is exiting, goodbye", terminal=True)
|
2018-07-12 07:37:10 +00:00
|
|
|
return
|
|
|
|
|
|
|
|
def showOutput(self):
|
2018-12-09 17:29:39 +00:00
|
|
|
while type(self.channel) is type(None) and self.flowRunning:
|
|
|
|
time.sleep(1)
|
|
|
|
try:
|
|
|
|
while self.flowRunning:
|
2019-04-27 15:43:16 +00:00
|
|
|
for block in self.myCore.getBlocksByType('txt'):
|
|
|
|
block = Block(block)
|
|
|
|
if block.getMetadata('ch') != self.channel:
|
|
|
|
continue
|
|
|
|
if block.getHash() in self.alreadyOutputed:
|
|
|
|
continue
|
|
|
|
if not self.flowRunning:
|
|
|
|
break
|
2019-06-19 20:29:27 +00:00
|
|
|
logger.info('\n------------------------', prompt = False, terminal=True)
|
2019-04-27 15:43:16 +00:00
|
|
|
content = block.getContent()
|
|
|
|
# Escape new lines, remove trailing whitespace, and escape ansi sequences
|
2019-06-25 23:07:35 +00:00
|
|
|
content = escapeansi.escape_ANSI(content.replace('\n', '\\n').replace('\r', '\\r').strip())
|
2019-06-19 20:29:27 +00:00
|
|
|
logger.info(block.getDate().strftime("%m/%d %H:%M") + ' - ' + logger.colors.reset + content, prompt = False, terminal=True)
|
2019-04-27 15:43:16 +00:00
|
|
|
self.alreadyOutputed.append(block.getHash())
|
|
|
|
time.sleep(5)
|
2018-12-09 17:29:39 +00:00
|
|
|
except KeyboardInterrupt:
|
|
|
|
self.flowRunning = False
|
2018-07-11 07:35:22 +00:00
|
|
|
|
|
|
|
def on_init(api, data = None):
|
|
|
|
'''
|
|
|
|
This event is called after Onionr is initialized, but before the command
|
|
|
|
inputted is executed. Could be called when daemon is starting or when
|
|
|
|
just the client is running.
|
|
|
|
'''
|
|
|
|
|
|
|
|
# Doing this makes it so that the other functions can access the api object
|
|
|
|
# by simply referencing the variable `pluginapi`.
|
|
|
|
global pluginapi
|
|
|
|
pluginapi = api
|
2018-07-12 07:37:10 +00:00
|
|
|
flow = OnionrFlow()
|
2018-07-18 04:45:51 +00:00
|
|
|
api.commands.register('flow', flow.start)
|
2018-07-11 07:35:22 +00:00
|
|
|
api.commands.register_help('flow', 'Open the flow messaging interface')
|
2018-07-18 04:45:51 +00:00
|
|
|
return
|