Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
6 changes: 3 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 +12,13 @@ jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@v5
with:
fetch-depth: 2
- name: Set up JDK
uses: actions/setup-java@v4
with:
distribution: 'adopt'
java-version: '11'
distribution: 'temurin'
java-version: '21'
- name: Build with Maven
run: mvn -B -q clean install
3 changes: 2 additions & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<parent>
<groupId>com.hubspot</groupId>
<artifactId>basepom</artifactId>
<version>63.4</version>
<version>63.8</version>
</parent>

<groupId>com.hubspot.slack</groupId>
Expand All @@ -27,6 +27,7 @@
<properties>
<horizon.version>0.1.1</horizon.version>
<dep.netty3.version>3.10.6.Final</dep.netty3.version>
<dep.plugin.spotbugs.version>4.9.3.2</dep.plugin.spotbugs.version>
</properties>

<dependencyManagement>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -643,7 +643,13 @@ public enum SlackMethods implements SlackMethod {
views_open(MethodWriteMode.WRITE, RateLimitingTiers.TIER_4, JsonStatus.ACCEPTS_JSON),
views_update(MethodWriteMode.WRITE, RateLimitingTiers.TIER_4, JsonStatus.ACCEPTS_JSON),
views_push(MethodWriteMode.WRITE, RateLimitingTiers.TIER_4, JsonStatus.ACCEPTS_JSON),
views_publish(MethodWriteMode.WRITE, RateLimitingTiers.TIER_4, JsonStatus.ACCEPTS_JSON);
views_publish(MethodWriteMode.WRITE, RateLimitingTiers.TIER_4, JsonStatus.ACCEPTS_JSON),

entity_presentDetails(
MethodWriteMode.WRITE,
RateLimitingTiers.TIER_3,
JsonStatus.ACCEPTS_JSON
);

private final MethodWriteMode writeMode;
private final RateLimitingTier rateLimitingTier;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package com.hubspot.slack.client.methods.params.chat.workobject;

import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.hubspot.slack.client.methods.params.chat.workobject.entity.EntityPayload;
import com.hubspot.slack.client.methods.params.chat.workobject.serializers.EntityTypeSerializer;

public interface WorkObjectBase {
@JsonSerialize(using = EntityTypeSerializer.class)
EntityType getEntityType();

EntityPayload getEntityPayload();

String getUrl();

ExternalRef getExternalRef();
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,12 @@

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.entity.EntityPayload;
import com.hubspot.slack.client.methods.params.chat.workobject.serializers.EntityTypeSerializer;
import org.immutables.value.Value;

@Value.Immutable
@HubSpotStyle
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface WorkObjectIF {
public interface WorkObjectIF extends WorkObjectBase {
String getAppUnfurlUrl();
String getUrl();
ExternalRef getExternalRef();

@JsonSerialize(using = EntityTypeSerializer.class)
EntityType getEntityType();

EntityPayload getEntityPayload();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.hubspot.slack.client.methods.params.chat.workobject.actions;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import java.util.List;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface WorkObjectActionBlockIF {
List<WorkObjectAction> getPrimaryActions();
List<WorkObjectAction> getOverflowActions();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package com.hubspot.slack.client.methods.params.chat.workobject.actions;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import java.util.Optional;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface WorkObjectActionIF {
String getText();
String getActionId();
Optional<String> getValue();
Optional<WorkObjectActionStyle> getStyle();
Optional<String> getUrl();
Optional<String> getAccessibilityLabel();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package com.hubspot.slack.client.methods.params.chat.workobject.actions;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;

public enum WorkObjectActionStyle {
PRIMARY,
DANGER;

@JsonCreator
public static WorkObjectActionStyle parse(String result) {
return WorkObjectActionStyle.valueOf(result.toUpperCase());
}

@JsonValue
public String value() {
return name().toLowerCase();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.actions.WorkObjectActionBlock;
import com.hubspot.slack.client.methods.params.chat.workobject.entity.fields.EntityPayloadFields;
import java.util.List;
import java.util.Optional;
Expand All @@ -18,4 +19,5 @@ public interface EntityPayloadIF {
Optional<EntityPayloadFields> getFields();
List<EntityPayloadAttributesCustomField> getCustomFields();
List<String> getDisplayOrder();
WorkObjectActionBlock getActions();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
package com.hubspot.slack.client.methods.params.chat.workobject.entity;

import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.ExternalRef;
import com.hubspot.slack.client.models.events.SlackEvent;
import com.hubspot.slack.client.models.events.links.Link;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
@JsonDeserialize(as = SlackEntityDetails.class)
public interface SlackEntityDetailsIF extends SlackEvent {
String getTriggerId();

@JsonProperty("user")
String getUserId();

@JsonProperty("channel")
String getChannelId();

String getMessageTs();

ExternalRef getExternalRef();

Link getLink();
String getAppUnfurlUrl();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package com.hubspot.slack.client.methods.params.chat.workobject.flexpane;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.WorkObjectBase;
import org.immutables.value.Value;

@Value.Immutable
@HubSpotStyle
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface FlexPaneMetadataIF extends WorkObjectBase {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package com.hubspot.slack.client.methods.params.chat.workobject.flexpane;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;

public enum MessageFormat {
STRING,
MARKDOWN;

@JsonCreator
public static MessageFormat parse(String result) {
return MessageFormat.valueOf(result.toUpperCase());
}

@JsonValue
public String value() {
return name().toLowerCase();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package com.hubspot.slack.client.methods.params.chat.workobject.flexpane;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.actions.WorkObjectAction;
import java.util.List;
import java.util.Optional;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface WorkObjectFlexpaneErrorIF {
WorkObjectFlexpaneErrorStatus getStatus();
Optional<String> getCustomTitle();
Optional<String> getCustomMessage();
MessageFormat getMessageFormat();
List<WorkObjectAction> getActions();
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package com.hubspot.slack.client.methods.params.chat.workobject.flexpane;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;

public enum WorkObjectFlexpaneErrorStatus {
RESTRICTED,
INTERNAL_ERROR,
NOT_FOUND,
CUSTOM,
CUSTOM_PARTIAL_VIEW,
TIMEOUT,
EDIT_ERROR;

@JsonCreator
public static WorkObjectFlexpaneErrorStatus parse(String result) {
return WorkObjectFlexpaneErrorStatus.valueOf(result.toUpperCase());
}

@JsonValue
public String value() {
return name().toLowerCase();
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package com.hubspot.slack.client.methods.params.chat.workobject.flexpane;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.methods.params.chat.workobject.Metadata;
import java.util.Optional;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface WorkObjectFlexpaneParamsIF {
String getTriggerId();
Metadata getMetadata();
Optional<Boolean> getIsUserAuthRequired();
Optional<String> getUserAuthUrl();
Optional<WorkObjectFlexpaneError> getError();
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;
import com.hubspot.slack.client.enums.EnumIndex;
import com.hubspot.slack.client.methods.params.chat.workobject.entity.SlackEntityDetails;
import com.hubspot.slack.client.models.events.app.SlackAppUninstalledEvent;
import com.hubspot.slack.client.models.events.app.SlackTokensRevokedEvent;
import com.hubspot.slack.client.models.events.assistant.SlackAssistantThreadContextChangedEvent;
Expand Down Expand Up @@ -69,6 +70,7 @@ public enum SlackEventType {
IM_HISTORY_CHANGED,
IM_OPEN,
LINK_SHARED(SlackLinkSharedEvent.class),
ENTITY_PRESENT_DETAILS(SlackEntityDetails.class),
MEMBER_JOINED_CHANNEL(SlackMemberJoinedChannelEvent.class),
MEMBER_LEFT_CHANNEL(SlackMemberLeftChannelEvent.class),
MESSAGE(SlackEventMessage.class),
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
package com.hubspot.slack.client.models.events.links;

import com.hubspot.immutables.style.HubSpotStyle;
import org.immutables.value.Value;

@HubSpotStyle
@Value.Immutable
public interface EntityDetailsRequestedEventIF {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package com.hubspot.slack.client.models.response.chat;

import com.fasterxml.jackson.databind.PropertyNamingStrategies;
import com.fasterxml.jackson.databind.annotation.JsonNaming;
import com.hubspot.immutables.style.HubSpotStyle;
import com.hubspot.slack.client.models.response.SlackResponse;
import org.immutables.value.Value;

@Value.Immutable
@HubSpotStyle
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy.class)
public interface EntityPresentDetailsResponseIF extends SlackResponse {}
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
import com.hubspot.slack.client.methods.params.chat.ChatScheduledMessagesListParams;
import com.hubspot.slack.client.methods.params.chat.ChatUnfurlParams;
import com.hubspot.slack.client.methods.params.chat.ChatUpdateMessageParams;
import com.hubspot.slack.client.methods.params.chat.workobject.flexpane.WorkObjectFlexpaneParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationArchiveParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationCreateParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationInviteParams;
Expand Down Expand Up @@ -107,6 +108,7 @@
import com.hubspot.slack.client.models.response.chat.ChatScheduledMessagesListResponse;
import com.hubspot.slack.client.models.response.chat.ChatUnfurlResponse;
import com.hubspot.slack.client.models.response.chat.ChatUpdateMessageResponse;
import com.hubspot.slack.client.models.response.chat.EntityPresentDetailsResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationKickResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationListResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationMemberResponse;
Expand Down Expand Up @@ -296,6 +298,9 @@ CompletableFuture<Result<ChatDeleteResponse, SlackError>> deleteMessage(
CompletableFuture<Result<ChatUnfurlResponse, SlackError>> unfurlLinks(
ChatUnfurlParams params
);
CompletableFuture<Result<EntityPresentDetailsResponse, SlackError>> entityPresentDetails(
WorkObjectFlexpaneParams params
);

// conversations
Iterable<CompletableFuture<Result<List<Conversation>, SlackError>>> listConversations(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@
import com.hubspot.slack.client.methods.params.chat.ChatScheduledMessagesListParams;
import com.hubspot.slack.client.methods.params.chat.ChatUnfurlParams;
import com.hubspot.slack.client.methods.params.chat.ChatUpdateMessageParams;
import com.hubspot.slack.client.methods.params.chat.workobject.flexpane.WorkObjectFlexpaneParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationArchiveParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationCreateParams;
import com.hubspot.slack.client.methods.params.conversations.ConversationInviteParams;
Expand Down Expand Up @@ -143,6 +144,7 @@
import com.hubspot.slack.client.models.response.chat.ChatScheduledMessagesListResponse;
import com.hubspot.slack.client.models.response.chat.ChatUnfurlResponse;
import com.hubspot.slack.client.models.response.chat.ChatUpdateMessageResponse;
import com.hubspot.slack.client.models.response.chat.EntityPresentDetailsResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationKickResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationListResponse;
import com.hubspot.slack.client.models.response.conversations.ConversationMemberResponse;
Expand Down Expand Up @@ -860,6 +862,17 @@ public CompletableFuture<Result<ChatUnfurlResponse, SlackError>> unfurlLinks(
return postSlackCommand(SlackMethods.chat_unfurl, params, ChatUnfurlResponse.class);
}

@Override
public CompletableFuture<Result<EntityPresentDetailsResponse, SlackError>> entityPresentDetails(
WorkObjectFlexpaneParams params
) {
return postSlackCommand(
SlackMethods.entity_presentDetails,
params,
EntityPresentDetailsResponse.class
);
}

@Override
public Iterable<CompletableFuture<Result<List<Conversation>, SlackError>>> listConversations(
ConversationsListParams params
Expand Down
Loading