transpub/transwhat.py

75 lines
2.1 KiB
Python
Raw Normal View History

2013-06-28 21:10:28 +00:00
#!/usr/bin/python
2013-08-01 23:45:51 +00:00
__author__ = "Steffen Vogel"
__copyright__ = "Copyright 2013, Steffen Vogel"
__license__ = "GPLv3"
__maintainer__ = "Steffen Vogel"
__email__ = "post@steffenvogel.de"
__status__ = "Prototype"
"""
This file is part of transWhat
transWhat 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
any later version.
transwhat 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 transWhat. If not, see <http://www.gnu.org/licenses/>.
"""
2013-06-28 21:10:28 +00:00
import argparse
import logging
import asyncore
import sys, os
import MySQLdb
import e4u
import threading
sys.path.insert(0, os.getcwd())
from Spectrum2.iochannel import IOChannel
from whatsappbackend import WhatsAppBackend
from constants import *
2015-06-21 12:01:05 +00:00
from yowsup.common import YowConstants
2013-06-28 21:10:28 +00:00
# Arguments
parser = argparse.ArgumentParser()
parser.add_argument('--debug', action='store_true')
parser.add_argument('--host', type=str, required=True)
parser.add_argument('--port', type=int, required=True)
parser.add_argument('--service.backend_id', metavar="ID", type=int, required=True)
parser.add_argument('config', type=str)
2015-06-21 12:01:05 +00:00
parser.add_argument('-j', type=str, required=True)
2013-06-28 21:10:28 +00:00
args, unknown = parser.parse_known_args()
YowConstants.PATH_STORAGE='/var/lib/spectrum2/' + args.j
2013-06-28 21:10:28 +00:00
# Logging
logging.basicConfig( \
2015-06-21 19:11:23 +00:00
filename='/var/log/spectrum2/' + args.j + '/backends/backend.log',\
2013-06-28 21:10:28 +00:00
format = "%(asctime)-15s %(levelname)s %(name)s: %(message)s", \
level = logging.DEBUG if args.debug else logging.INFO \
)
# Handler
def handleTransportData(data):
plugin.handleDataRead(data)
e4u.load()
# Main
db = MySQLdb.connect(DB_HOST, DB_USER, DB_PASS, DB_TABLE)
io = IOChannel(args.host, args.port, handleTransportData)
plugin = WhatsAppBackend(io, db)
asyncore.loop(1)