mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-07 10:55:40 +00:00
fix: Check user zone create/delete permission
Co-authored-by: zoeller-freinet <86965592+zoeller-freinet@users.noreply.github.com>
This commit is contained in:
parent
737e1fb93b
commit
d2f35a4059
@ -246,6 +246,48 @@ def api_can_create_domain(f):
|
|||||||
return decorated_function
|
return decorated_function
|
||||||
|
|
||||||
|
|
||||||
|
def apikey_can_create_domain(f):
|
||||||
|
"""
|
||||||
|
Grant access if:
|
||||||
|
- user is in Operator role or higher, or
|
||||||
|
- allow_user_create_domain is on
|
||||||
|
"""
|
||||||
|
@wraps(f)
|
||||||
|
def decorated_function(*args, **kwargs):
|
||||||
|
if g.apikey.role.name not in [
|
||||||
|
'Administrator', 'Operator'
|
||||||
|
] and not Setting().get('allow_user_create_domain'):
|
||||||
|
msg = "ApiKey #{0} does not have enough privileges to create domain"
|
||||||
|
current_app.logger.error(msg.format(g.apikey.id))
|
||||||
|
raise NotEnoughPrivileges()
|
||||||
|
return f(*args, **kwargs)
|
||||||
|
|
||||||
|
return decorated_function
|
||||||
|
|
||||||
|
|
||||||
|
def apikey_can_remove_domain(http_methods=[]):
|
||||||
|
"""
|
||||||
|
Grant access if:
|
||||||
|
- user is in Operator role or higher, or
|
||||||
|
- allow_user_remove_domain is on
|
||||||
|
"""
|
||||||
|
def decorator(f):
|
||||||
|
@wraps(f)
|
||||||
|
def decorated_function(*args, **kwargs):
|
||||||
|
check_current_http_method = not http_methods or request.method in http_methods
|
||||||
|
|
||||||
|
if (check_current_http_method and
|
||||||
|
g.apikey.role.name not in ['Administrator', 'Operator'] and
|
||||||
|
not Setting().get('allow_user_remove_domain')
|
||||||
|
):
|
||||||
|
msg = "ApiKey #{0} does not have enough privileges to remove domain"
|
||||||
|
current_app.logger.error(msg.format(g.apikey.id))
|
||||||
|
raise NotEnoughPrivileges()
|
||||||
|
return f(*args, **kwargs)
|
||||||
|
return decorated_function
|
||||||
|
return decorator
|
||||||
|
|
||||||
|
|
||||||
def apikey_is_admin(f):
|
def apikey_is_admin(f):
|
||||||
"""
|
"""
|
||||||
Grant access if user is in Administrator role
|
Grant access if user is in Administrator role
|
||||||
|
@ -27,8 +27,9 @@ from ..lib.errors import (
|
|||||||
)
|
)
|
||||||
from ..decorators import (
|
from ..decorators import (
|
||||||
api_basic_auth, api_can_create_domain, is_json, apikey_auth,
|
api_basic_auth, api_can_create_domain, is_json, apikey_auth,
|
||||||
apikey_is_admin, apikey_can_access_domain, api_role_can,
|
apikey_can_create_domain, apikey_can_remove_domain,
|
||||||
apikey_or_basic_auth,
|
apikey_is_admin, apikey_can_access_domain,
|
||||||
|
api_role_can, apikey_or_basic_auth,
|
||||||
)
|
)
|
||||||
import secrets
|
import secrets
|
||||||
import string
|
import string
|
||||||
@ -1037,6 +1038,7 @@ def api_zone_subpath_forward(server_id, zone_id, subpath):
|
|||||||
methods=['GET', 'PUT', 'PATCH', 'DELETE'])
|
methods=['GET', 'PUT', 'PATCH', 'DELETE'])
|
||||||
@apikey_auth
|
@apikey_auth
|
||||||
@apikey_can_access_domain
|
@apikey_can_access_domain
|
||||||
|
@apikey_can_remove_domain(http_methods=['DELETE'])
|
||||||
def api_zone_forward(server_id, zone_id):
|
def api_zone_forward(server_id, zone_id):
|
||||||
resp = helper.forward_request()
|
resp = helper.forward_request()
|
||||||
if not Setting().get('bg_domain_updates'):
|
if not Setting().get('bg_domain_updates'):
|
||||||
@ -1080,6 +1082,7 @@ def api_server_sub_forward(subpath):
|
|||||||
|
|
||||||
@api_bp.route('/servers/<string:server_id>/zones', methods=['POST'])
|
@api_bp.route('/servers/<string:server_id>/zones', methods=['POST'])
|
||||||
@apikey_auth
|
@apikey_auth
|
||||||
|
@apikey_can_create_domain
|
||||||
def api_create_zone(server_id):
|
def api_create_zone(server_id):
|
||||||
resp = helper.forward_request()
|
resp = helper.forward_request()
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user