Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AbfsoutputStream refactor #118

Merged
merged 88 commits into from
Jun 25, 2024
Merged
Show file tree
Hide file tree
Changes from 84 commits
Commits
Show all changes
88 commits
Select commit Hold shift + click to select a range
15fdd85
AbfsHandlers
anmolanmol1234 May 22, 2024
2e019a9
AbfsOutputStream changes
anmolanmol1234 May 27, 2024
6969b23
Synchronization issues
anmolanmol1234 May 28, 2024
1942e61
Small write
anmolanmol1234 May 28, 2024
2adae79
Javadocs update
anmolanmol1234 May 28, 2024
f653b07
Javadocs
anmolanmol1234 May 28, 2024
ea5b71e
Javadocs
anmolanmol1234 May 28, 2024
e9d93dd
appendblob
anmolanmol1234 May 29, 2024
095bc4b
merge conflict
anmolanmol1234 May 29, 2024
48e5b8f
length 0
anmolanmol1234 May 29, 2024
da83b8a
close AbfsBlock
anmolanmol1234 May 29, 2024
4d2dc86
add new error
anmolanmol1234 May 29, 2024
20002d5
Add ingress handler to tracing context
anmolanmol1234 May 30, 2024
54535fd
logging
anmolanmol1234 May 30, 2024
75fd3a1
Add AppendBlob support for FNS
anmolanmol1234 May 30, 2024
6dba239
close data block for append blob
anmolanmol1234 May 31, 2024
bbe2230
Add marker blob creation logic
anmolanmol1234 May 31, 2024
96b9f46
changes for create
anmolanmol1234 May 31, 2024
a84207a
extra line
anmolanmol1234 May 31, 2024
0e373c5
Append fixes
anmolanmol1234 Jun 4, 2024
450dc14
parent changes
anmolanmol1234 Jun 5, 2024
2520979
Back merge
anmolanmol1234 Jun 5, 2024
f0bac54
merge conflicts
anmolanmol1234 Jun 5, 2024
39790f6
Client orchestration
anmolanmol1234 Jun 5, 2024
2e3a9e4
test fix
anmolanmol1234 Jun 5, 2024
68ca484
test fixes
anmolanmol1234 Jun 5, 2024
eb1e655
test fix
anmolanmol1234 Jun 5, 2024
c39c389
Fix for switching handler
anmolanmol1234 Jun 5, 2024
f1318e6
final type
anmolanmol1234 Jun 5, 2024
b54cf97
tests
anmolanmol1234 Jun 6, 2024
0a09c50
tests
anmolanmol1234 Jun 6, 2024
700a534
adding test
anmolanmol1234 Jun 6, 2024
a1db4e9
Add lease test case
anmolanmol1234 Jun 6, 2024
41e4d03
fix test
anmolanmol1234 Jun 6, 2024
3d4584b
fix for all ingress types
anmolanmol1234 Jun 7, 2024
337830c
Merge branch 'azureBlobClient' of https://github.com/ABFSDriver/AbfsH…
anmolanmol1234 Jun 7, 2024
5afa789
Merge branch 'azureBlobClient' of https://github.com/ABFSDriver/AbfsH…
anmolanmol1234 Jun 7, 2024
98e2b29
add create tests
anmolanmol1234 Jun 7, 2024
27a70e6
add tests
anmolanmol1234 Jun 7, 2024
bdc3f66
Merge pull request #106 from ABFSDriver/azureBlobClient
anujmodi2021 Jun 10, 2024
530b2b3
Merge branch 'apache:trunk' into wasbDeprecation_Dev
anmolanmol1234 Jun 10, 2024
e702d1c
Merge branch 'wasbDeprecation_Dev' of https://github.com/ABFSDriver/A…
anmolanmol1234 Jun 10, 2024
499fc72
append blob fix
anmolanmol1234 Jun 10, 2024
66cb16d
fix
anmolanmol1234 Jun 11, 2024
f8a9553
fix for checksum
anmolanmol1234 Jun 11, 2024
16d8bb5
lease fix
anmolanmol1234 Jun 11, 2024
764691a
mocking resolution + getConnOutputStream to throw exception
saxenapranav Jun 11, 2024
6ae8457
casting not needed
anmolanmol1234 Jun 11, 2024
63f11ed
fix shared key test
anmolanmol1234 Jun 11, 2024
d0da028
fix test
anmolanmol1234 Jun 12, 2024
8d0ffca
fix stats
anmolanmol1234 Jun 12, 2024
04ddd14
fix create stats test
anmolanmol1234 Jun 12, 2024
ba8bd15
fix test for SAS
anmolanmol1234 Jun 12, 2024
ecc5f83
merge trunk
anmolanmol1234 Jun 13, 2024
d3f853e
merge conflicts
anmolanmol1234 Jun 13, 2024
68e4da2
CPK for HNS Blob
anmolanmol1234 Jun 13, 2024
a000d21
HNS cpk blob
anmolanmol1234 Jun 13, 2024
3d6eda0
fix test
anmolanmol1234 Jun 13, 2024
deab6f7
Fix SAS
anmolanmol1234 Jun 14, 2024
1cd0402
Merge branch 'CPKHNSIngressBlob' of https://github.com/ABFSDriver/Abf…
anmolanmol1234 Jun 14, 2024
f8483e8
review comments
anmolanmol1234 Jun 14, 2024
7e198c2
changes in test
anmolanmol1234 Jun 14, 2024
5ed9a5e
make changes
anmolanmol1234 Jun 14, 2024
dbd7ca4
review comments
anmolanmol1234 Jun 17, 2024
7948e97
small write change in context
anmolanmol1234 Jun 17, 2024
1f5af7a
remove unused method
anmolanmol1234 Jun 17, 2024
091fab8
merge conflicts
anmolanmol1234 Jun 18, 2024
2fff127
create flow fix
anmolanmol1234 Jun 18, 2024
a847923
fix recursion
anmolanmol1234 Jun 18, 2024
63c060b
fix call
anmolanmol1234 Jun 18, 2024
513aa52
fix test
anmolanmol1234 Jun 18, 2024
f1c6261
review comments
anmolanmol1234 Jun 18, 2024
7c24072
createBlock synchronized
anmolanmol1234 Jun 18, 2024
b6e3f77
missed file
anmolanmol1234 Jun 18, 2024
9f03a9b
review comments
anmolanmol1234 Jun 19, 2024
43e7da1
Merge branch 'azureBlobClient' of https://github.com/ABFSDriver/AbfsH…
anmolanmol1234 Jun 19, 2024
f0c233f
take care of switching only once
anmolanmol1234 Jun 19, 2024
327fb1f
remove small write check
anmolanmol1234 Jun 19, 2024
e4ce98c
Handle fallback effectively
anmolanmol1234 Jun 20, 2024
3b087dc
missed file
anmolanmol1234 Jun 20, 2024
ff8e959
change to getter
anmolanmol1234 Jun 21, 2024
f658a68
fallback for appendblob
anmolanmol1234 Jun 21, 2024
925fcf0
correct try catch
anmolanmol1234 Jun 21, 2024
887fa4d
commit for metrics test
anmolanmol1234 Jun 21, 2024
b41b3d9
review comments
anmolanmol1234 Jun 24, 2024
942ff29
changes for block manager
anmolanmol1234 Jun 24, 2024
4fce8b4
no param needed
anmolanmol1234 Jun 24, 2024
1414b60
revert no param
anmolanmol1234 Jun 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -478,9 +478,9 @@ public boolean isDfsToBlobFallbackEnabled() {

public void validateConfiguredServiceType(boolean isHNSEnabled) throws InvalidConfigurationValueException {
// Todo: [FnsOverBlob] - Remove this check, Failing FS Init with Blob Endpoint Until FNS over Blob is ready.
if (getFsConfiguredServiceType() == AbfsServiceType.BLOB) {
throw new InvalidConfigurationValueException(FS_DEFAULT_NAME_KEY, "Blob Endpoint Support not yet available");
}
// if (getFsConfiguredServiceType() == AbfsServiceType.BLOB) {
// throw new InvalidConfigurationValueException(FS_DEFAULT_NAME_KEY, "Blob Endpoint Support not yet available");
// }
if (isHNSEnabled && getConfiguredServiceTypeForFNSAccounts() == AbfsServiceType.BLOB) {
throw new InvalidConfigurationValueException(
FS_AZURE_FNS_ACCOUNT_SERVICE_TYPE, "Cannot be BLOB for HNS Account");
Expand Down Expand Up @@ -758,6 +758,10 @@ public boolean isSmallWriteOptimizationEnabled() {
return this.enableSmallWriteOptimization;
}

public void setSmallWriteOptimization(final boolean enableSmallWriteOptimization) {
this.enableSmallWriteOptimization = enableSmallWriteOptimization;
}

public boolean readSmallFilesCompletely() {
return this.readSmallFilesCompletely;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -607,9 +607,10 @@ public OutputStream createFile(final Path path,
final FsPermission permission, final FsPermission umask,
TracingContext tracingContext) throws IOException {
try (AbfsPerfInfo perfInfo = startTracking("createFile", "createPath")) {
AbfsClient createClient = getClientHandler().getIngressClient();
boolean isNamespaceEnabled = getIsNamespaceEnabled(tracingContext);
LOG.debug("createFile filesystem: {} path: {} overwrite: {} permission: {} umask: {} isNamespaceEnabled: {}",
getClient().getFileSystem(),
createClient.getFileSystem(),
path,
overwrite,
permission,
Expand All @@ -632,9 +633,9 @@ public OutputStream createFile(final Path path,
}

final ContextEncryptionAdapter contextEncryptionAdapter;
if (getClient().getEncryptionType() == EncryptionType.ENCRYPTION_CONTEXT) {
if (createClient.getEncryptionType() == EncryptionType.ENCRYPTION_CONTEXT) {
contextEncryptionAdapter = new ContextProviderEncryptionAdapter(
getClient().getEncryptionContextProvider(), getRelativePath(path));
createClient.getEncryptionContextProvider(), getRelativePath(path));
} else {
contextEncryptionAdapter = NoContextEncryptionAdapter.getInstance();
}
Expand All @@ -649,27 +650,28 @@ public OutputStream createFile(final Path path,
);

} else {
op = getClient().createPath(relativePath, true,
op = createClient.createPath(relativePath, true,
overwrite,
new Permissions(isNamespaceEnabled, permission, umask),
isAppendBlob,
null,
contextEncryptionAdapter,
tracingContext);
tracingContext, isNamespaceEnabled);

}
perfInfo.registerResult(op.getResult()).registerSuccess(true);

AbfsLease lease = maybeCreateLease(relativePath, tracingContext);

String eTag = extractEtagHeader(op.getResult());
return new AbfsOutputStream(
populateAbfsOutputStreamContext(
isAppendBlob,
lease,
getClient(),
getClientHandler(),
statistics,
relativePath,
0,
eTag,
contextEncryptionAdapter,
tracingContext));
}
Expand All @@ -692,13 +694,13 @@ private AbfsRestOperation conditionalCreateOverwriteFile(final String relativePa
final ContextEncryptionAdapter contextEncryptionAdapter,
final TracingContext tracingContext) throws IOException {
AbfsRestOperation op;

AbfsClient createClient = getClientHandler().getIngressClient();
try {
// Trigger a create with overwrite=false first so that eTag fetch can be
// avoided for cases when no pre-existing file is present (major portion
// of create file traffic falls into the case of no pre-existing file).
op = getClient().createPath(relativePath, true, false, permissions,
isAppendBlob, null, contextEncryptionAdapter, tracingContext);
op = createClient.createPath(relativePath, true, false, permissions,
isAppendBlob, null, contextEncryptionAdapter, tracingContext, getIsNamespaceEnabled(tracingContext));

} catch (AbfsRestOperationException e) {
if (e.getStatusCode() == HttpURLConnection.HTTP_CONFLICT) {
Expand All @@ -722,8 +724,8 @@ private AbfsRestOperation conditionalCreateOverwriteFile(final String relativePa

try {
// overwrite only if eTag matches with the file properties fetched befpre
op = getClient().createPath(relativePath, true, true, permissions,
isAppendBlob, eTag, contextEncryptionAdapter, tracingContext);
op = createClient.createPath(relativePath, true, true, permissions,
isAppendBlob, eTag, contextEncryptionAdapter, tracingContext, getIsNamespaceEnabled(tracingContext));
} catch (AbfsRestOperationException ex) {
if (ex.getStatusCode() == HttpURLConnection.HTTP_PRECON_FAILED) {
// Is a parallel access case, as file with eTag was just queried
Expand All @@ -750,7 +752,7 @@ private AbfsRestOperation conditionalCreateOverwriteFile(final String relativePa
*
* @param isAppendBlob is Append blob support enabled?
* @param lease instance of AbfsLease for this AbfsOutputStream.
* @param client AbfsClient.
* @param clientHandler AbfsClientHandler.
* @param statistics FileSystem statistics.
* @param path Path for AbfsOutputStream.
* @param position Position or offset of the file being opened, set to 0
Expand All @@ -762,10 +764,11 @@ private AbfsRestOperation conditionalCreateOverwriteFile(final String relativePa
private AbfsOutputStreamContext populateAbfsOutputStreamContext(
boolean isAppendBlob,
AbfsLease lease,
AbfsClient client,
AbfsClientHandler clientHandler,
FileSystem.Statistics statistics,
String path,
long position,
String eTag,
ContextEncryptionAdapter contextEncryptionAdapter,
TracingContext tracingContext) {
int bufferSize = abfsConfiguration.getWriteBufferSize();
Expand All @@ -786,24 +789,28 @@ private AbfsOutputStreamContext populateAbfsOutputStreamContext(
.withEncryptionAdapter(contextEncryptionAdapter)
.withBlockFactory(getBlockFactory())
.withBlockOutputActiveBlocks(blockOutputActiveBlocks)
.withClient(getClient())
.withClientHandler(clientHandler)
.withPosition(position)
.withFsStatistics(statistics)
.withPath(path)
.withExecutorService(new SemaphoredDelegatingExecutor(boundedThreadPool,
blockOutputActiveBlocks, true))
.withTracingContext(tracingContext)
.withAbfsBackRef(fsBackRef)
.withIngressServiceType(abfsConfiguration.getIngressServiceType())
anujmodi2021 marked this conversation as resolved.
Show resolved Hide resolved
.withDFSToBlobFallbackEnabled(abfsConfiguration.isDfsToBlobFallbackEnabled())
.withETag(eTag)
.build();
}

public void createDirectory(final Path path, final FsPermission permission,
final FsPermission umask, TracingContext tracingContext)
throws IOException {
try (AbfsPerfInfo perfInfo = startTracking("createDirectory", "createPath")) {
AbfsClient createClient = getClientHandler().getIngressClient();
boolean isNamespaceEnabled = getIsNamespaceEnabled(tracingContext);
LOG.debug("createDirectory filesystem: {} path: {} permission: {} umask: {} isNamespaceEnabled: {}",
getClient().getFileSystem(),
createClient.getFileSystem(),
path,
permission,
umask,
Expand All @@ -813,8 +820,8 @@ public void createDirectory(final Path path, final FsPermission permission,
!isNamespaceEnabled || abfsConfiguration.isEnabledMkdirOverwrite();
Permissions permissions = new Permissions(isNamespaceEnabled,
permission, umask);
final AbfsRestOperation op = getClient().createPath(getRelativePath(path),
false, overwrite, permissions, false, null, null, tracingContext);
final AbfsRestOperation op = createClient.createPath(getRelativePath(path),
false, overwrite, permissions, false, null, null, tracingContext, isNamespaceEnabled);
perfInfo.registerResult(op.getResult()).registerSuccess(true);
}
}
Expand Down Expand Up @@ -949,6 +956,7 @@ public OutputStream openFileForWrite(final Path path,
overwrite);

String relativePath = getRelativePath(path);
AbfsClient writeClient = getClientHandler().getIngressClient();

final AbfsRestOperation op = getClient()
.getPathStatus(relativePath, false, tracingContext, null);
Expand All @@ -961,7 +969,7 @@ public OutputStream openFileForWrite(final Path path,
throw new AbfsRestOperationException(
AzureServiceErrorCode.PATH_NOT_FOUND.getStatusCode(),
AzureServiceErrorCode.PATH_NOT_FOUND.getErrorCode(),
"openFileForRead must be used with files and not directories",
"openFileForWrite must be used with files and not directories",
null);
}

Expand All @@ -975,8 +983,9 @@ public OutputStream openFileForWrite(final Path path,
}

AbfsLease lease = maybeCreateLease(relativePath, tracingContext);
final String eTag = extractEtagHeader(op.getResult());
final ContextEncryptionAdapter contextEncryptionAdapter;
if (getClient().getEncryptionType() == EncryptionType.ENCRYPTION_CONTEXT) {
if (writeClient.getEncryptionType() == EncryptionType.ENCRYPTION_CONTEXT) {
final String encryptionContext = op.getResult()
.getResponseHeader(
HttpHeaderConfigurations.X_MS_ENCRYPTION_CONTEXT);
Expand All @@ -985,20 +994,20 @@ public OutputStream openFileForWrite(final Path path,
"File doesn't have encryptionContext.");
}
contextEncryptionAdapter = new ContextProviderEncryptionAdapter(
getClient().getEncryptionContextProvider(), getRelativePath(path),
writeClient.getEncryptionContextProvider(), getRelativePath(path),
encryptionContext.getBytes(StandardCharsets.UTF_8));
} else {
contextEncryptionAdapter = NoContextEncryptionAdapter.getInstance();
}

return new AbfsOutputStream(
populateAbfsOutputStreamContext(
isAppendBlob,
lease,
getClient(),
getClientHandler(),
statistics,
relativePath,
offset,
eTag,
contextEncryptionAdapter,
tracingContext));
}
Expand Down Expand Up @@ -1442,7 +1451,7 @@ public void modifyAclEntries(final Path path, final List<AclEntry> aclSpec,
final AbfsRestOperation op = getClient()
.getAclStatus(relativePath, useUpn, tracingContext);
perfInfoGet.registerResult(op.getResult());
final String eTag = op.getResult().getResponseHeader(HttpHeaderConfigurations.ETAG);
final String eTag = extractEtagHeader(op.getResult());

final Map<String, String> aclEntries = AbfsAclHelper.deserializeAclSpec(op.getResult().getResponseHeader(HttpHeaderConfigurations.X_MS_ACL));

Expand Down Expand Up @@ -1485,7 +1494,7 @@ public void removeAclEntries(final Path path, final List<AclEntry> aclSpec,
final AbfsRestOperation op = getClient()
.getAclStatus(relativePath, isUpnFormat, tracingContext);
perfInfoGet.registerResult(op.getResult());
final String eTag = op.getResult().getResponseHeader(HttpHeaderConfigurations.ETAG);
final String eTag = extractEtagHeader(op.getResult());

final Map<String, String> aclEntries = AbfsAclHelper.deserializeAclSpec(op.getResult().getResponseHeader(HttpHeaderConfigurations.X_MS_ACL));

Expand Down Expand Up @@ -1523,7 +1532,7 @@ public void removeDefaultAcl(final Path path, TracingContext tracingContext)
final AbfsRestOperation op = getClient()
.getAclStatus(relativePath, tracingContext);
perfInfoGet.registerResult(op.getResult());
final String eTag = op.getResult().getResponseHeader(HttpHeaderConfigurations.ETAG);
final String eTag = extractEtagHeader(op.getResult());
final Map<String, String> aclEntries = AbfsAclHelper.deserializeAclSpec(op.getResult().getResponseHeader(HttpHeaderConfigurations.X_MS_ACL));
final Map<String, String> defaultAclEntries = new HashMap<>();

Expand Down Expand Up @@ -1567,7 +1576,7 @@ public void removeAcl(final Path path, TracingContext tracingContext)
final AbfsRestOperation op = getClient()
.getAclStatus(relativePath, tracingContext);
perfInfoGet.registerResult(op.getResult());
final String eTag = op.getResult().getResponseHeader(HttpHeaderConfigurations.ETAG);
final String eTag = extractEtagHeader(op.getResult());

final Map<String, String> aclEntries = AbfsAclHelper.deserializeAclSpec(op.getResult().getResponseHeader(HttpHeaderConfigurations.X_MS_ACL));
final Map<String, String> newAclEntries = new HashMap<>();
Expand Down Expand Up @@ -1613,7 +1622,7 @@ public void setAcl(final Path path, final List<AclEntry> aclSpec,
final AbfsRestOperation op = getClient()
.getAclStatus(relativePath, isUpnFormat, tracingContext);
perfInfoGet.registerResult(op.getResult());
final String eTag = op.getResult().getResponseHeader(HttpHeaderConfigurations.ETAG);
final String eTag = extractEtagHeader(op.getResult());

final Map<String, String> getAclEntries = AbfsAclHelper.deserializeAclSpec(op.getResult().getResponseHeader(HttpHeaderConfigurations.X_MS_ACL));

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ public final class AbfsHttpConstants {
public static final String BLOCK_BLOB_TYPE = "BlockBlob";
public static final String BLOCK_TYPE_COMMITTED = "committed";
public static final String TOKEN_VERSION = "2";
public static final String APPEND_BLOCK = "appendblock";

public static final String JAVA_VENDOR = "java.vendor";
public static final String JAVA_VERSION = "java.version";
Expand Down Expand Up @@ -150,6 +151,7 @@ public enum ApiVersion {

DEC_12_2019("2019-12-12"),
APR_10_2021("2021-04-10"),
AUG_06_2021("2021-08-06"),
anujmodi2021 marked this conversation as resolved.
Show resolved Hide resolved
AUG_03_2023("2023-08-03");

private final String xMsApiVersion;
Expand All @@ -164,7 +166,7 @@ public String toString() {
}

public static ApiVersion getCurrentVersion() {
return DEC_12_2019;
return AUG_03_2023;
}
}

Expand Down Expand Up @@ -213,7 +215,11 @@ public static ApiVersion getCurrentVersion() {
public static final String XML_TAG_BLOB_ERROR_MESSAGE_END_XML = "</Message>";
public static final String XML_TAG_COMMITTED_BLOCKS = "CommittedBlocks";
public static final String XML_TAG_BLOCK_NAME = "Block";

public static final String XML_VERSION = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n";
public static final String BLOCK_LIST_START_TAG = "<BlockList>\n";
public static final String BLOCK_LIST_END_TAG = "</BlockList>\n";
public static final String LATEST_BLOCK_FORMAT = "<Latest>%s</Latest>\n";
public static final String PUT_BLOCK_LIST = "PutBlockList";
/**
* List of configurations that are related to Customer-Provided-Keys.
* <ol>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -168,5 +168,7 @@ public final class FileSystemConfigurations {
public static final int HUNDRED = 100;
public static final long THOUSAND = 1000L;

public static final int BLOCK_ID_LENGTH = 60;
anujmodi2021 marked this conversation as resolved.
Show resolved Hide resolved

private FileSystemConfigurations() {}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@

/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package org.apache.hadoop.fs.azurebfs.contracts.exceptions;

import org.apache.hadoop.classification.InterfaceAudience;
import org.apache.hadoop.classification.InterfaceStability;

@InterfaceAudience.Public
@InterfaceStability.Evolving
public final class InvalidIngressServiceException
extends AbfsRestOperationException {
public InvalidIngressServiceException(final int statusCode,
final String errorCode,
final String errorMessage,
final Exception innerException) {
super(statusCode, errorCode, errorMessage, innerException);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -130,4 +130,12 @@ public void setRetryDueToExpect(boolean retryDueToExpect) {
public void setExpectHeaderEnabled(boolean expectHeaderEnabled) {
isExpectHeaderEnabled = expectHeaderEnabled;
}

public void setBlockId(final String blockId) {
this.blockId = blockId;
}

public void setEtag(final String eTag) {
this.eTag = eTag;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,8 @@ public enum AzureServiceErrorCode {
ACCOUNT_REQUIRES_HTTPS("AccountRequiresHttps", HttpURLConnection.HTTP_BAD_REQUEST, null),
MD5_MISMATCH("Md5Mismatch", HttpURLConnection.HTTP_BAD_REQUEST,
"The MD5 value specified in the request did not match with the MD5 value calculated by the server."),
BLOB_OPERATION_NOT_SUPPORTED("BlobOperationNotSupported", HttpURLConnection.HTTP_CONFLICT, null),
INVALID_APPEND_OPERATION("InvalidAppendOperation", HttpURLConnection.HTTP_CONFLICT, null),
UNKNOWN(null, -1, null);

private final String errorCode;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ public interface SASTokenProvider {
String GET_STATUS_OPERATION = "get-status";
String GET_PROPERTIES_OPERATION = "get-properties";
String LIST_OPERATION = "list";
String LIST_BLOB_OPERATION = "list-blob";
String READ_OPERATION = "read";
String RENAME_SOURCE_OPERATION = "rename-source";
String RENAME_DESTINATION_OPERATION = "rename-destination";
Expand All @@ -49,6 +50,7 @@ public interface SASTokenProvider {
String SET_PERMISSION_OPERATION = "set-permission";
String SET_PROPERTIES_OPERATION = "set-properties";
String WRITE_OPERATION = "write";
String APPEND_BLOCK_OPERATION = "append-block";

/**
* Initialize authorizer for Azure Blob File System.
Expand Down
Loading
Loading