diff --git a/src/Discord.Net.Rest/Entities/Interactions/MessageComponents/RestMessageComponent.cs b/src/Discord.Net.Rest/Entities/Interactions/MessageComponents/RestMessageComponent.cs
index 52dfad62..ab4cc4f6 100644
--- a/src/Discord.Net.Rest/Entities/Interactions/MessageComponents/RestMessageComponent.cs
+++ b/src/Discord.Net.Rest/Entities/Interactions/MessageComponents/RestMessageComponent.cs
@@ -19,7 +19,7 @@ namespace Discord.Rest
///
/// Gets the data received with this interaction, contains the button that was clicked.
///
- public new RestMessageComponentData Data { get; }
+ public new RestMessageComponentData Data { get; private set; }
///
public RestUserMessage Message { get; private set; }
@@ -29,17 +29,18 @@ namespace Discord.Rest
internal RestMessageComponent(BaseDiscordClient client, Model model)
: base(client, model.Id)
{
- var dataModel = model.Data.IsSpecified
- ? (DataModel)model.Data.Value
- : null;
-
- Data = new RestMessageComponentData(dataModel, client, Guild);
}
internal new static async Task CreateAsync(DiscordRestClient client, Model model, bool doApiCall)
{
var entity = new RestMessageComponent(client, model);
await entity.UpdateAsync(client, model, doApiCall).ConfigureAwait(false);
+
+ var dataModel = model.Data.IsSpecified
+ ? (DataModel)model.Data.Value
+ : null;
+
+ entity.Data = new RestMessageComponentData(dataModel, client, entity.Guild);
return entity;
}
internal override async Task UpdateAsync(DiscordRestClient discord, Model model, bool doApiCall)
diff --git a/src/Discord.Net.Rest/Entities/Interactions/Modals/RestModal.cs b/src/Discord.Net.Rest/Entities/Interactions/Modals/RestModal.cs
index e7d08e41..09cc59ab 100644
--- a/src/Discord.Net.Rest/Entities/Interactions/Modals/RestModal.cs
+++ b/src/Discord.Net.Rest/Entities/Interactions/Modals/RestModal.cs
@@ -22,22 +22,22 @@ namespace Discord.Rest
internal RestModal(DiscordRestClient client, ModelBase model)
: base(client, model.Id)
{
- var dataModel = model.Data.IsSpecified
- ? (DataModel)model.Data.Value
- : null;
-
if (model.Message.IsSpecified && model.ChannelId.IsSpecified)
{
Message = RestUserMessage.Create(Discord, Channel, User, model.Message.Value);
}
-
- Data = new RestModalData(dataModel, client, Guild);
}
internal new static async Task CreateAsync(DiscordRestClient client, ModelBase model, bool doApiCall)
{
var entity = new RestModal(client, model);
await entity.UpdateAsync(client, model, doApiCall);
+
+ var dataModel = model.Data.IsSpecified
+ ? (DataModel)model.Data.Value
+ : null;
+
+ entity.Data = new RestModalData(dataModel, client, entity.Guild);
return entity;
}