# Invites

Invites allow you to add users to a channel with a pending state. The invited user receives a notification and can accept or reject the invite.

Unread counts are not incremented for channels with a pending invite.

## Invite Users

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
val channelClient = client.channel("messaging", "general")

channelClient.inviteMembers(memberIds = listOf("nick")).enqueue { result ->
  if (result is Result.Success) {
    val channel: Channel = result.value
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
await channel.inviteMembers(["nick"]);
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
$channel->inviteMembers(['thierry']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
final invite = client.channel("messaging", id: "awesome-chat",
  extraData: {
   "name": "Founder Chat",
   "members": ["thierry", "tommaso"],
   "invites": ["nick"],
  });

await invite.create();
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
let controller = client.channelController(for: .init(type: .messaging, id: "general"))

controller.inviteMembers(userIds: ["thierry"])
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
// Not yet supported in the Unreal SDK
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
channel.invite_members(["thierry"])
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
# require 'stream-chat'

channel.invite_members(['thierry'])
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
channel.InviteMembers(ctx, "thierry")
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.InviteAsync("<channel-type>", "<channel-id>", "thierry");
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
// Android SDK
ChannelClient channelClient = client.channel("messaging", "general");

List<String> memberIds = Arrays.asList("thierry", "tommaso");
Map<String, Object> data = new HashMap<>();
data.put("invites", Arrays.asList("nick"));

channelClient.create(memberIds, data).enqueue(result -> {
  if (result.isSuccess()) {
    Channel channel = result.data();
  } else {
    // Handle result.error()
  }
 });


// Backend SDK
Channel.update("messaging", "general")
  .invites(Arrays.asList("thierry", "tommaso"))
  .request();
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
// Invite IStreamUser collection as new members
await channel.InviteMembersAsync(users);

// Or add by ID
await channel.InviteMembersAsync("some-user-id-1", "some-user-id-2");
```

</codetabs-item>

</codetabs>

## Accept an Invite

Call `acceptInvite` to accept a pending invite. You can optionally include a `message` parameter to post a system message when the user joins (e.g., "Nick joined this channel!").

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
channelClient.acceptInvite(
  message = "Nick joined this channel!"
).enqueue { result ->
  if (result is Result.Success) {
    val channel: Channel = result.value
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
// initialize the channel
const channel = client.channel("messaging", "awesome-chat");

// accept the invite
await channel.acceptInvite({
  message: { text: "Nick joined this channel!" },
});

// accept the invite server side
await channel.acceptInvite({ user_id: "nick" });
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
// initialize the channel
$channel = $client->Channel('messaging', 'team-chat-5');

// accept the invite
$accept = $channel->acceptInvite(['user_id'=>'elon']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
final channel = client.channel("messaging", id: "awesome-chat");
await channel.acceptInvite();
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
let controller = client.channelController(for: .init(type: .messaging, id: "general"))


controller.acceptInvite()
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
// Not yet supported in the Unreal SDK
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.AcceptInviteAsync("<channel-type>", "<channel-id>", "thierry");
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
channel.accept_invite("thierry")
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
channel.accept_invite("thierry")
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
channel.AcceptInvite(ctx, "thierry", nil)
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
// Android SDK
channelClient.acceptInvite("Nick joined this channel!").enqueue(result -> {
  if (result.isSuccess()) {
    Channel channel = result.data();
  } else {
    // Handle result.error()
  }
});

// Backend SDK
Channel.update("messaging", "general")
  .acceptInvite(true)
  .userId("nick")
  .message(MessageRequestObject.builder().text("Nick joined the channel").build())
  .request();
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
await channel.AcceptInviteAsync();
```

</codetabs-item>

</codetabs>

## Reject an Invite

Call `rejectInvite` to decline a pending invite. Client-side calls use the currently connected user. Server-side calls require a `user_id` parameter.

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
channelClient.rejectInvite().enqueue { result ->
  if (result is Result.Success) {
    // Invite rejected
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
await channel.rejectInvite();

//server side
await channel.rejectInvite({ user_id: "rob" });
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
$reject = $channel->rejectInvite(['user_id'=>'elon']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
await channel.rejectInvite();
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
let controller = client.channelController(for: .init(type: .messaging, id: "general"))

controller.rejectInvite()
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
// Not yet supported in the Unreal SDK
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.RejectInviteAsync("<channel-type>", "<channel-id>", "thierry");
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
channel.reject_invite("thierry")
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
channel.reject_invite("thierry")
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
channel.RejectInvite(ctx, "thierry", nil)
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
// Android SDK
channelClient.rejectInvite().enqueue(result -> {
  if (result.isSuccess()) {
    // Invite rejected
  } else {
    // Handle result.error()
  }
});

// Backend SDK
Channel.update("messaging", "general")
  .acceptInvite(false)
  .userId("nick")
  .request();
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
await channel.RejectInviteAsync();
```

</codetabs-item>

</codetabs>

## Query Invites by Status

Use `queryChannels` with the `invite` filter to retrieve channels based on invite status. Valid values are `pending`, `accepted`, and `rejected`.

### Query Accepted Invites

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
val request = QueryChannelsRequest(
  filter = Filters.eq("invite", "accepted"),
  offset = 0,
  limit = 10
)
client.queryChannels(request).enqueue { result ->
  if (result is Result.Success) {
    val channels: List<Channel> = result.value
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
const invites = await client.queryChannels({
  invite: "accepted",
});

//server side (query invites for user rob)
const invites = await client.queryChannels(
  {
    invite: "accepted",
  },
  {},
  { user_id: "rob" },
);
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
$invites = $client->queryChannels(['invite' => 'accepted'],[], ['user_id' => 'jenny']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
final invites = await client.queryChannels(filter: {"invite": "accepted"});
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
import StreamChat

let controller = chatClient.channelListController(
  query: .init(
    filter: .equal(.invite, to: .accepted)
  )
)

controller.synchronize { error in
  if let error = error {
    // handle error
    print(error)
  } else {
    // access channels
    print(controller.channels)

    // load more if needed
    controller.loadNextChannels(limit: 10) { _ in
      // handle error / access channels
    }
  }
}
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
Client->QueryChannels(FFilter::Equal(TEXT("invite"), TEXT("accepted")));
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.QueryChannelsAsync(QueryChannelsOptions.Default.WithFilter(new Dictionary<string, object>
{
  { "invite", "accepted" },
}));
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
client.query_channels({"invite": "accepted"})
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
client.query_channels({ 'invite' => 'accepted' })
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
client.QueryChannels(ctx, &QueryOption{
	Filter: map[string]interface{}{
		"invite": "accepted",
	},
})
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
// Android SDK
FilterObject filter = Filters.eq("invite", "accepted");
int offset = 0;
int limit = 10;
QuerySorter<Channel> sort = new QuerySortByField<>();
int messageLimit = 0;
int memberLimit = 0;
QueryChannelsRequest request = new QueryChannelsRequest(filter, offset, limit, sort, messageLimit, memberLimit);

client.queryChannels(request).enqueue(result -> {
  if (result.isSuccess()) {
    List<Channel> channels = result.data();
  } else {
    // Handle result.error()
  }
});

// Backend SDK
Channel.queryMembers().type("messaging").id("general").filterCondition("invite", "accepted").request();
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
var filter = new List<IFieldFilterRule>
{
  ChannelFilter.Invite.EqualsTo(ChannelFieldInvite.Status.Accepted)
};

var sort = ChannelSort.OrderByDescending(ChannelSortFieldName.LastMessageAt);

var acceptedInvites = await Client.QueryChannelsAsync(filter, sort);
```

</codetabs-item>

</codetabs>

### Query Rejected Invites

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
val request = QueryChannelsRequest(
  filter = Filters.eq("invite", "rejected"),
  offset = 0,
  limit = 10
)
client.queryChannels(request).enqueue { result ->
  if (result is Result.Success) {
    val channels: List<Channel> = result.value
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
const rejected = client.queryChannels({
  invite: "rejected",
});

//server side (query invites for user rob)
const invites = await client.queryChannels(
  {
    invite: "rejected",
  },
  {},
  { user_id: "rob" },
);
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
$invites = $client->queryChannels(['invite' => 'rejected'],[], ['user_id' => 'jenny']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
final rejected = await client.queryChannels(filter: {"invite": "rejected"});
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
import StreamChat

let controller = chatClient.channelListController(
  query: .init(
    filter: .equal(.invite, to: .rejected)
  )
)

controller.synchronize { error in
  if let error = error {
    // handle error
    print(error)
  } else {
    // access channels
    print(controller.channels)

    // load more if needed
    controller.loadNextChannels(limit: 10) { _ in
      // handle error / access channels
    }
  }
}
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
Client->QueryChannels(FFilter::Equal(TEXT("invite"), TEXT("rejected")));
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.QueryChannelsAsync(QueryChannelsOptions.Default.WithFilter(new Dictionary<string, object>
{
  { "invite", "rejected" },
}));
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
client.query_channels({"invite": "rejected"})
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
client.query_channels({ 'invite' => 'rejected' })
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
client.QueryChannels(ctx, &QueryOption{
	Filter: map[string]interface{}{
		"invite": "rejected",
	},
})
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
// Android SDK
FilterObject filter = Filters.eq("invite", "rejected");
int offset = 0;
int limit = 10;
QuerySorter<Channel> sort = new QuerySortByField<>();
int messageLimit = 0;
int memberLimit = 0;
QueryChannelsRequest request = new QueryChannelsRequest(filter, offset, limit, sort, messageLimit, memberLimit);

client.queryChannels(request).enqueue(result -> {
  if (result.isSuccess()) {
    List<Channel> channels = result.data();
  } else {
    // Handle result.error()
  }
});

// Backend SDK
Channel.queryMembers()
  .type("messaging")
  .id("general")
  .filterCondition("invite", "rejected")
  .request();
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
var filter = new List<IFieldFilterRule>
{
  ChannelFilter.Invite.EqualsTo(ChannelFieldInvite.Status.Rejected)
};

var sort = ChannelSort.OrderByDescending(ChannelSortFieldName.LastMessageAt);

var rejectedInvites = await Client.QueryChannelsAsync(filter, sort);
```

</codetabs-item>

</codetabs>

### Query Pending Invites

<codetabs>

<codetabs-item value="kotlin" label="Kotlin">

```kotlin
val request = QueryChannelsRequest(
  filter = Filters.eq("invite", "pending"),
  offset = 0,
  limit = 10
)
client.queryChannels(request).enqueue { result ->
  if (result is Result.Success) {
    val channels: List<Channel> = result.value
  } else {
    // Handle Result.Failure
  }
}
```

</codetabs-item>

<codetabs-item value="javascript" label="JavaScript">

```js
const rejected = client.queryChannels({
  invite: "pending",
});

//server side (query invites for user rob)
const invites = await client.queryChannels(
  {
    invite: "pending",
  },
  {},
  { user_id: "rob" },
);
```

</codetabs-item>

<codetabs-item value="php" label="PHP">

```php
$invites = $client->queryChannels(['invite' => 'pending'],[], ['user_id' => 'jenny']);
```

</codetabs-item>

<codetabs-item value="dart" label="Dart">

```dart
final rejected = await client.queryChannels(filter: {"invite": "pending"});
```

</codetabs-item>

<codetabs-item value="swift" label="Swift">

```swift
import StreamChat

let controller = chatClient.channelListController(
  query: .init(
    filter: .equal(.invite, to: .pending)
  )
)

controller.synchronize { error in
  if let error = error {
    // handle error
    print(error)
  } else {
    // access channels
    print(controller.channels)

    // load more if needed
    controller.loadNextChannels(limit: 10) { _ in
      // handle error / access channels
    }
  }
}
```

</codetabs-item>

<codetabs-item value="unreal" label="Unreal">

```cpp
Client->QueryChannels(FFilter::Equal(TEXT("invite"), TEXT("pending")));
```

</codetabs-item>

<codetabs-item value="csharp" label="C#">

```csharp
await channelClient.QueryChannelsAsync(QueryChannelsOptions.Default.WithFilter(new Dictionary<string, object>
{
  { "invite", "pending" },
}));
```

</codetabs-item>

<codetabs-item value="python" label="Python">

```python
client.query_channels({"invite": "pending"})
```

</codetabs-item>

<codetabs-item value="ruby" label="Ruby">

```ruby
client.query_channels({ 'invite' => 'pending' })
```

</codetabs-item>

<codetabs-item value="go" label="Go">

```go
client.QueryChannels(ctx, &QueryOption{
	Filter: map[string]interface{}{
		"invite": "pending",
	},
})
```

</codetabs-item>

<codetabs-item value="java" label="Java">

```java
FilterObject filter = Filters.eq("invite", "pending");
int offset = 0;
int limit = 10;
QuerySorter<Channel> sort = new QuerySortByField<>();
int messageLimit = 0;
int memberLimit = 0;
QueryChannelsRequest request = new QueryChannelsRequest(filter, offset, limit, sort, messageLimit, memberLimit);

client.queryChannels(request).enqueue(result -> {
  if (result.isSuccess()) {
    List<Channel> channels = result.data();
  } else {
    // Handle result.error()
  }
});
```

</codetabs-item>

<codetabs-item value="unity" label="Unity">

```csharp
var filter = new List<IFieldFilterRule>
{
  ChannelFilter.Invite.EqualsTo(ChannelFieldInvite.Status.Pending)
};

var sort = ChannelSort.OrderByDescending(ChannelSortFieldName.LastMessageAt);

var pendingInvites = await Client.QueryChannelsAsync(filter, sort);
```

</codetabs-item>

</codetabs>


---

This page was last updated at 2026-03-05T19:05:24.072Z.

For the most recent version of this documentation, visit [https://getstream.io/chat/docs/go-golang/channel_invites/](https://getstream.io/chat/docs/go-golang/channel_invites/).