YARN-11392 Audit Log missing in ClientRMService (#5250). Contributed by Beibei Zhao.
Signed-off-by: Chris Nauroth <cnauroth@apache.org>
(cherry picked from commit 9668a85d40
)
This commit is contained in:
parent
7190fcf713
commit
290dc7817c
@ -406,22 +406,11 @@ public GetApplicationReportResponse getApplicationReport(
|
|||||||
throw new ApplicationNotFoundException("Invalid application id: null");
|
throw new ApplicationNotFoundException("Invalid application id: null");
|
||||||
}
|
}
|
||||||
|
|
||||||
UserGroupInformation callerUGI;
|
UserGroupInformation callerUGI = getCallerUgi(applicationId,
|
||||||
try {
|
AuditConstants.GET_APP_REPORT);
|
||||||
callerUGI = UserGroupInformation.getCurrentUser();
|
|
||||||
} catch (IOException ie) {
|
|
||||||
LOG.info("Error getting UGI ", ie);
|
|
||||||
throw RPCUtil.getRemoteException(ie);
|
|
||||||
}
|
|
||||||
|
|
||||||
RMApp application = this.rmContext.getRMApps().get(applicationId);
|
RMApp application = verifyUserAccessForRMApp(applicationId, callerUGI,
|
||||||
if (application == null) {
|
AuditConstants.GET_APP_REPORT, ApplicationAccessType.VIEW_APP, false);
|
||||||
// If the RM doesn't have the application, throw
|
|
||||||
// ApplicationNotFoundException and let client to handle.
|
|
||||||
throw new ApplicationNotFoundException("Application with id '"
|
|
||||||
+ applicationId + "' doesn't exist in RM. Please check "
|
|
||||||
+ "that the job submission was successful.");
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean allowAccess = checkAccess(callerUGI, application.getUser(),
|
boolean allowAccess = checkAccess(callerUGI, application.getUser(),
|
||||||
ApplicationAccessType.VIEW_APP, application);
|
ApplicationAccessType.VIEW_APP, application);
|
||||||
@ -881,13 +870,8 @@ public GetClusterMetricsResponse getClusterMetrics(
|
|||||||
@Override
|
@Override
|
||||||
public GetApplicationsResponse getApplications(GetApplicationsRequest request)
|
public GetApplicationsResponse getApplications(GetApplicationsRequest request)
|
||||||
throws YarnException {
|
throws YarnException {
|
||||||
UserGroupInformation callerUGI;
|
UserGroupInformation callerUGI = getCallerUgi(null,
|
||||||
try {
|
AuditConstants.GET_APPLICATIONS_REQUEST);
|
||||||
callerUGI = UserGroupInformation.getCurrentUser();
|
|
||||||
} catch (IOException ie) {
|
|
||||||
LOG.info("Error getting UGI ", ie);
|
|
||||||
throw RPCUtil.getRemoteException(ie);
|
|
||||||
}
|
|
||||||
|
|
||||||
Set<String> applicationTypes = getLowerCasedAppTypes(request);
|
Set<String> applicationTypes = getLowerCasedAppTypes(request);
|
||||||
EnumSet<YarnApplicationState> applicationStates =
|
EnumSet<YarnApplicationState> applicationStates =
|
||||||
@ -1028,13 +1012,8 @@ public GetClusterNodesResponse getClusterNodes(GetClusterNodesRequest request)
|
|||||||
@Override
|
@Override
|
||||||
public GetQueueInfoResponse getQueueInfo(GetQueueInfoRequest request)
|
public GetQueueInfoResponse getQueueInfo(GetQueueInfoRequest request)
|
||||||
throws YarnException {
|
throws YarnException {
|
||||||
UserGroupInformation callerUGI;
|
UserGroupInformation callerUGI = getCallerUgi(null,
|
||||||
try {
|
AuditConstants.GET_QUEUE_INFO_REQUEST);
|
||||||
callerUGI = UserGroupInformation.getCurrentUser();
|
|
||||||
} catch (IOException ie) {
|
|
||||||
LOG.info("Error getting UGI ", ie);
|
|
||||||
throw RPCUtil.getRemoteException(ie);
|
|
||||||
}
|
|
||||||
|
|
||||||
GetQueueInfoResponse response =
|
GetQueueInfoResponse response =
|
||||||
recordFactory.newRecordInstance(GetQueueInfoResponse.class);
|
recordFactory.newRecordInstance(GetQueueInfoResponse.class);
|
||||||
@ -1700,16 +1679,10 @@ public SignalContainerResponse signalToContainer(
|
|||||||
SignalContainerRequest request) throws YarnException, IOException {
|
SignalContainerRequest request) throws YarnException, IOException {
|
||||||
ContainerId containerId = request.getContainerId();
|
ContainerId containerId = request.getContainerId();
|
||||||
|
|
||||||
UserGroupInformation callerUGI;
|
|
||||||
try {
|
|
||||||
callerUGI = UserGroupInformation.getCurrentUser();
|
|
||||||
} catch (IOException ie) {
|
|
||||||
LOG.info("Error getting UGI ", ie);
|
|
||||||
throw RPCUtil.getRemoteException(ie);
|
|
||||||
}
|
|
||||||
|
|
||||||
ApplicationId applicationId = containerId.getApplicationAttemptId().
|
ApplicationId applicationId = containerId.getApplicationAttemptId().
|
||||||
getApplicationId();
|
getApplicationId();
|
||||||
|
UserGroupInformation callerUGI = getCallerUgi(applicationId,
|
||||||
|
AuditConstants.SIGNAL_CONTAINER);
|
||||||
RMApp application = this.rmContext.getRMApps().get(applicationId);
|
RMApp application = this.rmContext.getRMApps().get(applicationId);
|
||||||
if (application == null) {
|
if (application == null) {
|
||||||
RMAuditLogger.logFailure(callerUGI.getUserName(),
|
RMAuditLogger.logFailure(callerUGI.getUserName(),
|
||||||
|
@ -57,6 +57,7 @@ public static class AuditConstants {
|
|||||||
public static final String GET_APP_PRIORITY = "Get Application Priority";
|
public static final String GET_APP_PRIORITY = "Get Application Priority";
|
||||||
public static final String GET_APP_QUEUE = "Get Application Queue";
|
public static final String GET_APP_QUEUE = "Get Application Queue";
|
||||||
public static final String GET_APP_ATTEMPTS = "Get Application Attempts";
|
public static final String GET_APP_ATTEMPTS = "Get Application Attempts";
|
||||||
|
public static final String GET_APP_REPORT = "Get Application Report";
|
||||||
public static final String GET_APP_ATTEMPT_REPORT
|
public static final String GET_APP_ATTEMPT_REPORT
|
||||||
= "Get Application Attempt Report";
|
= "Get Application Attempt Report";
|
||||||
public static final String GET_CONTAINERS = "Get Containers";
|
public static final String GET_CONTAINERS = "Get Containers";
|
||||||
|
Loading…
Reference in New Issue
Block a user