Giter Club home page Giter Club logo

arlo's Introduction

arlo

Python module for interacting with Netgear's Arlo camera system.

Now supports MFA!

MFA using this library relies on using the Gmail API to retrieve MFA codes. Please see the Wiki for detailed instructions for configuring MFA via Gmail.

Now in Golang!

If you love the Go programming language, check out arlo-golang. My goal is to bring parity to the Python version asap. If you know what you're doing in Go, I would appreciate any feedback on the >general structure of the library, and contributions, etc.


GETTING STARTED

Check out the API DOCS

IMPORTANT: There is a regression in sseclient 0.0.24 that breaks this package. Please ensure you have seeclient 0.0.22 installed.

IMPORTANT: Please ensure you don't have ANY other sseclient packages installed in addition to sseclient 0.0.22! This may cause this package to fail in unexpected ways. A common one that is known to cause issues is the sseclient-py 1.7 package. If you have a hard requirement to have more than one, please let me know and we can look into making that work.

IMPORTANT: my.arlo.com requires TLS 1.2 for their API. So, if you're getting ssl errors, it's most likely related to your version of openssl. You may need to upgrade your openssl library. If you're running this library on OSX or macOS, they ship with openssl v0.9.x which does not support TLS 1.2. You should follow the instructions found here to upgrade your openssl library.


Filing an Issue

Please read the Issue Guidelines and Policies wiki page BEFORE you file an issue. Thanks.


Install

# Install latest stable package
$ pip install arlo

--or--

# Install from master branch
$ pip install git+https://github.com/jeffreydwalter/arlo

This just a personal utility that I created out of necessity. It is by no means complete, although it does expose quite a bit of the Arlo interface in an easy to use Python package. As such, this package does not come with unit tests (feel free to add them) or guarantees. All contributions are welcome and appreciated!

If you have a specific Arlo device that you want to improve support for, please consider sending me one! Since this project is solely maintained by yours truely and I don't have unlimited funds to support it, I can only really test and debug the code with the first gen Arlo cameras and basestation that I have. I also highly encourage and appreciate Pull Requests!

Please, feel free to contribute to this repo or buy Jeff a beer! Donate


Generous Benefactors (Thank you!)

  • sfederman - 🍺🍺🍺🍺
  • DerekEwing - 🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺🍺 - THANK YOU!!! * hickup *
  • apsteinmetz - 🍺
  • mhallikainen - 🍺🍺
  • tinsheep - 🍺🍺
  • cubewot - 🍺🍺
  • imopen - 🍺
  • notalifeform - 🍺🍺
  • anonymous - 🍺🍺🍺🍺
  • kewashi - 🍺

Awesomely Smart Contributors (Thank you!)

  • sfederman - Aug 3, 2021 - Helped to debug and fix EventStream in MFA branch.
  • neilferreira - Jun 4, 2021 - Pointed out missing schemaVersoin header.
  • timgates42 - Mar 3, 2021 - Fixed crappy spelling in README.
  • Kerl1310 - Jan 11, 2020 - Added automated unit tests. THANK YOU!
  • Kerl1310 - Jan 8, 2020 - Added comments and a method to get account information.
  • fleicher - Mar 29, 2020 - Added a helper method to get devices by name.
  • apsteinmetz - Feb 12, 2020 - Added an example of timestamping Arlo snapshots to the wiki.
  • alvin-chang - Dec 15, 2019 - Updated some print statements to work with Python 3 in an example script.
  • pabloNZ - Jun 4, 2019 - Added the Arlo doorbell, Ultra camera and basestation schemas to the wiki.
  • m3ntalsp00n - May 18, 2019 - Expanded ArloQ device support.
  • burken- - Apr 17, 2019 - Fixed arming/disarming ArloQ devices.
  • m0urs - Apr 16, 2019 - Updated fqdn to new Arlo domain.
  • kimc78 - Aug 16, 2018 - Added method to get CVR recording list.
  • jurgenweber - Apr 25, 2018 - Added Arlo Baby APIs!
  • pliablepixels - Apr 3, 2018 - Fixed up issues with the README.
  • manluk - Mar 2, 2018 - Squashed a couple of bugs.
  • notalifeform - Feb 10, 2018 - Fixed bug and formatting in example script.
  • erosen - Jan 27, 2018 - Added the ArloQ camera schema to the wiki.
  • deanmcguire - Dec 7, 2017 - Unravelled the mysteries of RTSP streaming video.
  • andijakl - Jul 24, 2017 - Added Python 3 support and cleaned up examples.
  • cemeyer2 - Nov 26, 2016 - Fixed setup issues.
  • LenShustek - Sep 14, 2016, - Added Logout().

If You'd like to make a difference in the world and get your name on this most prestigious list, have a look at our help wanted section!

After installing all of the required libraries, you can import and use this library like so:

from arlo import Arlo

from datetime import timedelta, date
import datetime
import sys

USERNAME = '[email protected]'
PASSWORD = 'supersecretpassword'

try:
	# Instantiating the Arlo object automatically calls Login(), which returns an oAuth token that gets cached.
	# Subsequent successful calls to login will update the oAuth token.
	arlo = Arlo(USERNAME, PASSWORD)
	# At this point you're logged into Arlo.

	today = (date.today()-timedelta(days=0)).strftime("%Y%m%d")
	seven_days_ago = (date.today()-timedelta(days=7)).strftime("%Y%m%d")

	# Get all of the recordings for a date range.
	library = arlo.GetLibrary(seven_days_ago, today)

	# Iterate through the recordings in the library.
	for recording in library:

		videofilename = datetime.datetime.fromtimestamp(int(recording['name'])//1000).strftime('%Y-%m-%d %H-%M-%S') + ' ' + recording['uniqueId'] + '.mp4'
		##
		# The videos produced by Arlo are pretty small, even in their longest, best quality settings,
		# but you should probably prefer the chunked stream (see below). 
		###    
		#    # Download the whole video into memory as a single chunk.
		#    video = arlo.GetRecording(recording['presignedContentUrl'])
		#	 with open('videos/'+videofilename, 'wb') as f:
		#        f.write(video)
		#        f.close()
		# Or:
		#
		# Get video as a chunked stream; this function returns a generator.
		stream = arlo.StreamRecording(recording['presignedContentUrl'])
		with open('videos/'+videofilename, 'wb') as f:
			for chunk in stream:
				f.write(chunk)
			f.close()

		print('Downloaded video '+videofilename+' from '+recording['createdDate']+'.')

	# Delete all of the videos you just downloaded from the Arlo library.
	# Notice that you can pass the "library" object we got back from the GetLibrary() call.
	result = arlo.BatchDeleteRecordings(library)

	# If we made it here without an exception, then the videos were successfully deleted.
	print('Batch deletion of videos completed successfully.')

except Exception as e:
    print(e)

For more code examples check out the wiki

arlo's People

Contributors

aeon avatar alvin-chang avatar andijakl avatar booi avatar burken- avatar cemeyer2 avatar charlesvestal avatar cwilko avatar dependabot[bot] avatar fleicher avatar frostman avatar jeffreydwalter avatar jlathrop avatar jschroth avatar jurgenweber avatar jwalter1-quest avatar kerl1310 avatar kimc78 avatar lenshustek avatar m0urs avatar m3ntalsp00n avatar notalifeform avatar pliablepixels avatar proxymiity avatar robweber avatar timgates42 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.