class CustBlink: def __init__(self, blink_location, blink_period): self.blink_location = blink_location self.blink_period = blink_period if not blink_location.is_dir(): blink_location.mkdir() def login_only(self): self.blink = Blink() creds = self.blink_location / "creds.json" started = self.blink.start() if started: self.blink.save(creds) return started def reauth(self): self.blink = Blink() creds = self.blink_location / "creds.json" started = False print("Logging in to Blink...") if creds.is_file(): auth = Auth(json_load(creds)) auth.no_prompt = True self.blink.auth = auth started = self.blink.start() return started
def blink_video_schedule(event, context): """Triggered from a message on a Cloud Pub/Sub topic. Args: event (dict): Event payload. context (google.cloud.functions.Context): Metadata for the event.""" FILENAME = 'blink_creds.json' #FILENAME = re.sub(r"\/.*\/(.*\.\w{1,4}",r'\1',FILE) #BLOB_UPLOAD = BLINK_BUCKET.blob(f"{create_file_path()[1:]}/{FILENAME}") #Set filename format (uploads/year/month/filename). #BLOB_UPLOAD.upload_from_filename(FILE) USER_NAME, PASSWORD = load_credentials() AUTH = Auth({"username": USER_NAME, "password": PASSWORD}, no_prompt=True) pubsub_message = base64.b64decode(event['data']).decode('utf-8') if pubsub_message == 'RUN': blink = Blink() blink.auth = AUTH blink.start() AUTH.send_auth_key(blink, '167363') blink.setup_post_verify() #print(type(blink.save(f'{FILENAME}'))) CREDS = json_load("blink_creds.json") blob_blink = BLINK_BUCKET.blob('blink_creds.json') blob_blink.upload_from_string(data=json.dumps(CREDS), content_type='application/json') print('i am before the cameras') print(blink.cameras.items()) try: for name, camera in blink.cameras.items(): print('i am inside the camera') print(name) # Name of the camera print( camera.attributes) # Print available attributes of camera except ValueError: print('there is some error') blink.download_videos(since='2018/07/04 09:34') return "SUCCESS"
class BlinkSession: def __init__( self ): self.auth_file = AUTH_FILE self.blink = Blink() def _auth_file_exists(self): return os.path.exists(self.auth_file) def _refresh_auth(self, reset=False): self.blink = Blink() with_sleep = False if not reset and self._auth_file_exists(): self.blink.auth = Auth(json_load(self.auth_file)) with_sleep = True else: self.blink.auth = Auth() self.blink.start() # write auth file self.blink.save(self.auth_file) print('Auth file updated: ' + self.auth_file) if with_sleep: time.sleep(3) return self.get(force_reset=False) def get(self, force_reset=False): if force_reset or not self._auth_file_exists(): self.blink = self._refresh_auth(reset=True) else: self.blink.auth = Auth(login_data=json_load(self.auth_file), no_prompt=True) self.blink.start() if not self.blink.available: return self._refresh_auth(reset=False) return self.blink
def start_blink_session( blink_config_file: str, blink_username, blink_password ) -> (bool, object, object): """Starts a blink cam session :param blink_config_file: blink session config file path :type blink_config_file: string :param blink_username: blink username :type blink_username: string :param blink_password: blink password :type blink_password: string :return: authentication_success for existing session or 2FA token required, blink instance, auth instance :rtype authentication_success: boolean :rtype blink: class :rtype auth: class """ blink = Blink(refresh_rate=3) if os.path.exists(blink_config_file): logger.info("using existing blink_config.json") auth = Auth(json_load(blink_config_file), no_prompt=True) authentication_success = True else: logger.info( "no blink_config.json found - 2FA " + "authentication token required" ) auth = Auth( {"username": blink_username, "password": blink_password}, no_prompt=True ) authentication_success = None blink.auth = auth opts = {"retries": 10, "backoff": 2} blink.auth.session = blink.auth.create_session(opts=opts) try: logger.info("start blink session") blink.start() except Exception as err: logger.info("blink session exception occured: {0}".format(err)) pass return authentication_success, blink, auth
def _blink_startup_wrapper(hass, entry): """Startup wrapper for blink.""" blink = Blink() auth_data = deepcopy(dict(entry.data)) blink.auth = Auth(auth_data, no_prompt=True) blink.refresh_rate = entry.options.get(CONF_SCAN_INTERVAL, DEFAULT_SCAN_INTERVAL) if blink.start(): blink.setup_post_verify() elif blink.auth.check_key_required(): _LOGGER.debug("Attempting a reauth flow") _reauth_flow_wrapper(hass, auth_data) return blink
from urllib.request import urlopen import json, time from blinkpy.blinkpy import Blink from blinkpy.auth import Auth blink = Blink() # https://pypi.org/project/blinkpy/ auth = Auth( { "username": "******", "password": "******" }, no_prompt=False) trusted_mac_addresses = ["aa:bb:cc:dd:ee:ff"] blink.auth = auth blink.start() # all this shit below here is to parse my router's device list properly. i love proper object notation, and tried to do this without regex. ;p in_table = False this_device = [] row_name = "" last_tag = "" device_list = {} class MyHTMLParser(HTMLParser): def handle_starttag(self, tag, attrs): global in_table, this_device, row_name, last_tag, device_list if tag == "table": in_table = True if in_table:
class TestBlinkSetup(unittest.TestCase): """Test the Blink class in blinkpy.""" def setUp(self): """Set up Blink module.""" self.blink = Blink(username=USERNAME, password=PASSWORD) self.blink.sync["test"] = BlinkSyncModule(self.blink, "test", "1234", []) self.blink.urls = BlinkURLHandler("test") self.blink.session = create_session() def tearDown(self): """Clean up after test.""" self.blink = None def test_initialization(self, mock_sess): """Verify we can initialize blink.""" self.assertEqual(self.blink.version, __version__) self.assertEqual(self.blink.login_handler.data["username"], USERNAME) self.assertEqual(self.blink.login_handler.data["password"], PASSWORD) def test_bad_request(self, mock_sess): """Check that we raise an Exception with a bad request.""" self.blink.session = create_session() explog = "WARNING:blinkpy.helpers.util:" "Response from server: 200 - foo" with self.assertRaises(BlinkException): http_req(self.blink, reqtype="bad") with self.assertLogs() as logrecord: http_req(self.blink, reqtype="post", is_retry=True) self.assertEqual(logrecord.output, [explog]) def test_authentication(self, mock_sess): """Check that we can authenticate Blink up properly.""" authtoken = self.blink.get_auth_token()["TOKEN_AUTH"] expected = mresp.LOGIN_RESPONSE["authtoken"]["authtoken"] self.assertEqual(authtoken, expected) def test_reauthorization_attempt(self, mock_sess): """Check that we can reauthorize after first unsuccessful attempt.""" original_header = self.blink.get_auth_token() # pylint: disable=protected-access bad_header = {"Host": self.blink._host, "TOKEN_AUTH": "BADTOKEN"} # pylint: disable=protected-access self.blink._auth_header = bad_header self.assertEqual(self.blink.auth_header, bad_header) api.request_homescreen(self.blink) self.assertEqual(self.blink.auth_header, original_header) def test_multiple_networks(self, mock_sess): """Check that we handle multiple networks appropriately.""" self.blink.networks = { "0000": { "onboarded": False, "name": "foo" }, "5678": { "onboarded": True, "name": "bar" }, "1234": { "onboarded": False, "name": "test" }, } self.blink.get_ids() self.assertTrue("5678" in self.blink.network_ids) def test_multiple_onboarded_networks(self, mock_sess): """Check that we handle multiple networks appropriately.""" self.blink.networks = { "0000": { "onboarded": False, "name": "foo" }, "5678": { "onboarded": True, "name": "bar" }, "1234": { "onboarded": True, "name": "test" }, } self.blink.get_ids() self.assertTrue("0000" not in self.blink.network_ids) self.assertTrue("5678" in self.blink.network_ids) self.assertTrue("1234" in self.blink.network_ids) @mock.patch("blinkpy.blinkpy.time.time") def test_throttle(self, mock_time, mock_sess): """Check throttling functionality.""" now = self.blink.refresh_rate + 1 mock_time.return_value = now self.assertEqual(self.blink.last_refresh, None) self.assertEqual(self.blink.check_if_ok_to_update(), True) self.assertEqual(self.blink.last_refresh, None) with mock.patch("blinkpy.sync_module.BlinkSyncModule.refresh", return_value=True): self.blink.refresh() self.assertEqual(self.blink.last_refresh, now) self.assertEqual(self.blink.check_if_ok_to_update(), False) self.assertEqual(self.blink.last_refresh, now) def test_sync_case_insensitive_dict(self, mock_sess): """Check that we can access sync modules ignoring case.""" self.assertEqual(self.blink.sync["test"].name, "test") self.assertEqual(self.blink.sync["TEST"].name, "test") @mock.patch("blinkpy.api.request_login") def test_unexpected_login(self, mock_login, mock_sess): """Check that we appropriately handle unexpected login info.""" mock_login.return_value = None self.assertFalse(self.blink.get_auth_token()) @mock.patch("blinkpy.api.request_homescreen") def test_get_cameras(self, mock_home, mock_sess): """Check retrieval of camera information.""" mock_home.return_value = { "cameras": [ { "name": "foo", "network_id": 1234, "id": 5678 }, { "name": "bar", "network_id": 1234, "id": 5679 }, { "name": "test", "network_id": 4321, "id": 0000 }, ] } result = self.blink.get_cameras() self.assertEqual( result, { "1234": [{ "name": "foo", "id": 5678 }, { "name": "bar", "id": 5679 }], "4321": [{ "name": "test", "id": 0000 }], }, ) @mock.patch("blinkpy.api.request_homescreen") def test_get_cameras_failure(self, mock_home, mock_sess): """Check that on failure we initialize empty info and move on.""" mock_home.return_value = {} result = self.blink.get_cameras() self.assertEqual(result, {}) @mock.patch.object(LoginHandler, "send_auth_key") @mock.patch.object(Blink, "setup_post_verify") def test_startup_prompt(self, mock_send_key, mock_verify, mock_sess): """Test startup logic with command-line prompt.""" mock_send_key.return_value = True mock_verify.return_value = True self.blink.no_prompt = False self.blink.key_required = True self.blink.available = True with mock.patch("builtins.input", return_value="1234"): self.blink.start() self.assertFalse(self.blink.key_required) def test_startup_no_prompt(self, mock_sess): """Test startup with no_prompt flag set.""" self.blink.key_required = True self.blink.no_prompt = True self.blink.start() self.assertTrue(self.blink.key_required)
def start(): """Startup blink app.""" blink = Blink() blink.auth = Auth(json_load(CREDFILE)) blink.start() return blink