integrated cloud function, removed implied environment variables
This commit is contained in:
parent
5aa8e47ddf
commit
c221025c5f
21
.gcloudignore
Normal file
21
.gcloudignore
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# This file specifies files that are *not* uploaded to Google Cloud Platform
|
||||||
|
# using gcloud. It follows the same syntax as .gitignore, with the addition of
|
||||||
|
# "#!include" directives (which insert the entries of the given .gitignore-style
|
||||||
|
# file at that point).
|
||||||
|
#
|
||||||
|
# For more information, run:
|
||||||
|
# $ gcloud topic gcloudignore
|
||||||
|
#
|
||||||
|
.gcloudignore
|
||||||
|
# If you would like to upload your .git directory, .gitignore file or files
|
||||||
|
# from your .gitignore file, remove the corresponding line
|
||||||
|
# below:
|
||||||
|
.git
|
||||||
|
.gitignore
|
||||||
|
|
||||||
|
env
|
||||||
|
.idea
|
||||||
|
.spot
|
||||||
|
|
||||||
|
node_modules
|
||||||
|
#!include:.gitignore
|
5
alarm.py
5
alarm.py
@ -22,7 +22,10 @@ if __name__ == '__main__':
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
||||||
network = Network(User())
|
network = Network(User(os.environ['SPOTCLIENT'],
|
||||||
|
os.environ['SPOTSECRET'],
|
||||||
|
os.environ['SPOTACCESS'],
|
||||||
|
os.environ['SPOTREFRESH']))
|
||||||
|
|
||||||
found = False
|
found = False
|
||||||
|
|
||||||
|
@ -11,7 +11,10 @@ if __name__ == '__main__':
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
||||||
network = Network(User())
|
network = Network(User(os.environ['SPOTCLIENT'],
|
||||||
|
os.environ['SPOTSECRET'],
|
||||||
|
os.environ['SPOTACCESS'],
|
||||||
|
os.environ['SPOTREFRESH']))
|
||||||
playlists = network.get_user_playlists()
|
playlists = network.get_user_playlists()
|
||||||
|
|
||||||
for playlist in playlists:
|
for playlist in playlists:
|
||||||
|
@ -104,7 +104,10 @@ def go():
|
|||||||
log.log('none to execute, terminating')
|
log.log('none to execute, terminating')
|
||||||
return
|
return
|
||||||
|
|
||||||
net = Network(User())
|
net = Network(User(os.environ['SPOTCLIENT'],
|
||||||
|
os.environ['SPOTSECRET'],
|
||||||
|
os.environ['SPOTACCESS'],
|
||||||
|
os.environ['SPOTREFRESH']))
|
||||||
|
|
||||||
engine = PlaylistEngine(net)
|
engine = PlaylistEngine(net)
|
||||||
engine.load_user_playlists()
|
engine.load_user_playlists()
|
||||||
|
@ -1,8 +1,13 @@
|
|||||||
from spotframework.net.user import User
|
from spotframework.net.user import User
|
||||||
from spotframework.net.network import Network
|
from spotframework.net.network import Network
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
||||||
network = Network(User())
|
network = Network(User(os.environ['SPOTCLIENT'],
|
||||||
|
os.environ['SPOTSECRET'],
|
||||||
|
os.environ['SPOTACCESS'],
|
||||||
|
os.environ['SPOTREFRESH']))
|
||||||
|
|
||||||
print(network.user.access_token)
|
print(network.user.access_token)
|
||||||
|
36
main.py
36
main.py
@ -1,36 +1,14 @@
|
|||||||
import spotframework.net.user as userclass
|
|
||||||
import spotframework.net.network as networkclass
|
|
||||||
import spotframework.net.network as playlist
|
|
||||||
|
|
||||||
import spotframework.io.json as json
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
def run_user_playlist(event, context):
|
||||||
print('hello world')
|
|
||||||
|
|
||||||
# data = json.loadJson('.spot/config.json')
|
import base64
|
||||||
|
|
||||||
# print(data)
|
name = base64.b64decode(event['data']).decode('utf-8')
|
||||||
|
username = event['attributes']['username']
|
||||||
|
|
||||||
network = networkclass.Network(userclass.User())
|
print(f'{username} - {name}')
|
||||||
|
|
||||||
# tracks = network.getPlaylistTracks("76ynkbkyc4uq11u1FcpOyG")
|
from spotframework.google.run_user_playlist import run_user_playlist as run
|
||||||
|
|
||||||
# print(tracks[0])
|
run(username, name)
|
||||||
|
|
||||||
# network.setVolume(105)
|
|
||||||
|
|
||||||
# network.getPlaylist('000Eh2vXzYGgrEFlgcWZj3')
|
|
||||||
#
|
|
||||||
# playlist = network.makePlaylist('new playlist')
|
|
||||||
#
|
|
||||||
# network.addPlaylistTracks(playlist.playlistid, ["spotify:track:78lC4VmDVSSsCUQ0VNdQva"]*149)
|
|
||||||
#
|
|
||||||
# network.replacePlaylistTracks(playlist.playlistid, ["spotify:track:78lC4VmDVSSsCUQ0VNdQva"] * 160)
|
|
||||||
#
|
|
||||||
# network.pause()
|
|
||||||
|
|
||||||
#network.getPlayer()
|
|
||||||
|
|
||||||
# playlists = network.getUserPlaylists()
|
|
||||||
# for playlist in playlists:
|
|
||||||
# print(playlist.name + ' ' + playlist.playlistid)
|
|
||||||
|
18
requirements.txt
Normal file
18
requirements.txt
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
cachetools==3.1.1
|
||||||
|
certifi==2019.3.9
|
||||||
|
chardet==3.0.4
|
||||||
|
google-api-core==1.14.2
|
||||||
|
google-auth==1.6.3
|
||||||
|
google-cloud-core==1.0.3
|
||||||
|
google-cloud-firestore==1.3.0
|
||||||
|
googleapis-common-protos==1.6.0
|
||||||
|
grpcio==1.22.0
|
||||||
|
idna==2.8
|
||||||
|
protobuf==3.9.0
|
||||||
|
pyasn1==0.4.6
|
||||||
|
pyasn1-modules==0.2.5
|
||||||
|
pytz==2019.2
|
||||||
|
requests==2.21.0
|
||||||
|
rsa==4.0
|
||||||
|
six==1.12.0
|
||||||
|
urllib3==1.24.3
|
0
spotframework/google/__init__.py
Normal file
0
spotframework/google/__init__.py
Normal file
65
spotframework/google/run_user_playlist.py
Normal file
65
spotframework/google/run_user_playlist.py
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
from google.cloud import firestore
|
||||||
|
|
||||||
|
from spotframework.engine.playlistengine import PlaylistEngine
|
||||||
|
from spotframework.engine.filter.shuffle import Shuffle
|
||||||
|
from spotframework.engine.filter.sortreversereleasedate import SortReverseReleaseDate
|
||||||
|
from spotframework.engine.filter.deduplicatebyid import DeduplicateByID
|
||||||
|
|
||||||
|
from spotframework.net.network import Network
|
||||||
|
from spotframework.net.user import User
|
||||||
|
|
||||||
|
db = firestore.Client()
|
||||||
|
|
||||||
|
|
||||||
|
def run_user_playlist(username, playlist_name):
|
||||||
|
|
||||||
|
users = db.collection(u'spotify_users').where(u'username', u'==', username).stream()
|
||||||
|
users = [i for i in users]
|
||||||
|
|
||||||
|
if len(users) == 1:
|
||||||
|
|
||||||
|
user_dict = users[0].to_dict()
|
||||||
|
|
||||||
|
playlist_collection = db.collection(u'spotify_users', u'{}'.format(users[0].id), 'playlists')
|
||||||
|
|
||||||
|
print(user_dict['access_token'], user_dict['refresh_token'])
|
||||||
|
|
||||||
|
playlists = [i for i in playlist_collection.where(u'name', u'==', playlist_name).stream()]
|
||||||
|
|
||||||
|
if len(playlists) == 1:
|
||||||
|
|
||||||
|
playlist_dict = playlists[0].to_dict()
|
||||||
|
|
||||||
|
if playlist_dict['playlist_id'] is None:
|
||||||
|
raise Exception('no playlist id to populate')
|
||||||
|
|
||||||
|
if len(playlist_dict['parts']) == 0:
|
||||||
|
raise Exception('no playlists to use for creation')
|
||||||
|
|
||||||
|
spotify_keys = db.document('key/spotify').get().to_dict()
|
||||||
|
|
||||||
|
net = Network(User(spotify_keys['clientid'],
|
||||||
|
spotify_keys['clientsecret'],
|
||||||
|
user_dict['access_token'],
|
||||||
|
user_dict['refresh_token']))
|
||||||
|
|
||||||
|
engine = PlaylistEngine(net)
|
||||||
|
engine.load_user_playlists()
|
||||||
|
|
||||||
|
processors = [DeduplicateByID()]
|
||||||
|
|
||||||
|
if playlist_dict['shuffle'] is True:
|
||||||
|
processors.append(Shuffle())
|
||||||
|
else:
|
||||||
|
processors.append(SortReverseReleaseDate())
|
||||||
|
|
||||||
|
tracks = engine.make_playlist(playlist_dict['parts'], processors)
|
||||||
|
|
||||||
|
engine.execute_playlist(tracks, playlist_dict['playlist_id'])
|
||||||
|
engine.change_description(playlist_dict['parts'], playlist_dict['playlist_id'])
|
||||||
|
|
||||||
|
else:
|
||||||
|
raise Exception('multiple playlists found')
|
||||||
|
|
||||||
|
else:
|
||||||
|
raise Exception('more than one user found')
|
@ -111,7 +111,7 @@ class Network:
|
|||||||
|
|
||||||
params = {'offset': offset, 'limit': limit}
|
params = {'offset': offset, 'limit': limit}
|
||||||
|
|
||||||
resp = self._make_get_request('getPlaylistTracks', 'playlists/{}/tracks'.format(playlistid), params=params)
|
resp = self._make_get_request('getPlaylistTracks', f'playlists/{playlistid}/tracks', params=params)
|
||||||
|
|
||||||
tracks += resp['items']
|
tracks += resp['items']
|
||||||
|
|
||||||
@ -202,8 +202,7 @@ class Network:
|
|||||||
|
|
||||||
def make_playlist(self, name, description=None, public=True, collaborative=False):
|
def make_playlist(self, name, description=None, public=True, collaborative=False):
|
||||||
|
|
||||||
log.log("makePlaylist", name, 'description:{}'.format(description), 'public:{}'.format(public),
|
log.log("makePlaylist", name, f'description:{description}', f'public:{public}', f'collaborative:{collaborative}')
|
||||||
'collaborative:{}'.format(collaborative))
|
|
||||||
|
|
||||||
headers = {"Content-Type": "application/json"}
|
headers = {"Content-Type": "application/json"}
|
||||||
|
|
||||||
@ -212,8 +211,7 @@ class Network:
|
|||||||
if description is not None:
|
if description is not None:
|
||||||
json["description"] = description
|
json["description"] = description
|
||||||
|
|
||||||
req = self._make_post_request('makePlaylist', 'users/{}/playlists'.format(self.user.username), json=json,
|
req = self._make_post_request('makePlaylist', f'users/{self.user.username}/playlists', json=json, headers=headers)
|
||||||
headers=headers)
|
|
||||||
|
|
||||||
if req is not None:
|
if req is not None:
|
||||||
resp = req.json()
|
resp = req.json()
|
||||||
@ -232,8 +230,7 @@ class Network:
|
|||||||
|
|
||||||
json = {"uris": uris[:100]}
|
json = {"uris": uris[:100]}
|
||||||
|
|
||||||
req = self._make_put_request('replacePlaylistTracks', 'playlists/{}/tracks'.format(playlistid), json=json,
|
req = self._make_put_request('replacePlaylistTracks', f'playlists/{playlistid}/tracks', json=json, headers=headers)
|
||||||
headers=headers)
|
|
||||||
|
|
||||||
if req is not None:
|
if req is not None:
|
||||||
resp = req.json()
|
resp = req.json()
|
||||||
@ -261,8 +258,7 @@ class Network:
|
|||||||
if description is not None:
|
if description is not None:
|
||||||
json['description'] = description
|
json['description'] = description
|
||||||
|
|
||||||
req = self._make_put_request('changePlaylistDetails', 'playlists/{}'.format(playlistid), json=json,
|
req = self._make_put_request('changePlaylistDetails', f'playlists/{playlistid}', json=json, headers=headers)
|
||||||
headers=headers)
|
|
||||||
return req
|
return req
|
||||||
|
|
||||||
def add_playlist_tracks(self, playlistid, uris):
|
def add_playlist_tracks(self, playlistid, uris):
|
||||||
@ -273,8 +269,7 @@ class Network:
|
|||||||
|
|
||||||
json = {"uris": uris[:100]}
|
json = {"uris": uris[:100]}
|
||||||
|
|
||||||
req = self._make_post_request('addPlaylistTracks', 'playlists/{}/tracks'.format(playlistid), json=json,
|
req = self._make_post_request('addPlaylistTracks', f'playlists/{playlistid}/tracks', json=json, headers=headers)
|
||||||
headers=headers)
|
|
||||||
|
|
||||||
if req is not None:
|
if req is not None:
|
||||||
resp = req.json()
|
resp = req.json()
|
||||||
|
@ -1,24 +1,23 @@
|
|||||||
import os
|
|
||||||
import requests
|
import requests
|
||||||
from base64 import b64encode
|
from base64 import b64encode
|
||||||
|
|
||||||
client_id = os.environ['SPOTCLIENT']
|
|
||||||
client_secret = os.environ['SPOTSECRET']
|
|
||||||
|
|
||||||
|
|
||||||
class User:
|
class User:
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self, client_id, client_secret, access_token, refresh_token):
|
||||||
self.accesstoken = os.environ['SPOTACCESS']
|
self.accesstoken = access_token
|
||||||
self.refreshtoken = os.environ['SPOTREFRESH']
|
self.refreshtoken = refresh_token
|
||||||
|
|
||||||
|
self.client_id = client_id
|
||||||
|
self.client_secret = client_secret
|
||||||
|
|
||||||
self.refresh_token()
|
self.refresh_token()
|
||||||
|
|
||||||
self.username = self.get_info()['id']
|
self.username = self.get_info()['id']
|
||||||
|
|
||||||
def refresh_token(self):
|
def refresh_token(self):
|
||||||
|
|
||||||
idsecret = b64encode(bytes(client_id + ':' + client_secret, "utf-8")).decode("ascii")
|
idsecret = b64encode(bytes(self.client_id + ':' + self.client_secret, "utf-8")).decode("ascii")
|
||||||
headers = {'Authorization': 'Basic %s' % idsecret}
|
headers = {'Authorization': 'Basic %s' % idsecret}
|
||||||
|
|
||||||
data = {"grant_type": "refresh_token", "refresh_token": self.refreshtoken}
|
data = {"grant_type": "refresh_token", "refresh_token": self.refreshtoken}
|
||||||
|
Loading…
Reference in New Issue
Block a user