diff --git a/common.gypi b/common.gypi index 79a22ac0faca37..9d8f977e35e1a6 100644 --- a/common.gypi +++ b/common.gypi @@ -371,7 +371,7 @@ }], [ 'OS in "linux freebsd openbsd solaris aix"', { 'cflags': [ '-pthread' ], - 'ldflags': [ '-pthread' ], + 'ldflags': [ '-pthread', '-lcap' ], }], [ 'OS in "linux freebsd openbsd solaris android aix cloudabi"', { 'cflags': [ '-Wall', '-Wextra', '-Wno-unused-parameter', ], diff --git a/src/node_credentials.cc b/src/node_credentials.cc index 5d9ff4b0e22612..6af339a6f21c89 100644 --- a/src/node_credentials.cc +++ b/src/node_credentials.cc @@ -37,18 +37,18 @@ namespace credentials { #if !defined(__CloudABI__) && !defined(_WIN32) // Returns true if the current process has effective capabilities and the // passed-in capability is in that set. -bool HasCapability(int capability) { +bool HasCapability(cap_value_t capability) { DCHECK(cap_valid(capability)); - struct __user_cap_header_struct cap_header_data = { - _LINUX_CAPABILITY_VERSION_1, getpid() - }; - struct __user_cap_data_struct cap_data; - if (capget(&cap_header_data, &cap_data) == -1) { + cap_t cap = cap_get_proc(); + if (cap == nullptr) { return false; } + cap_flag_value_t cap_flag_value; + cap_get_flag(cap, capability, CAP_EFFECTIVE, &cap_flag_value); - return cap_data.effective & CAP_TO_MASK(capability); + cap_free(cap); + return cap_flag_value == 1; } #endif