Commit Graph

220 Commits

Author SHA1 Message Date
Blacktwin
42d381f9e2 encoding for killmessage, enviro instead of config, import os missing. 2018-07-10 10:55:58 -04:00
Blacktwin
03b36c1035 obsolete, use limiterr 2018-07-10 08:22:31 -04:00
Blacktwin
8cd280ea8a limiterr and readme with examples. 2018-07-10 08:17:54 -04:00
Blacktwin
20f79eafa8 doc fix 2018-07-10 08:17:29 -04:00
JonnyWong16
c413526ec3 Return empty list if get_activity fails 2018-06-29 23:58:24 -07:00
JonnyWong16
2bd92acca7 Encode back to UTF-8 2018-06-29 23:50:42 -07:00
JonnyWong16
1e8e96398b Decode script arguments 2018-06-29 13:14:13 -07:00
Landon Abney
473a073dd6
Wrap message in quotes
Now that Tautulli is sending the arguments correctly as of v2.1.14, wrap the kill messages in quotes so it's obvious where they start and stop.
2018-06-27 14:41:43 -07:00
Landon Abney
bef7be7627
Exit if a sessionID wasn't provided
If the user mistakenly calls the script without a `sessionID`, exit 
early with a warning message and the likely reason.
2018-06-20 10:45:00 -07:00
Landon Abney
98186dec8b
Ensure newlines in output
Although there will only be a single line of output in most cases, 
ensure that newlines are printed in case there are multiple lines, or 
the script is running in a full shell.
2018-06-18 20:49:16 -07:00
Landon Abney
75b4fa3229
Add examples for paused streams
Add a few examples for usage of the new paused stream functionality.
2018-06-18 13:30:41 -07:00
Landon Abney
c976a3dfb1
Cleanup format of examples
Cleans up the examples to all have a standard format that covers all
required settings and gives example messages where appropriate.
2018-06-18 13:22:40 -07:00
Landon Abney
7b07bb314f
Update authors 2018-06-18 12:39:21 -07:00
Landon Abney
0e5c374449
Return instead of forcibly exiting
This makes no difference currently as the script doesn't do anything
after this function finishes, but it allows any cleanup work to happen
at the end.
2018-06-18 12:38:10 -07:00
Landon Abney
ad682f3d1b
Fix time limit on paused stream monitoring
The only way that this could ever be hit is if the stream is still
active on the server, but the state is NOT one of paused, playing, or
buffering. In case Plex decides to change the states in the future
having this working properly is a good idea ;)
2018-06-18 12:37:12 -07:00
Landon Abney
4f3e35ef97
Remove an incorrect condition
The stream location can be `CELL` for example, which would count as
"local" for the first method of checking.
2018-06-18 12:09:54 -07:00
Landon Abney
1fdae8a105
Minor style cleanup and typos 2018-06-18 12:09:05 -07:00
Landon Abney
99b36aab88
camelCase -> snake_case 2018-06-18 11:54:17 -07:00
Landon Abney
31ddd97a34
Actually use BODY_TEXT_USER 2018-06-18 11:50:41 -07:00
Landon Abney
98b72f0a62
Cleanup documentation and add examples
Cleanup the documentation on how to set it up to match the current 
Tautulli state. Add a few examples to give people ideas for how to use 
this script.
2018-06-17 00:27:13 -07:00
Landon Abney
c03860ec70
Incorporate waiting to kill paused streams into kill_stream.py
Incorporate the functionality of `wait_kill_paused_notify.py` into 
`kill_stream.py`. A new selector is added of `paused` enabling this 
mode, and adds two additional arguments to control how long to wait for 
paused streams, and how often to check a stream's status. The default 
values are to kill a stream after 20 minutes, checking every 30 seconds.

