mirror of
https://github.com/status-im/wakuconnect-chat-sdk.git
synced 2025-01-11 20:54:37 +00:00
fix channel schema encode-url-data.ts
(#549)
* Update encode-url-data.ts * Create slimy-keys-melt.md * f * f
This commit is contained in:
parent
2d9dbdd49e
commit
13f7ed5415
5
.changeset/slimy-keys-melt.md
Normal file
5
.changeset/slimy-keys-melt.md
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
"@status-im/js": patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Update encode-url-data.ts
|
@ -107,15 +107,6 @@ describe('Encode URL data', () => {
|
|||||||
],
|
],
|
||||||
\\"message\\": \\"Required\\"
|
\\"message\\": \\"Required\\"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
\\"code\\": \\"invalid_type\\",
|
|
||||||
\\"expected\\": \\"string\\",
|
|
||||||
\\"received\\": \\"undefined\\",
|
|
||||||
\\"path\\": [
|
|
||||||
\\"emoji\\"
|
|
||||||
],
|
|
||||||
\\"message\\": \\"Required\\"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
\\"code\\": \\"invalid_type\\",
|
\\"code\\": \\"invalid_type\\",
|
||||||
\\"expected\\": \\"string\\",
|
\\"expected\\": \\"string\\",
|
||||||
@ -188,15 +179,6 @@ describe('Encode URL data', () => {
|
|||||||
],
|
],
|
||||||
\\"message\\": \\"Required\\"
|
\\"message\\": \\"Required\\"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
\\"code\\": \\"invalid_type\\",
|
|
||||||
\\"expected\\": \\"string\\",
|
|
||||||
\\"received\\": \\"undefined\\",
|
|
||||||
\\"path\\": [
|
|
||||||
\\"emoji\\"
|
|
||||||
],
|
|
||||||
\\"message\\": \\"Required\\"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
\\"code\\": \\"invalid_type\\",
|
\\"code\\": \\"invalid_type\\",
|
||||||
\\"expected\\": \\"string\\",
|
\\"expected\\": \\"string\\",
|
||||||
|
@ -25,8 +25,7 @@ export function encodeCommunityURLData(
|
|||||||
return encodeURLData(new Community(data).toBinary()) as EncodedURLData
|
return encodeURLData(new Community(data).toBinary()) as EncodedURLData
|
||||||
}
|
}
|
||||||
|
|
||||||
// note: PlainMessage<T> type does not ensure returning of only own properties
|
export function decodeCommunityURLData(data: string) {
|
||||||
export function decodeCommunityURLData(data: string): PlainMessage<Community> {
|
|
||||||
const deserialized = decodeURLData(data)
|
const deserialized = decodeURLData(data)
|
||||||
|
|
||||||
const community = Community.fromBinary(deserialized.content).toJson()
|
const community = Community.fromBinary(deserialized.content).toJson()
|
||||||
@ -37,7 +36,7 @@ export function decodeCommunityURLData(data: string): PlainMessage<Community> {
|
|||||||
const channelSchema = z.object({
|
const channelSchema = z.object({
|
||||||
displayName: z.string().max(24).nonempty(),
|
displayName: z.string().max(24).nonempty(),
|
||||||
description: z.string().max(140).nonempty(),
|
description: z.string().max(140).nonempty(),
|
||||||
emoji: z.string().emoji(),
|
emoji: z.string().emoji().optional(),
|
||||||
color: colorSchema,
|
color: colorSchema,
|
||||||
community: z.object({
|
community: z.object({
|
||||||
displayName: communityDisplayName,
|
displayName: communityDisplayName,
|
||||||
@ -51,12 +50,7 @@ export function encodeChannelURLData(
|
|||||||
return encodeURLData(new Channel(data).toBinary()) as EncodedURLData
|
return encodeURLData(new Channel(data).toBinary()) as EncodedURLData
|
||||||
}
|
}
|
||||||
|
|
||||||
export function decodeChannelURLData(data: string): Omit<
|
export function decodeChannelURLData(data: string) {
|
||||||
PlainMessage<Channel>,
|
|
||||||
'community'
|
|
||||||
> & {
|
|
||||||
community: Pick<PlainMessage<Community>, 'displayName'>
|
|
||||||
} {
|
|
||||||
const deserialized = decodeURLData(data)
|
const deserialized = decodeURLData(data)
|
||||||
|
|
||||||
const channel = Channel.fromBinary(deserialized.content).toJson()
|
const channel = Channel.fromBinary(deserialized.content).toJson()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user