-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Allow clients to drop channel on close or blindly (#657)
* Add client side support for upcoming drop channel API * Address review comments * Add copyright blurb
- Loading branch information
1 parent
f8c8e3f
commit ec5cf9b
Showing
13 changed files
with
443 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
89 changes: 89 additions & 0 deletions
89
src/main/java/net/snowflake/ingest/streaming/DropChannelRequest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
/* | ||
* Copyright (c) 2024 Snowflake Computing Inc. All rights reserved. | ||
*/ | ||
|
||
package net.snowflake.ingest.streaming; | ||
|
||
import net.snowflake.ingest.utils.Utils; | ||
|
||
/** A class that is used to drop a {@link SnowflakeStreamingIngestChannel} */ | ||
public class DropChannelRequest { | ||
// Name of the channel | ||
private final String channelName; | ||
|
||
// Name of the database that the channel belongs to | ||
private final String dbName; | ||
|
||
// Name of the schema that the channel belongs to | ||
private final String schemaName; | ||
|
||
// Name of the table that the channel belongs to | ||
private final String tableName; | ||
|
||
public static DropChannelRequestBuilder builder(String channelName) { | ||
return new DropChannelRequestBuilder(channelName); | ||
} | ||
|
||
/** A builder class to build a DropChannelRequest */ | ||
public static class DropChannelRequestBuilder { | ||
private final String channelName; | ||
private String dbName; | ||
private String schemaName; | ||
private String tableName; | ||
|
||
public DropChannelRequestBuilder(String channelName) { | ||
this.channelName = channelName; | ||
} | ||
|
||
public DropChannelRequestBuilder setDBName(String dbName) { | ||
this.dbName = dbName; | ||
return this; | ||
} | ||
|
||
public DropChannelRequestBuilder setSchemaName(String schemaName) { | ||
this.schemaName = schemaName; | ||
return this; | ||
} | ||
|
||
public DropChannelRequestBuilder setTableName(String tableName) { | ||
this.tableName = tableName; | ||
return this; | ||
} | ||
|
||
public DropChannelRequest build() { | ||
return new DropChannelRequest(this); | ||
} | ||
} | ||
|
||
public DropChannelRequest(DropChannelRequestBuilder builder) { | ||
Utils.assertStringNotNullOrEmpty("channel name", builder.channelName); | ||
Utils.assertStringNotNullOrEmpty("database name", builder.dbName); | ||
Utils.assertStringNotNullOrEmpty("schema name", builder.schemaName); | ||
Utils.assertStringNotNullOrEmpty("table name", builder.tableName); | ||
|
||
this.channelName = builder.channelName; | ||
this.dbName = builder.dbName; | ||
this.schemaName = builder.schemaName; | ||
this.tableName = builder.tableName; | ||
} | ||
|
||
public String getDBName() { | ||
return this.dbName; | ||
} | ||
|
||
public String getSchemaName() { | ||
return this.schemaName; | ||
} | ||
|
||
public String getTableName() { | ||
return this.tableName; | ||
} | ||
|
||
public String getChannelName() { | ||
return this.channelName; | ||
} | ||
|
||
public String getFullyQualifiedTableName() { | ||
return String.format("%s.%s.%s", this.dbName, this.schemaName, this.tableName); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
72 changes: 72 additions & 0 deletions
72
src/main/java/net/snowflake/ingest/streaming/internal/DropChannelResponse.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
/* | ||
* Copyright (c) 2024 Snowflake Computing Inc. All rights reserved. | ||
*/ | ||
|
||
package net.snowflake.ingest.streaming.internal; | ||
|
||
import com.fasterxml.jackson.annotation.JsonProperty; | ||
|
||
/** Response for a {@link net.snowflake.ingest.streaming.DropChannelRequest}. */ | ||
class DropChannelResponse extends StreamingIngestResponse { | ||
private Long statusCode; | ||
private String message; | ||
private String dbName; | ||
private String schemaName; | ||
private String tableName; | ||
private String channelName; | ||
|
||
@JsonProperty("status_code") | ||
void setStatusCode(Long statusCode) { | ||
this.statusCode = statusCode; | ||
} | ||
|
||
@Override | ||
Long getStatusCode() { | ||
return this.statusCode; | ||
} | ||
|
||
@JsonProperty("message") | ||
void setMessage(String message) { | ||
this.message = message; | ||
} | ||
|
||
String getMessage() { | ||
return this.message; | ||
} | ||
|
||
@JsonProperty("database") | ||
void setDBName(String dbName) { | ||
this.dbName = dbName; | ||
} | ||
|
||
String getDBName() { | ||
return this.dbName; | ||
} | ||
|
||
@JsonProperty("schema") | ||
void setSchemaName(String schemaName) { | ||
this.schemaName = schemaName; | ||
} | ||
|
||
String getSchemaName() { | ||
return this.schemaName; | ||
} | ||
|
||
@JsonProperty("table") | ||
void setTableName(String tableName) { | ||
this.tableName = tableName; | ||
} | ||
|
||
String getTableName() { | ||
return this.tableName; | ||
} | ||
|
||
@JsonProperty("channel") | ||
void setChannelName(String channelName) { | ||
this.channelName = channelName; | ||
} | ||
|
||
String getChannelName() { | ||
return this.channelName; | ||
} | ||
} |
23 changes: 23 additions & 0 deletions
23
src/main/java/net/snowflake/ingest/streaming/internal/DropChannelVersionRequest.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
/* | ||
* Copyright (c) 2024 Snowflake Computing Inc. All rights reserved. | ||
*/ | ||
|
||
package net.snowflake.ingest.streaming.internal; | ||
|
||
import net.snowflake.ingest.streaming.DropChannelRequest; | ||
|
||
/** | ||
* Same as DropChannelRequest but allows specifying a client sequencer to drop a specific version. | ||
*/ | ||
class DropChannelVersionRequest extends DropChannelRequest { | ||
private final Long clientSequencer; | ||
|
||
public DropChannelVersionRequest(DropChannelRequestBuilder builder, long clientSequencer) { | ||
super(builder); | ||
this.clientSequencer = clientSequencer; | ||
} | ||
|
||
Long getClientSequencer() { | ||
return this.clientSequencer; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.