@sideline/domain 0.9.0 → 0.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/api/AgeThresholdApi.js +7 -1
- package/dist/cjs/api/AgeThresholdApi.js.map +1 -1
- package/dist/cjs/api/Auth.js +9 -8
- package/dist/cjs/api/Auth.js.map +1 -1
- package/dist/cjs/api/EventApi.js +39 -23
- package/dist/cjs/api/EventApi.js.map +1 -1
- package/dist/cjs/api/EventRsvpApi.js +11 -9
- package/dist/cjs/api/EventRsvpApi.js.map +1 -1
- package/dist/cjs/api/EventSeriesApi.js +44 -24
- package/dist/cjs/api/EventSeriesApi.js.map +1 -1
- package/dist/cjs/api/GroupApi.js +22 -14
- package/dist/cjs/api/GroupApi.js.map +1 -1
- package/dist/cjs/api/ICalApi.js +25 -0
- package/dist/cjs/api/ICalApi.js.map +1 -0
- package/dist/cjs/api/RoleApi.js +19 -5
- package/dist/cjs/api/RoleApi.js.map +1 -1
- package/dist/cjs/api/Roster.js +19 -13
- package/dist/cjs/api/Roster.js.map +1 -1
- package/dist/cjs/api/TeamSettingsApi.js +13 -12
- package/dist/cjs/api/TeamSettingsApi.js.map +1 -1
- package/dist/cjs/api/TrainingTypeApi.js +27 -8
- package/dist/cjs/api/TrainingTypeApi.js.map +1 -1
- package/dist/cjs/index.js +5 -1
- package/dist/cjs/models/AgeThresholdRule.js +2 -2
- package/dist/cjs/models/AgeThresholdRule.js.map +1 -1
- package/dist/cjs/models/ChannelSyncEvent.js +5 -5
- package/dist/cjs/models/ChannelSyncEvent.js.map +1 -1
- package/dist/cjs/models/Event.js +8 -5
- package/dist/cjs/models/Event.js.map +1 -1
- package/dist/cjs/models/EventRsvp.js +1 -1
- package/dist/cjs/models/EventRsvp.js.map +1 -1
- package/dist/cjs/models/EventSeries.js +8 -5
- package/dist/cjs/models/EventSeries.js.map +1 -1
- package/dist/cjs/models/GroupModel.js +2 -2
- package/dist/cjs/models/GroupModel.js.map +1 -1
- package/dist/cjs/models/ICalToken.js +17 -0
- package/dist/cjs/models/ICalToken.js.map +1 -0
- package/dist/cjs/models/OAuthConnection.js +1 -1
- package/dist/cjs/models/OAuthConnection.js.map +1 -1
- package/dist/cjs/models/RoleSyncEvent.js +5 -5
- package/dist/cjs/models/RoleSyncEvent.js.map +1 -1
- package/dist/cjs/models/TeamInvite.js +1 -1
- package/dist/cjs/models/TeamInvite.js.map +1 -1
- package/dist/cjs/models/TeamMember.js +1 -1
- package/dist/cjs/models/TeamMember.js.map +1 -1
- package/dist/cjs/models/TrainingType.js +2 -1
- package/dist/cjs/models/TrainingType.js.map +1 -1
- package/dist/cjs/models/User.js +5 -4
- package/dist/cjs/models/User.js.map +1 -1
- package/dist/cjs/rpc/event/EventRpcEvents.js +14 -12
- package/dist/cjs/rpc/event/EventRpcEvents.js.map +1 -1
- package/dist/cjs/rpc/event/EventRpcGroup.js +16 -8
- package/dist/cjs/rpc/event/EventRpcGroup.js.map +1 -1
- package/dist/cjs/rpc/event/EventRpcModels.js +41 -16
- package/dist/cjs/rpc/event/EventRpcModels.js.map +1 -1
- package/dist/cjs/rpc/guild/GuildRpcGroup.js +3 -3
- package/dist/cjs/rpc/guild/GuildRpcGroup.js.map +1 -1
- package/dist/dts/api/AgeThresholdApi.d.ts +6 -1
- package/dist/dts/api/AgeThresholdApi.d.ts.map +1 -1
- package/dist/dts/api/Auth.d.ts +22 -21
- package/dist/dts/api/Auth.d.ts.map +1 -1
- package/dist/dts/api/EventApi.d.ts +109 -69
- package/dist/dts/api/EventApi.d.ts.map +1 -1
- package/dist/dts/api/EventRsvpApi.d.ts +25 -25
- package/dist/dts/api/EventSeriesApi.d.ts +128 -72
- package/dist/dts/api/EventSeriesApi.d.ts.map +1 -1
- package/dist/dts/api/GroupApi.d.ts +49 -44
- package/dist/dts/api/GroupApi.d.ts.map +1 -1
- package/dist/dts/api/ICalApi.d.ts +28 -0
- package/dist/dts/api/ICalApi.d.ts.map +1 -0
- package/dist/dts/api/RoleApi.d.ts +31 -9
- package/dist/dts/api/RoleApi.d.ts.map +1 -1
- package/dist/dts/api/Roster.d.ts +50 -33
- package/dist/dts/api/Roster.d.ts.map +1 -1
- package/dist/dts/api/TeamSettingsApi.d.ts +36 -36
- package/dist/dts/api/TeamSettingsApi.d.ts.map +1 -1
- package/dist/dts/api/TrainingTypeApi.d.ts +62 -25
- package/dist/dts/api/TrainingTypeApi.d.ts.map +1 -1
- package/dist/dts/index.d.ts +2 -0
- package/dist/dts/index.d.ts.map +1 -1
- package/dist/dts/models/AgeThresholdRule.d.ts +22 -22
- package/dist/dts/models/ChannelSyncEvent.d.ts +55 -55
- package/dist/dts/models/Event.d.ts +81 -55
- package/dist/dts/models/Event.d.ts.map +1 -1
- package/dist/dts/models/EventRsvp.d.ts +11 -11
- package/dist/dts/models/EventSeries.d.ts +81 -55
- package/dist/dts/models/EventSeries.d.ts.map +1 -1
- package/dist/dts/models/GroupModel.d.ts +22 -22
- package/dist/dts/models/ICalToken.d.ts +69 -0
- package/dist/dts/models/ICalToken.d.ts.map +1 -0
- package/dist/dts/models/OAuthConnection.d.ts +8 -8
- package/dist/dts/models/RoleSyncEvent.d.ts +55 -55
- package/dist/dts/models/TeamInvite.d.ts +11 -11
- package/dist/dts/models/TeamMember.d.ts +22 -22
- package/dist/dts/models/TrainingType.d.ts +24 -11
- package/dist/dts/models/TrainingType.d.ts.map +1 -1
- package/dist/dts/models/User.d.ts +44 -44
- package/dist/dts/models/User.d.ts.map +1 -1
- package/dist/dts/rpc/SyncRpcs.d.ts +16 -12
- package/dist/dts/rpc/SyncRpcs.d.ts.map +1 -1
- package/dist/dts/rpc/event/EventRpcEvents.d.ts +12 -12
- package/dist/dts/rpc/event/EventRpcEvents.d.ts.map +1 -1
- package/dist/dts/rpc/event/EventRpcGroup.d.ts +14 -10
- package/dist/dts/rpc/event/EventRpcGroup.d.ts.map +1 -1
- package/dist/dts/rpc/event/EventRpcModels.d.ts +113 -45
- package/dist/dts/rpc/event/EventRpcModels.d.ts.map +1 -1
- package/dist/dts/rpc/guild/GuildRpcGroup.d.ts +3 -3
- package/dist/esm/api/AgeThresholdApi.js +5 -0
- package/dist/esm/api/AgeThresholdApi.js.map +1 -1
- package/dist/esm/api/Auth.js +8 -7
- package/dist/esm/api/Auth.js.map +1 -1
- package/dist/esm/api/EventApi.js +38 -23
- package/dist/esm/api/EventApi.js.map +1 -1
- package/dist/esm/api/EventRsvpApi.js +11 -9
- package/dist/esm/api/EventRsvpApi.js.map +1 -1
- package/dist/esm/api/EventSeriesApi.js +43 -24
- package/dist/esm/api/EventSeriesApi.js.map +1 -1
- package/dist/esm/api/GroupApi.js +20 -13
- package/dist/esm/api/GroupApi.js.map +1 -1
- package/dist/esm/api/ICalApi.js +16 -0
- package/dist/esm/api/ICalApi.js.map +1 -0
- package/dist/esm/api/RoleApi.js +16 -4
- package/dist/esm/api/RoleApi.js.map +1 -1
- package/dist/esm/api/Roster.js +17 -12
- package/dist/esm/api/Roster.js.map +1 -1
- package/dist/esm/api/TeamSettingsApi.js +13 -12
- package/dist/esm/api/TeamSettingsApi.js.map +1 -1
- package/dist/esm/api/TrainingTypeApi.js +25 -7
- package/dist/esm/api/TrainingTypeApi.js.map +1 -1
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/models/AgeThresholdRule.js +2 -2
- package/dist/esm/models/AgeThresholdRule.js.map +1 -1
- package/dist/esm/models/ChannelSyncEvent.js +5 -5
- package/dist/esm/models/ChannelSyncEvent.js.map +1 -1
- package/dist/esm/models/Event.js +8 -5
- package/dist/esm/models/Event.js.map +1 -1
- package/dist/esm/models/EventRsvp.js +1 -1
- package/dist/esm/models/EventRsvp.js.map +1 -1
- package/dist/esm/models/EventSeries.js +8 -5
- package/dist/esm/models/EventSeries.js.map +1 -1
- package/dist/esm/models/GroupModel.js +2 -2
- package/dist/esm/models/GroupModel.js.map +1 -1
- package/dist/esm/models/ICalToken.js +10 -0
- package/dist/esm/models/ICalToken.js.map +1 -0
- package/dist/esm/models/OAuthConnection.js +1 -1
- package/dist/esm/models/OAuthConnection.js.map +1 -1
- package/dist/esm/models/RoleSyncEvent.js +5 -5
- package/dist/esm/models/RoleSyncEvent.js.map +1 -1
- package/dist/esm/models/TeamInvite.js +1 -1
- package/dist/esm/models/TeamInvite.js.map +1 -1
- package/dist/esm/models/TeamMember.js +1 -1
- package/dist/esm/models/TeamMember.js.map +1 -1
- package/dist/esm/models/TrainingType.js +2 -1
- package/dist/esm/models/TrainingType.js.map +1 -1
- package/dist/esm/models/User.js +5 -4
- package/dist/esm/models/User.js.map +1 -1
- package/dist/esm/rpc/event/EventRpcEvents.js +13 -12
- package/dist/esm/rpc/event/EventRpcEvents.js.map +1 -1
- package/dist/esm/rpc/event/EventRpcGroup.js +17 -9
- package/dist/esm/rpc/event/EventRpcGroup.js.map +1 -1
- package/dist/esm/rpc/event/EventRpcModels.js +35 -15
- package/dist/esm/rpc/event/EventRpcModels.js.map +1 -1
- package/dist/esm/rpc/guild/GuildRpcGroup.js +3 -3
- package/dist/esm/rpc/guild/GuildRpcGroup.js.map +1 -1
- package/package.json +2 -2
- package/src/api/AgeThresholdApi.ts +7 -0
- package/src/api/Auth.ts +8 -7
- package/src/api/EventApi.ts +36 -23
- package/src/api/EventRsvpApi.ts +9 -9
- package/src/api/EventSeriesApi.ts +41 -24
- package/src/api/GroupApi.ts +21 -13
- package/src/api/ICalApi.ts +32 -0
- package/src/api/RoleApi.ts +17 -3
- package/src/api/Roster.ts +17 -11
- package/src/api/TeamSettingsApi.ts +13 -12
- package/src/api/TrainingTypeApi.ts +22 -7
- package/src/index.ts +4 -0
- package/src/models/AgeThresholdRule.ts +2 -2
- package/src/models/ChannelSyncEvent.ts +5 -5
- package/src/models/Event.ts +8 -5
- package/src/models/EventRsvp.ts +1 -1
- package/src/models/EventSeries.ts +8 -5
- package/src/models/GroupModel.ts +2 -2
- package/src/models/ICalToken.ts +10 -0
- package/src/models/OAuthConnection.ts +1 -1
- package/src/models/RoleSyncEvent.ts +5 -5
- package/src/models/TeamInvite.ts +1 -1
- package/src/models/TeamMember.ts +1 -1
- package/src/models/TrainingType.ts +2 -1
- package/src/models/User.ts +5 -4
- package/src/rpc/event/EventRpcEvents.ts +13 -12
- package/src/rpc/event/EventRpcGroup.ts +25 -8
- package/src/rpc/event/EventRpcModels.ts +44 -15
- package/src/rpc/guild/GuildRpcGroup.ts +3 -3
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Model } from '@effect/sql';
|
|
2
|
+
import { Schema } from 'effect';
|
|
3
|
+
import { UserId } from '~/models/User.js';
|
|
4
|
+
|
|
5
|
+
export class ICalToken extends Model.Class<ICalToken>('ICalToken')({
|
|
6
|
+
id: Model.Generated(Schema.String),
|
|
7
|
+
user_id: UserId,
|
|
8
|
+
token: Schema.String,
|
|
9
|
+
created_at: Model.DateTimeInsertFromDate,
|
|
10
|
+
}) {}
|
|
@@ -10,7 +10,7 @@ export class OAuthConnection extends Model.Class<OAuthConnection>('OAuthConnecti
|
|
|
10
10
|
user_id: UserId,
|
|
11
11
|
provider: Schema.String,
|
|
12
12
|
access_token: Model.Sensitive(Schema.String),
|
|
13
|
-
refresh_token: Model.Sensitive(Schema.
|
|
13
|
+
refresh_token: Model.Sensitive(Schema.OptionFromNullOr(Schema.String)),
|
|
14
14
|
created_at: Model.DateTimeInsertFromDate,
|
|
15
15
|
updated_at: Model.DateTimeUpdateFromDate,
|
|
16
16
|
}) {}
|
|
@@ -21,10 +21,10 @@ export class RoleSyncEvent extends Model.Class<RoleSyncEvent>('RoleSyncEvent')({
|
|
|
21
21
|
guild_id: Schema.String,
|
|
22
22
|
event_type: RoleSyncEventType,
|
|
23
23
|
role_id: RoleId,
|
|
24
|
-
role_name: Schema.
|
|
25
|
-
team_member_id: Schema.
|
|
26
|
-
discord_user_id: Schema.
|
|
27
|
-
processed_at: Schema.
|
|
28
|
-
error: Schema.
|
|
24
|
+
role_name: Schema.OptionFromNullOr(Schema.String),
|
|
25
|
+
team_member_id: Schema.OptionFromNullOr(TeamMemberId),
|
|
26
|
+
discord_user_id: Schema.OptionFromNullOr(Schema.String),
|
|
27
|
+
processed_at: Schema.OptionFromNullOr(Schema.String),
|
|
28
|
+
error: Schema.OptionFromNullOr(Schema.String),
|
|
29
29
|
created_at: Model.DateTimeInsertFromDate,
|
|
30
30
|
}) {}
|
package/src/models/TeamInvite.ts
CHANGED
|
@@ -14,5 +14,5 @@ export class TeamInvite extends Model.Class<TeamInvite>('TeamInvite')({
|
|
|
14
14
|
active: Schema.Boolean,
|
|
15
15
|
created_by: UserId,
|
|
16
16
|
created_at: Model.DateTimeInsertFromDate,
|
|
17
|
-
expires_at: Schema.
|
|
17
|
+
expires_at: Schema.OptionFromNullOr(Schemas.DateTimeFromDate),
|
|
18
18
|
}) {}
|
package/src/models/TeamMember.ts
CHANGED
|
@@ -11,6 +11,6 @@ export class TeamMember extends Model.Class<TeamMember>('TeamMember')({
|
|
|
11
11
|
team_id: TeamId,
|
|
12
12
|
user_id: UserId,
|
|
13
13
|
active: Schema.Boolean,
|
|
14
|
-
jersey_number: Model.FieldExcept('insert')(Schema.
|
|
14
|
+
jersey_number: Model.FieldExcept('insert')(Schema.OptionFromNullOr(Schema.Number)),
|
|
15
15
|
joined_at: Model.DateTimeInsertFromDate,
|
|
16
16
|
}) {}
|
|
@@ -10,6 +10,7 @@ export class TrainingType extends Model.Class<TrainingType>('TrainingType')({
|
|
|
10
10
|
id: Model.Generated(TrainingTypeId),
|
|
11
11
|
team_id: TeamId,
|
|
12
12
|
name: Schema.String,
|
|
13
|
-
|
|
13
|
+
owner_group_id: Schema.OptionFromNullOr(GroupId),
|
|
14
|
+
member_group_id: Schema.OptionFromNullOr(GroupId),
|
|
14
15
|
created_at: Model.DateTimeInsertFromDate,
|
|
15
16
|
}) {}
|
package/src/models/User.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Model } from '@effect/sql';
|
|
2
2
|
import * as Schemas from '@sideline/effect-lib/Schemas';
|
|
3
3
|
import { Schema } from 'effect';
|
|
4
|
+
import { Snowflake } from '~/models/Discord.js';
|
|
4
5
|
|
|
5
6
|
export const UserId = Schema.String.pipe(Schema.brand('UserId'));
|
|
6
7
|
export type UserId = typeof UserId.Type;
|
|
@@ -13,12 +14,12 @@ export type Locale = typeof Locale.Type;
|
|
|
13
14
|
|
|
14
15
|
export class User extends Model.Class<User>('User')({
|
|
15
16
|
id: Model.Generated(UserId),
|
|
16
|
-
discord_id:
|
|
17
|
+
discord_id: Snowflake,
|
|
17
18
|
username: Schema.String,
|
|
18
|
-
avatar: Schema.
|
|
19
|
-
name: Schema.
|
|
19
|
+
avatar: Schema.OptionFromNullOr(Schema.String),
|
|
20
|
+
name: Schema.OptionFromNullOr(Schema.String),
|
|
20
21
|
birth_date: Schema.OptionFromNullOr(Schemas.DateTimeFromDate),
|
|
21
|
-
gender: Schema.
|
|
22
|
+
gender: Schema.OptionFromNullOr(Gender),
|
|
22
23
|
locale: Locale,
|
|
23
24
|
created_at: Model.DateTimeInsertFromDate,
|
|
24
25
|
is_profile_complete: Schema.Boolean,
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as Schemas from '@sideline/effect-lib/Schemas';
|
|
1
2
|
import { Schema } from 'effect';
|
|
2
3
|
import { Discord, Event, Team } from '~/index.js';
|
|
3
4
|
|
|
@@ -7,12 +8,12 @@ export class EventCreatedEvent extends Schema.TaggedClass<EventCreatedEvent>()('
|
|
|
7
8
|
guild_id: Discord.Snowflake,
|
|
8
9
|
event_id: Event.EventId,
|
|
9
10
|
title: Schema.String,
|
|
10
|
-
description: Schema.
|
|
11
|
-
start_at:
|
|
12
|
-
end_at: Schema.
|
|
13
|
-
location: Schema.
|
|
11
|
+
description: Schema.OptionFromNullOr(Schema.String),
|
|
12
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
13
|
+
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromIsoString),
|
|
14
|
+
location: Schema.OptionFromNullOr(Schema.String),
|
|
14
15
|
event_type: Schema.String,
|
|
15
|
-
discord_channel_id: Schema.
|
|
16
|
+
discord_channel_id: Schema.OptionFromNullOr(Discord.Snowflake),
|
|
16
17
|
}) {}
|
|
17
18
|
|
|
18
19
|
export class EventUpdatedEvent extends Schema.TaggedClass<EventUpdatedEvent>()('event_updated', {
|
|
@@ -21,12 +22,12 @@ export class EventUpdatedEvent extends Schema.TaggedClass<EventUpdatedEvent>()('
|
|
|
21
22
|
guild_id: Discord.Snowflake,
|
|
22
23
|
event_id: Event.EventId,
|
|
23
24
|
title: Schema.String,
|
|
24
|
-
description: Schema.
|
|
25
|
-
start_at:
|
|
26
|
-
end_at: Schema.
|
|
27
|
-
location: Schema.
|
|
25
|
+
description: Schema.OptionFromNullOr(Schema.String),
|
|
26
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
27
|
+
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromIsoString),
|
|
28
|
+
location: Schema.OptionFromNullOr(Schema.String),
|
|
28
29
|
event_type: Schema.String,
|
|
29
|
-
discord_channel_id: Schema.
|
|
30
|
+
discord_channel_id: Schema.OptionFromNullOr(Discord.Snowflake),
|
|
30
31
|
}) {}
|
|
31
32
|
|
|
32
33
|
export class EventCancelledEvent extends Schema.TaggedClass<EventCancelledEvent>()(
|
|
@@ -45,8 +46,8 @@ export class RsvpReminderEvent extends Schema.TaggedClass<RsvpReminderEvent>()('
|
|
|
45
46
|
guild_id: Discord.Snowflake,
|
|
46
47
|
event_id: Event.EventId,
|
|
47
48
|
title: Schema.String,
|
|
48
|
-
start_at:
|
|
49
|
-
discord_channel_id: Schema.
|
|
49
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
50
|
+
discord_channel_id: Schema.OptionFromNullOr(Discord.Snowflake),
|
|
50
51
|
}) {}
|
|
51
52
|
|
|
52
53
|
export const UnprocessedEventSyncEvent = Schema.Union(
|
|
@@ -10,11 +10,14 @@ import {
|
|
|
10
10
|
CreateEventResult,
|
|
11
11
|
EventDiscordMessage,
|
|
12
12
|
EventEmbedInfo,
|
|
13
|
+
GuildEventListResult,
|
|
14
|
+
GuildNotFound,
|
|
13
15
|
RsvpAttendeesResult,
|
|
14
16
|
RsvpCountsResult,
|
|
15
17
|
RsvpDeadlinePassed,
|
|
16
18
|
RsvpEventNotFound,
|
|
17
19
|
RsvpMemberNotFound,
|
|
20
|
+
RsvpNotGroupMember,
|
|
18
21
|
RsvpReminderSummary,
|
|
19
22
|
} from './EventRpcModels.js';
|
|
20
23
|
|
|
@@ -32,8 +35,8 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
32
35
|
Rpc.make('SaveDiscordMessageId', {
|
|
33
36
|
payload: {
|
|
34
37
|
event_id: Event.EventId,
|
|
35
|
-
discord_channel_id:
|
|
36
|
-
discord_message_id:
|
|
38
|
+
discord_channel_id: Discord.Snowflake,
|
|
39
|
+
discord_message_id: Discord.Snowflake,
|
|
37
40
|
},
|
|
38
41
|
}),
|
|
39
42
|
Rpc.make('GetDiscordMessageId', {
|
|
@@ -46,10 +49,15 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
46
49
|
team_id: Team.TeamId,
|
|
47
50
|
discord_user_id: Discord.Snowflake,
|
|
48
51
|
response: EventRsvp.RsvpResponse,
|
|
49
|
-
message: Schema.
|
|
52
|
+
message: Schema.OptionFromNullOr(Schema.String),
|
|
50
53
|
},
|
|
51
54
|
success: RsvpCountsResult,
|
|
52
|
-
error: Schema.Union(
|
|
55
|
+
error: Schema.Union(
|
|
56
|
+
RsvpMemberNotFound,
|
|
57
|
+
RsvpDeadlinePassed,
|
|
58
|
+
RsvpEventNotFound,
|
|
59
|
+
RsvpNotGroupMember,
|
|
60
|
+
),
|
|
53
61
|
}),
|
|
54
62
|
Rpc.make('GetRsvpCounts', {
|
|
55
63
|
payload: { event_id: Event.EventId },
|
|
@@ -60,7 +68,7 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
60
68
|
success: Schema.OptionFromNullOr(EventEmbedInfo),
|
|
61
69
|
}),
|
|
62
70
|
Rpc.make('GetChannelEvents', {
|
|
63
|
-
payload: { discord_channel_id:
|
|
71
|
+
payload: { discord_channel_id: Discord.Snowflake },
|
|
64
72
|
success: Schema.Array(ChannelEventEntry),
|
|
65
73
|
}),
|
|
66
74
|
Rpc.make('GetRsvpAttendees', {
|
|
@@ -71,6 +79,15 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
71
79
|
payload: { event_id: Event.EventId },
|
|
72
80
|
success: RsvpReminderSummary,
|
|
73
81
|
}),
|
|
82
|
+
Rpc.make('GetUpcomingGuildEvents', {
|
|
83
|
+
payload: {
|
|
84
|
+
guild_id: Discord.Snowflake,
|
|
85
|
+
offset: Schema.Number,
|
|
86
|
+
limit: Schema.Number,
|
|
87
|
+
},
|
|
88
|
+
success: GuildEventListResult,
|
|
89
|
+
error: GuildNotFound,
|
|
90
|
+
}),
|
|
74
91
|
Rpc.make('CreateEvent', {
|
|
75
92
|
payload: {
|
|
76
93
|
guild_id: Discord.Snowflake,
|
|
@@ -78,9 +95,9 @@ export const EventRpcGroup = RpcGroup.make(
|
|
|
78
95
|
event_type: Event.EventType,
|
|
79
96
|
title: Schema.String,
|
|
80
97
|
start_at: Schema.String,
|
|
81
|
-
end_at: Schema.
|
|
82
|
-
location: Schema.
|
|
83
|
-
description: Schema.
|
|
98
|
+
end_at: Schema.OptionFromNullOr(Schema.String),
|
|
99
|
+
location: Schema.OptionFromNullOr(Schema.String),
|
|
100
|
+
description: Schema.OptionFromNullOr(Schema.String),
|
|
84
101
|
},
|
|
85
102
|
success: CreateEventResult,
|
|
86
103
|
error: Schema.Union(CreateEventNotMember, CreateEventForbidden, CreateEventInvalidDate),
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
import * as Schemas from '@sideline/effect-lib/Schemas';
|
|
1
2
|
import { Schema } from 'effect';
|
|
3
|
+
import { Snowflake } from '~/models/Discord.js';
|
|
2
4
|
|
|
3
5
|
export class EventDiscordMessage extends Schema.Class<EventDiscordMessage>('EventDiscordMessage')({
|
|
4
|
-
discord_channel_id:
|
|
5
|
-
discord_message_id:
|
|
6
|
+
discord_channel_id: Snowflake,
|
|
7
|
+
discord_message_id: Snowflake,
|
|
6
8
|
}) {}
|
|
7
9
|
|
|
8
10
|
export class RsvpCountsResult extends Schema.Class<RsvpCountsResult>('RsvpCountsResult')({
|
|
@@ -15,8 +17,8 @@ export class RsvpCountsResult extends Schema.Class<RsvpCountsResult>('RsvpCounts
|
|
|
15
17
|
export class EventEmbedInfo extends Schema.Class<EventEmbedInfo>('EventEmbedInfo')({
|
|
16
18
|
title: Schema.String,
|
|
17
19
|
description: Schema.OptionFromNullOr(Schema.String),
|
|
18
|
-
start_at:
|
|
19
|
-
end_at: Schema.OptionFromNullOr(
|
|
20
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
21
|
+
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromIsoString),
|
|
20
22
|
location: Schema.OptionFromNullOr(Schema.String),
|
|
21
23
|
event_type: Schema.String,
|
|
22
24
|
}) {}
|
|
@@ -25,13 +27,13 @@ export class ChannelEventEntry extends Schema.Class<ChannelEventEntry>('ChannelE
|
|
|
25
27
|
event_id: Schema.String,
|
|
26
28
|
team_id: Schema.String,
|
|
27
29
|
title: Schema.String,
|
|
28
|
-
description: Schema.
|
|
29
|
-
start_at:
|
|
30
|
-
end_at: Schema.
|
|
31
|
-
location: Schema.
|
|
30
|
+
description: Schema.OptionFromNullOr(Schema.String),
|
|
31
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
32
|
+
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromIsoString),
|
|
33
|
+
location: Schema.OptionFromNullOr(Schema.String),
|
|
32
34
|
event_type: Schema.String,
|
|
33
35
|
status: Schema.String,
|
|
34
|
-
discord_message_id:
|
|
36
|
+
discord_message_id: Snowflake,
|
|
35
37
|
}) {}
|
|
36
38
|
|
|
37
39
|
export class RsvpMemberNotFound extends Schema.TaggedError<RsvpMemberNotFound>()(
|
|
@@ -49,6 +51,11 @@ export class RsvpEventNotFound extends Schema.TaggedError<RsvpEventNotFound>()(
|
|
|
49
51
|
{},
|
|
50
52
|
) {}
|
|
51
53
|
|
|
54
|
+
export class RsvpNotGroupMember extends Schema.TaggedError<RsvpNotGroupMember>()(
|
|
55
|
+
'RsvpNotGroupMember',
|
|
56
|
+
{},
|
|
57
|
+
) {}
|
|
58
|
+
|
|
52
59
|
export class CreateEventNotMember extends Schema.TaggedError<CreateEventNotMember>()(
|
|
53
60
|
'CreateEventNotMember',
|
|
54
61
|
{},
|
|
@@ -69,11 +76,33 @@ export class CreateEventResult extends Schema.Class<CreateEventResult>('CreateEv
|
|
|
69
76
|
title: Schema.String,
|
|
70
77
|
}) {}
|
|
71
78
|
|
|
79
|
+
export class GuildEventListEntry extends Schema.Class<GuildEventListEntry>('GuildEventListEntry')({
|
|
80
|
+
event_id: Schema.String,
|
|
81
|
+
title: Schema.String,
|
|
82
|
+
start_at: Schemas.DateTimeFromIsoString,
|
|
83
|
+
end_at: Schema.OptionFromNullOr(Schemas.DateTimeFromIsoString),
|
|
84
|
+
location: Schema.OptionFromNullOr(Schema.String),
|
|
85
|
+
event_type: Schema.String,
|
|
86
|
+
yes_count: Schema.Number,
|
|
87
|
+
no_count: Schema.Number,
|
|
88
|
+
maybe_count: Schema.Number,
|
|
89
|
+
}) {}
|
|
90
|
+
|
|
91
|
+
export class GuildEventListResult extends Schema.Class<GuildEventListResult>(
|
|
92
|
+
'GuildEventListResult',
|
|
93
|
+
)({
|
|
94
|
+
events: Schema.Array(GuildEventListEntry),
|
|
95
|
+
total: Schema.Number,
|
|
96
|
+
team_id: Schema.String,
|
|
97
|
+
}) {}
|
|
98
|
+
|
|
99
|
+
export class GuildNotFound extends Schema.TaggedError<GuildNotFound>()('GuildNotFound', {}) {}
|
|
100
|
+
|
|
72
101
|
export class RsvpAttendeeEntry extends Schema.Class<RsvpAttendeeEntry>('RsvpAttendeeEntry')({
|
|
73
|
-
discord_id: Schema.
|
|
74
|
-
name: Schema.
|
|
102
|
+
discord_id: Schema.OptionFromNullOr(Snowflake),
|
|
103
|
+
name: Schema.OptionFromNullOr(Schema.String),
|
|
75
104
|
response: Schema.Literal('yes', 'no', 'maybe'),
|
|
76
|
-
message: Schema.
|
|
105
|
+
message: Schema.OptionFromNullOr(Schema.String),
|
|
77
106
|
}) {}
|
|
78
107
|
|
|
79
108
|
export class RsvpAttendeesResult extends Schema.Class<RsvpAttendeesResult>('RsvpAttendeesResult')({
|
|
@@ -84,9 +113,9 @@ export class RsvpAttendeesResult extends Schema.Class<RsvpAttendeesResult>('Rsvp
|
|
|
84
113
|
export class NonResponderRpcEntry extends Schema.Class<NonResponderRpcEntry>(
|
|
85
114
|
'NonResponderRpcEntry',
|
|
86
115
|
)({
|
|
87
|
-
discord_id: Schema.
|
|
88
|
-
name: Schema.
|
|
89
|
-
username: Schema.
|
|
116
|
+
discord_id: Schema.OptionFromNullOr(Snowflake),
|
|
117
|
+
name: Schema.OptionFromNullOr(Schema.String),
|
|
118
|
+
username: Schema.OptionFromNullOr(Schema.String),
|
|
90
119
|
}) {}
|
|
91
120
|
|
|
92
121
|
export class RsvpReminderSummary extends Schema.Class<RsvpReminderSummary>('RsvpReminderSummary')({
|
|
@@ -21,7 +21,7 @@ export const GuildRpcGroup = RpcGroup.make(
|
|
|
21
21
|
channel_id: Discord.Snowflake,
|
|
22
22
|
name: Schema.String,
|
|
23
23
|
type: Schema.Number,
|
|
24
|
-
parent_id: Schema.
|
|
24
|
+
parent_id: Schema.OptionFromNullOr(Discord.Snowflake),
|
|
25
25
|
}),
|
|
26
26
|
),
|
|
27
27
|
},
|
|
@@ -33,7 +33,7 @@ export const GuildRpcGroup = RpcGroup.make(
|
|
|
33
33
|
Schema.Struct({
|
|
34
34
|
discord_id: Schema.String,
|
|
35
35
|
username: Schema.String,
|
|
36
|
-
avatar: Schema.
|
|
36
|
+
avatar: Schema.OptionFromNullOr(Schema.String),
|
|
37
37
|
roles: Schema.Array(Schema.String),
|
|
38
38
|
}),
|
|
39
39
|
),
|
|
@@ -44,7 +44,7 @@ export const GuildRpcGroup = RpcGroup.make(
|
|
|
44
44
|
guild_id: Discord.Snowflake,
|
|
45
45
|
discord_id: Schema.String,
|
|
46
46
|
username: Schema.String,
|
|
47
|
-
avatar: Schema.
|
|
47
|
+
avatar: Schema.OptionFromNullOr(Schema.String),
|
|
48
48
|
roles: Schema.Array(Schema.String),
|
|
49
49
|
},
|
|
50
50
|
}),
|