facebook_business/adobjects/helpers/adaccountusermixin.py (31 lines of code) (raw):
# Copyright 2014 Facebook, Inc.
# You are hereby granted a non-exclusive, worldwide, royalty-free license to
# use, copy, modify, and distribute this software in source code or binary
# form for use in connection with the web services and APIs provided by
# Facebook.
# As with any software that integrates with the Facebook platform, your use
# of this software is subject to the Facebook Developer Principles and
# Policies [http://developers.facebook.com/policy/]. This copyright notice
# shall be included in all copies or substantial portions of the software.
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.
from facebook_business.adobjects.adaccount import AdAccount
from facebook_business.adobjects.page import Page
from facebook_business.adobjects.objectparser import ObjectParser
from facebook_business.api import FacebookRequest
from facebook_business.typechecker import TypeChecker
class AdAccountUserMixin:
class Field(object):
id = 'id'
name = 'name'
permissions = 'permissions'
role = 'role'
class Permission(object):
account_admin = 1
admanager_read = 2
admanager_write = 3
billing_read = 4
billing_write = 5
reports = 7
class Role(object):
administrator = 1001
analyst = 1003
manager = 1002
# @deprecated get_endpoint function is deprecated
@classmethod
def get_endpoint(cls):
return 'users'
def get_ad_accounts(self, fields=None, params=None):
"""Returns iterator over AdAccounts associated with this user."""
return self.iterate_edge(AdAccount, fields, params, endpoint='adaccounts')
def get_ad_account(self, fields=None, params=None):
"""Returns first AdAccount associated with this user."""
return self.edge_object(AdAccount, fields, params)
def get_pages(self, fields=None, params=None):
"""Returns iterator over Pages's associated with this user."""
return self.iterate_edge(Page, fields, params)