+# $Id$
+# $URL$
from PLC.Faults import *
from PLC.Method import Method
from PLC.Parameter import Parameter, Mixed
+from PLC.Filter import Filter
from PLC.Addresses import Address, Addresses
-from PLC.Auth import PasswordAuth
+from PLC.Auth import Auth
class GetAddresses(Method):
"""
- Get an array of structs containing details about addresses. If
- address_id_list is specified, only the specified addresses will be
- queried.
+ Returns an array of structs containing details about addresses. If
+ address_filter is specified and is an array of address
+ identifiers, or a struct of address attributes, only addresses
+ matching the filter will be returned. If return_fields is
+ specified, only the specified details will be returned.
"""
- roles = ['admin', 'pi', 'user', 'tech']
+ roles = ['admin', 'pi', 'user', 'tech', 'node']
accepts = [
- PasswordAuth(),
- [Address.fields['address_id']],
+ Auth(),
+ Mixed([Address.fields['address_id']],
+ Filter(Address.fields)),
+ Parameter([str], "List of fields to return", nullok = True)
]
returns = [Address.fields]
- def call(self, auth, address_id_list = None):
- addresses = Addresses(self.api, address_id_list).values()
-
- # Turn each address into a real dict
- addresses = [dict(address) for address in addresses]
- return addresses
+ def call(self, auth, address_filter = None, return_fields = None):
+ return Addresses(self.api, address_filter, return_fields)