def load(self, username): """ :param username: :type username: :return: :rtype: """ config_dir = StorageTools.getStorageForPhone(username) logger.debug("Detecting config for username=%s, dir=%s" % (username, config_dir)) exhausted = [] for ftype in self.MAP_EXT: if len(ftype): fname = (self.NAME_FILE_CONFIG + "." + ftype) else: fname = self.NAME_FILE_CONFIG fpath = os.path.join(config_dir, fname) logger.debug("Trying %s" % fpath) if os.path.isfile(fpath): return self.load_path(fpath) exhausted.append(fpath) logger.error( "Could not find a config for username=%s, paths checked: %s" % (username, ":".join(exhausted)))
def save_as(media, filename): """ Save binary data `media` as `filename`. Return saved path if successful. Otherwise, print error and return `None`. """ try: layer = self.getLayerInterface(YowAuthenticationProtocolLayer) username = layer.getUsername(False) path = StorageTools.getStorageForPhone(username) + filename with open(path, 'wb') as f: f.write(media) return path except Exception as e: logger.error("Save Error:%s", e) return None
def load(self, username): """ :param username: :type username: :return: :rtype: """ config_dir = StorageTools.getStorageForPhone(username) logger.debug("Detecting config for username=%s, dir=%s" % (username, config_dir)) exhausted = [] for ftype in self.MAP_EXT: if len(ftype): fname = (self.NAME_FILE_CONFIG + "." + ftype) else: fname = self.NAME_FILE_CONFIG fpath = os.path.join(config_dir, fname) logger.debug("Trying %s" % fpath) if os.path.isfile(fpath): return self.load_path(fpath) exhausted.append(fpath) logger.error("Could not find a config for username=%s, paths checked: %s" % (username, ":".join(exhausted)))
from yowsup_ext.layers.cleverbot.layer import YowCleverBotLayer from yowsup_ext.layers.store import YowStorageLayer import sys import logging logging.basicConfig(level=logging.DEBUG) logger = logging.getLogger(__name__) if __name__ == "__main__": if len(sys.argv) < 3: print("Usage: run.py username password") sys.exit(1) credentials = (sys.argv[1], sys.argv[2]) stackBuilder = YowStackBuilder() phoneStorage = StorageTools.getStorageForPhone(credentials[0]) stackBuilder.setProp( YowStorageLayer.PROP_DB_PATH, StorageTools.constructPath(phoneStorage, "yowstore.db")) stack = stackBuilder\ .pushDefaultLayers(True)\ .push(YowStorageLayer)\ .push(YowCleverBotLayer)\ .build() stack.setCredentials(credentials) logger.info("Starting") stack.broadcastEvent(YowLayerEvent(YowNetworkLayer.EVENT_STATE_CONNECT)) try: stack.loop(timeout=0.5, discrete=0.5)
from yowsup_ext.layers.cleverbot.layer import YowCleverBotLayer from yowsup_ext.layers.store import YowStorageLayer import sys import logging logging.basicConfig(level = logging.DEBUG) logger = logging.getLogger(__name__) if __name__ == "__main__": if len(sys.argv) < 3: print("Usage: run.py username password") sys.exit(1) credentials = (sys.argv[1], sys.argv[2]) stackBuilder = YowStackBuilder() phoneStorage = StorageTools.getStorageForPhone(credentials[0]) stackBuilder.setProp(YowStorageLayer.PROP_DB_PATH, StorageTools.constructPath(phoneStorage, "yowstore.db")) stack = stackBuilder\ .pushDefaultLayers(True)\ .push(YowStorageLayer)\ .push(YowCleverBotLayer)\ .build() stack.setCredentials(credentials) logger.info("Starting") stack.broadcastEvent(YowLayerEvent(YowNetworkLayer.EVENT_STATE_CONNECT)) try: stack.loop(timeout = 0.5, discrete = 0.5) except AuthError as e: print("Auth Error, reason %s" % e)