The Tautulli API is used for all functionality, meaning the `plexapi` 
module is no longer required.
2018-06-17 00:01:00 -07:00
Landon Abney
0ba8e2bda0
Add a docstring for terminate_session 2018-06-16 23:53:17 -07:00
Landon Abney
4ebfaf17bd
Always send a notification if an agent is specified
Whenever a stream is killed, send a notification for that stream if a 
notification agent has been specified. If no username is specified, 
simply list the session ID.
2018-06-16 23:53:15 -07:00
Landon Abney
2116082fd7
List --killMessage at the end
Although argparse should be smart enough to handle this in any order, 
it's generally easier for us poor humans to read the arguments if the 
unstructured one is the last argument. Re-order the listing to make this 
clearer.
2018-06-16 23:53:12 -07:00
Landon Abney
342284173b
Use the same session for all requests
Use the Session created at the start of the script for all requests, 
instead of creating a new one for some of them (which doesn't inherit 
the settings set on it at the start).
2018-06-16 23:51:53 -07:00
Landon Abney
7b0cc2d2a9
Disable InsecureRequestWarning if SSL verify is False
If checking of HTTPS validity is disable, turn off the warning that it 
has been disabled since we have done so explicitly.
2018-06-16 23:51:51 -07:00
Landon Abney
00f4bf26a9
Rename get_user_activity
This function was actually getting _just_ the session IDs, not the whole 
session data.
2018-06-16 23:51:48 -07:00
Landon Abney
e56d23b12d
Refactor get_activity into two functions
Create a new function get_user_activity that returns the same data 
get_activity originally did and use that in main. get_activity now 
actually follows the name and gets all activity on the server.
2018-06-16 23:51:46 -07:00
Landon Abney
f7c555caa7
Add docbloc for send_notification 2018-06-16 23:51:43 -07:00
Landon Abney
36c2ddaaf6
Fix PEP8 issues
Some minor refactoring to follow PEP8 guidlines.
2018-06-16 23:51:32 -07:00
Blacktwin
302820a075 headers for arg and cond examples. 2018-06-15 08:40:02 -04:00
Blacktwin
e70787827d updated arguments comments.
moved examples.txt to readme.md
removed examples.txt
2018-06-15 08:32:28 -04:00
Blacktwin
64f008d1eb Corrected killMessage processing.
updated argument instruction.
2018-06-14 08:56:20 -04:00
Blacktwin
776fe7334b show --jbop choices. 2018-06-14 00:47:21 -04:00
Too Much IO
33c29f4bcc
Format syntax error [ instead of { 2018-06-14 09:04:33 +10:00
Blacktwin
c93972f46c overide/fallback clean up. 2018-06-12 15:51:08 -04:00
Blacktwin
58f9011850 adding examples page for kill_streams.py 2018-06-12 10:08:35 -04:00
Blacktwin
e1d904727c delete files, obsolete. 2018-06-12 10:06:45 -04:00
Blacktwin
a8cee9b115 more messaging, moved episode check to conditions, correction for 0 watched history for the day. 2018-06-12 09:55:13 -04:00
Blacktwin
bb9b42cae1 grk to int, stopped_time bracket correction. 2018-06-12 09:55:08 -04:00
Blacktwin
fd3b3675d6 != instead of 'is not' 2018-06-12 09:55:08 -04:00
blacktwin
406161120e clarity 2018-06-12 09:55:07 -04:00
Blacktwin
9f97b5218e Added ablility to kill multiple streams from one user.
Allowing for elimination of other killstream scripts.
Added notification
2018-06-11 15:57:29 -04:00
Blacktwin
e4b49d3297 fix message and ssl 2018-05-09 14:43:02 -04:00
Blacktwin
fb7c16ee80 == not in 2018-05-05 08:20:48 -04:00
Blacktwin
35382673a6 move message to arg. another example 2018-05-05 08:15:35 -04:00
Blacktwin
96594c93d6 cleanup. removing kill scripts that can now be done through conditions 2018-03-29 10:17:04 -04:00
Blacktwin
2950494a89 updated 2018-03-29 10:03:17 -04:00
Blacktwin
98b7965852 Merge remote-tracking branch 'origin/config-update' into config-update 2018-03-29 10:00:45 -04:00
Blacktwin
1000ca1e39 updated 2018-03-29 09:59:31 -04:00
Blacktwin
4f67c4dd55 updated 2018-03-29 09:53:34 -04:00
Blacktwin
5ecd42ef46 stdout instead of print. 2018-03-29 09:49:30 -04:00
Blacktwin
1e44845d9a adding else print out for logs. 2018-03-29 09:49:30 -04:00
Blacktwin
9c461dbe43 updated sessions check. Trailers and pre-rolls not included in plexapi sessions(). 2018-03-29 09:49:29 -04:00
Blacktwin
ae410b8fec fix if, add int 2018-03-29 09:49:29 -04:00
Blacktwin
a9cf95652f updated notifierID and notifierID location for tautulli 2018-03-29 09:49:28 -04:00
Blacktwin
56bf099416 Add wait_kill_pause_notify from samwiseg00 2018-03-29 09:49:28 -04:00
Blacktwin
bdff121f5b PlexPy names to tautulli. Agent_id to notifier_id. 2018-03-29 09:48:21 -04:00
blacktwin
ee73a93fdc If else
Added else
2018-03-29 09:48:20 -04:00
Blacktwin
9b62cf6192 testing 2018-03-14 10:21:25 -04:00
blacktwin
99a86693a3 Update for killing streams. Adding config structure. 2018-03-14 08:49:48 -04:00
blacktwin
81cb09ebf5
Update kill_trans_library.py 2018-02-14 08:34:27 -05:00
blacktwin
10686c6f26
library check
Actually check against the targeted library...
2018-02-14 08:34:10 -05:00
KurtzPT
168ea61824
Update kill_trans_pause.py 2018-02-06 16:58:32 +00:00
blacktwin
5325030cb6
fixed if 2018-02-03 18:04:20 -05:00
blacktwin
ce12c4a1bf
simpler
Add only the devices that you want to kill on playback start.
2018-02-03 17:22:19 -05:00
blacktwin
8ffdbbb939
if session.transcodeSessions:
if stream is not copy or transcode then this entry will be null. If null then it would error out the script. Adding this if will clean up the error.
2018-01-26 10:23:07 -05:00
blacktwin
d69570ad44
Update kill_trans_library.py 2018-01-26 10:18:58 -05:00
blacktwin
a8f6cb31a0
Update kill_more_than.py 2018-01-26 09:18:40 -05:00
blacktwin
5855fb3297
session_key added
session_key from session that caused the concurrent trigger will be collected.
2018-01-26 09:16:03 -05:00
blacktwin
fab88eda03
Update kill_trans_library.py
add session_key arg and separate `if transcodeSessions`
If an active session was not transcoding then the script would error on the session and may not complete loop through all sessions.
2018-01-24 13:45:13 -05:00
blacktwin
ad5fcb6d75
Update message.
previous message was related to another script.
2018-01-11 14:45:15 -05:00
blacktwin
25698107fb
Instruction correction
Paused not start
2018-01-11 13:59:42 -05:00
blacktwin
ce252afcb4
Update kill_trans_pause.py 2018-01-08 18:37:19 -05:00
blacktwin
5998395f27
sleep(interval)
sleep time should be constant value and not an increasing value.
2018-01-06 10:53:50 -05:00
blacktwin
465d47b668
Update kill_trans_exp_audio.py 2018-01-03 11:37:26 -05:00
blacktwin
a2f0d09bfe
except for non transcoding sessions
if not transcoding would error out instead of continuing.
2018-01-03 11:37:02 -05:00
blacktwin
a6aacee41b
pass instead of exit() 2018-01-03 08:50:00 -05:00
blacktwin
0989d2d824
transcode not trancode.... 2018-01-03 08:46:08 -05:00
blacktwin
c81dcf6477
players 2018-01-02 23:57:27 -05:00
blacktwin
67c743bb7f
if fix 2017-12-13 13:03:28 -05:00
blacktwin
d229a22b55
Update kill_trans_library.py 2017-12-13 13:02:37 -05:00
blacktwin
3bf0bf270f
!=
not track....
2017-12-13 13:01:32 -05:00
blacktwin
7a84b41f28
Create kill_trans_library.py 2017-12-13 12:51:25 -05:00
blacktwin
dd0abe9203
Create kill_trans_quality.py 2017-12-12 23:59:22 -05:00
blacktwin
44c9160e74
s 2017-12-12 23:13:04 -05:00
blacktwin
88d1ffc06d
Update kill_device.py 2017-12-06 12:05:43 -05:00
blacktwin
7d2e8692c7
message fix 2017-12-06 12:05:20 -05:00
blacktwin
dd064f583f
Update kill_trans_exp_audio.py 2017-12-06 12:04:32 -05:00
blacktwin
a8550934b6
message fix 2017-12-06 12:02:29 -05:00
blacktwin
0d2c9cff97
Create kill_device.py 2017-12-05 07:16:20 -05:00
blacktwin
7861141c30
Oops 2017-11-13 12:53:33 -05:00
blacktwin
53f418c64f
Oops2
()
2017-11-13 12:51:55 -05:00
blacktwin
6f1b0d85f1
Update play_limit.py 2017-11-10 10:08:40 -05:00
blacktwin
b065c36ae0
Kill stream based if user see Library X
feature request for 
2017-11-10 10:07:33 -05:00
blacktwin
55f4764533
adding print
adding prints to identify what sub script is doing.
2017-11-10 08:14:27 -05:00
blacktwin
5dbcb48093
missing session stop command
session.stop(reason=KILL_MESSAGE)
2017-11-06 10:25:28 -05:00
blacktwin
ce97452382 Update time_limit.py
2017-10-26 12:40:30 -04:00
blacktwin
155e6a129f Create time_limit.py
So many more feature to add to this. notify user of removal, record user invitedAt and removedAt, the libraries shared with user (in case you invite them back you could provide the same libraries).
2017-10-26 12:37:48 -04:00
blacktwin
a7f360e7ec remove print 2017-10-23 12:56:21 -04:00