2017-03-10 15:36:30 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
import logging
|
|
|
|
from flask import current_app
|
|
|
|
from flask_script import Manager
|
|
|
|
|
|
|
|
from pillar.cli import manager
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
manager_cloud = Manager(
|
|
|
|
current_app, usage="Blender Cloud scripts")
|
|
|
|
|
|
|
|
|
|
|
|
@manager_cloud.command
|
|
|
|
def reconcile_subscribers():
|
|
|
|
"""For every user, check their subscription status with the store."""
|
2017-05-04 18:17:37 +02:00
|
|
|
from pillar.api.blender_cloud.subscription import fetch_subscription_info
|
2017-03-10 15:36:30 +01:00
|
|
|
|
|
|
|
users_coll = current_app.data.driver.db['users']
|
|
|
|
unsubscribed_users = []
|
|
|
|
for user in users_coll.find({'roles': 'subscriber'}):
|
|
|
|
print('Processing %s' % user['email'])
|
|
|
|
print(' Checking subscription')
|
2017-05-04 18:17:37 +02:00
|
|
|
user_store = fetch_subscription_info(user['email'])
|
2017-03-10 15:36:30 +01:00
|
|
|
if user_store['cloud_access'] == 0:
|
|
|
|
print(' Removing subscriber role')
|
|
|
|
users_coll.update(
|
|
|
|
{'_id': user['_id']},
|
|
|
|
{'$pull': {'roles': 'subscriber'}})
|
|
|
|
unsubscribed_users.append(user['email'])
|
|
|
|
|
|
|
|
if not unsubscribed_users:
|
|
|
|
return
|
|
|
|
|
|
|
|
print('The following users have been unsubscribed')
|
|
|
|
for user in unsubscribed_users:
|
|
|
|
print(user)
|
|
|
|
|
|
|
|
manager.add_command("cloud", manager_cloud)
|