[ 
https://issues.apache.org/jira/browse/HADOOP-19795?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=18055113#comment-18055113
 ] 

ASF GitHub Bot commented on HADOOP-19795:
-----------------------------------------

anmolanmol1234 commented on code in PR #8212:
URL: https://github.com/apache/hadoop/pull/8212#discussion_r2741002477


##########
hadoop-tools/hadoop-azure/src/main/java/org/apache/hadoop/fs/azurebfs/services/AbfsInputStream.java:
##########
@@ -561,11 +578,55 @@ protected int readInternal(final long position, final 
byte[] b, final int offset
     }
   }
 
+   String getRelativePath(final Path path) {
+    Preconditions.checkNotNull(path, "path");
+    String relPath = path.toUri().getPath();
+    if (relPath.isEmpty()) {
+      // This means that path passed by user is absolute path of root without 
"/" at end.
+      relPath = ROOT_PATH;
+    }
+    return relPath;
+  }
+
+  /**
+   * Creates an exception indicating that a read operation was attempted on a 
directory.
+   *
+   * @return an {@link AbfsRestOperationException} indicating the operation is 
not permitted on a directory
+   */
+  private IOException directoryReadException() {
+    return new AbfsRestOperationException(
+            AzureServiceErrorCode.PATH_NOT_FOUND.getStatusCode(),
+            AzureServiceErrorCode.PATH_NOT_FOUND.getErrorCode(),
+            readOnDirectoryErrorMsg,
+            null);
+  }
+
+  /**
+   * Checks if the current path is a directory (for both implicit and 
explicit) in FNS account.
+   * If the path is a directory, throws an exception indicating that read 
operations are not permitted.
+   *
+   * @throws IOException if the path is a directory or if there is an error 
accessing the path status
+   */
+  private void checkIfDirPathInFNS() throws IOException {
+    AbfsHttpOperation gpsOp = client.getPathStatus(
+            getRelativePath(new Path(path)),
+            false,
+            tracingContext,
+            contextEncryptionAdapter).getResult();
+
+    String resourceType =

Review Comment:
   use client.checkIsDir method





> ABFS: GetPathStatus Optimization on OpenFileForRead
> ---------------------------------------------------
>
>                 Key: HADOOP-19795
>                 URL: https://issues.apache.org/jira/browse/HADOOP-19795
>             Project: Hadoop Common
>          Issue Type: Task
>          Components: fs/azure
>    Affects Versions: 3.4.1, 3.4.2
>            Reporter: Manika Joshi
>            Assignee: Manika Joshi
>            Priority: Major
>              Labels: pull-request-available
>
> We do a getPathStatus call during file open for read. This call is primarily 
> used to fetch the file’s metadata properties before the actual read begins. 
> We are now introducing an optional, config-driven read flow that avoids the 
> getPathStatus call during open and instead derives required metadata from the 
> read response itself. 



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to