#
# Thierry Parmentelat - INRIA
-#
+#
from PLC.Faults import *
from PLC.Method import Method
from PLC.Filter import Filter
from PLC.Auth import Auth
+from PLC.Persons import Person
from PLC.Peers import Peer, Peers
class GetPeers (Method):
specified details will be returned.
"""
- roles = ['admin']
+ roles = ['admin', 'node','pi','user']
accepts = [
Auth(),
Mixed([Mixed(Peer.fields['peer_id'],
Peer.fields['peername'])],
Filter(Peer.fields)),
- Parameter([str], "List of fields to return", nullok = True)
+ Parameter([str], "List of fields to return", nullok = True)
]
returns = [Peer.fields]
def call (self, auth, peer_filter = None, return_fields = None):
- return Peers(self.api, peer_filter, return_fields)
+
+ peers = Peers(self.api, peer_filter, return_fields)
+
+ # Remove admin only fields
+ if not isinstance(self.caller, Person) or \
+ 'admin' not in self.caller['roles']:
+ for peer in peers:
+ for field in ['key', 'cacert']:
+ if field in peer:
+ del peer[field]
+
+ return peers