Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
mqtt-client
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
ReactWeb5
mqtt-client
Commits
314358e1
Commit
314358e1
authored
Nov 16, 2020
by
邓晓峰
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: WireMessage
parent
c1b555d7
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
43 additions
and
65 deletions
+43
-65
.gitignore
.gitignore
+1
-1
ClientImplementation.js
es/ClientImplementation.js
+2
-0
ClientImplementation.js
lib/ClientImplementation.js
+2
-0
WireMessage.js
src/WireMessage.js
+38
-64
No files found.
.gitignore
View file @
314358e1
...
@@ -12,7 +12,7 @@ config.local.js
...
@@ -12,7 +12,7 @@ config.local.js
.umi-production
.umi-production
.idea/
.idea/
.cache
.cache
yarn.loc
k
yarn.loc
package-lock.json
package-lock.json
.eslintcache
.eslintcache
.history
.history
...
...
es/ClientImplementation.js
View file @
314358e1
...
@@ -21,6 +21,8 @@ var Timeout = function Timeout(client, timeoutSeconds, action, args) {
...
@@ -21,6 +21,8 @@ var Timeout = function Timeout(client, timeoutSeconds, action, args) {
};
};
};
};
var
version
=
"@VERSION@-@BUILDLEVEL@"
;
var
scope
=
function
scope
(
f
,
_scope
)
{
var
scope
=
function
scope
(
f
,
_scope
)
{
return
function
()
{
return
function
()
{
return
f
.
apply
(
_scope
,
arguments
);
return
f
.
apply
(
_scope
,
arguments
);
...
...
lib/ClientImplementation.js
View file @
314358e1
...
@@ -34,6 +34,8 @@ var Timeout = function Timeout(client, timeoutSeconds, action, args) {
...
@@ -34,6 +34,8 @@ var Timeout = function Timeout(client, timeoutSeconds, action, args) {
};
};
};
};
var
version
=
"@VERSION@-@BUILDLEVEL@"
;
var
scope
=
function
scope
(
f
,
_scope
)
{
var
scope
=
function
scope
(
f
,
_scope
)
{
return
function
()
{
return
function
()
{
return
f
.
apply
(
_scope
,
arguments
);
return
f
.
apply
(
_scope
,
arguments
);
...
...
src/WireMessage.js
View file @
314358e1
...
@@ -26,19 +26,18 @@ import {
...
@@ -26,19 +26,18 @@ import {
// [key: string]: any
// [key: string]: any
// }
// }
class
WireMessage
{
const
WireMessage
=
function
(
type
,
options
)
{
constructor
(
type
,
options
)
{
this
.
type
=
type
;
this
.
type
=
type
;
for
(
var
name
in
options
)
{
for
(
var
name
in
options
)
{
if
(
options
.
hasOwnProperty
(
name
))
{
if
(
options
.
hasOwnProperty
(
name
))
{
this
[
name
]
=
options
[
name
];
this
[
name
]
=
options
[
name
];
}
}
}
}
}
};
encode
()
{
WireMessage
.
prototype
.
encode
=
function
()
{
// Compute the first byte of the fixed header
// Compute the first byte of the fixed header
var
first
=
(
this
.
type
&
0x0f
)
<<
4
;
var
first
=
(
(
this
.
type
&
0x0f
)
<<
4
)
;
/*
/*
* Now calculate the length of the variable header + payload by adding up the lengths
* Now calculate the length of the variable header + payload by adding up the lengths
...
@@ -51,12 +50,13 @@ class WireMessage {
...
@@ -51,12 +50,13 @@ class WireMessage {
var
willMessagePayloadBytes
;
var
willMessagePayloadBytes
;
// if the message contains a messageIdentifier then we need two bytes for that
// if the message contains a messageIdentifier then we need two bytes for that
if
(
this
.
messageIdentifier
!==
undefined
)
remLength
+=
2
;
if
(
this
.
messageIdentifier
!==
undefined
)
remLength
+=
2
;
switch
(
this
.
type
)
{
switch
(
this
.
type
)
{
// If this a Connect then we need to include 12 bytes for its header
// If this a Connect then we need to include 12 bytes for its header
case
MESSAGE_TYPE
.
CONNECT
:
case
MESSAGE_TYPE
.
CONNECT
:
switch
(
this
.
mqttVersion
)
{
switch
(
this
.
mqttVersion
)
{
case
3
:
case
3
:
remLength
+=
MqttProtoIdentifierv3
.
length
+
3
;
remLength
+=
MqttProtoIdentifierv3
.
length
+
3
;
break
;
break
;
...
@@ -72,7 +72,7 @@ class WireMessage {
...
@@ -72,7 +72,7 @@ class WireMessage {
willMessagePayloadBytes
=
this
.
willMessage
.
payloadBytes
;
willMessagePayloadBytes
=
this
.
willMessage
.
payloadBytes
;
if
(
!
(
willMessagePayloadBytes
instanceof
Uint8Array
))
if
(
!
(
willMessagePayloadBytes
instanceof
Uint8Array
))
willMessagePayloadBytes
=
new
Uint8Array
(
payloadBytes
);
willMessagePayloadBytes
=
new
Uint8Array
(
payloadBytes
);
remLength
+=
willMessagePayloadBytes
.
byteLength
+
2
;
remLength
+=
willMessagePayloadBytes
.
byteLength
+
2
;
}
}
if
(
this
.
userName
!==
undefined
)
if
(
this
.
userName
!==
undefined
)
remLength
+=
UTF8Length
(
this
.
userName
)
+
2
;
remLength
+=
UTF8Length
(
this
.
userName
)
+
2
;
...
@@ -83,7 +83,7 @@ class WireMessage {
...
@@ -83,7 +83,7 @@ class WireMessage {
// Subscribe, Unsubscribe can both contain topic strings
// Subscribe, Unsubscribe can both contain topic strings
case
MESSAGE_TYPE
.
SUBSCRIBE
:
case
MESSAGE_TYPE
.
SUBSCRIBE
:
first
|=
0x02
;
// Qos = 1;
first
|=
0x02
;
// Qos = 1;
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
topicStrLength
[
i
]
=
UTF8Length
(
this
.
topics
[
i
]);
topicStrLength
[
i
]
=
UTF8Length
(
this
.
topics
[
i
]);
remLength
+=
topicStrLength
[
i
]
+
2
;
remLength
+=
topicStrLength
[
i
]
+
2
;
}
}
...
@@ -93,7 +93,7 @@ class WireMessage {
...
@@ -93,7 +93,7 @@ class WireMessage {
case
MESSAGE_TYPE
.
UNSUBSCRIBE
:
case
MESSAGE_TYPE
.
UNSUBSCRIBE
:
first
|=
0x02
;
// Qos = 1;
first
|=
0x02
;
// Qos = 1;
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
topicStrLength
[
i
]
=
UTF8Length
(
this
.
topics
[
i
]);
topicStrLength
[
i
]
=
UTF8Length
(
this
.
topics
[
i
]);
remLength
+=
topicStrLength
[
i
]
+
2
;
remLength
+=
topicStrLength
[
i
]
+
2
;
}
}
...
@@ -105,7 +105,7 @@ class WireMessage {
...
@@ -105,7 +105,7 @@ class WireMessage {
case
MESSAGE_TYPE
.
PUBLISH
:
case
MESSAGE_TYPE
.
PUBLISH
:
if
(
this
.
payloadMessage
.
duplicate
)
first
|=
0x08
;
if
(
this
.
payloadMessage
.
duplicate
)
first
|=
0x08
;
first
=
first
|=
this
.
payloadMessage
.
qos
<<
1
;
first
=
first
|=
(
this
.
payloadMessage
.
qos
<<
1
)
;
if
(
this
.
payloadMessage
.
retained
)
first
|=
0x01
;
if
(
this
.
payloadMessage
.
retained
)
first
|=
0x01
;
destinationNameLength
=
UTF8Length
(
this
.
payloadMessage
.
destinationName
);
destinationNameLength
=
UTF8Length
(
this
.
payloadMessage
.
destinationName
);
remLength
+=
destinationNameLength
+
2
;
remLength
+=
destinationNameLength
+
2
;
...
@@ -133,17 +133,13 @@ class WireMessage {
...
@@ -133,17 +133,13 @@ class WireMessage {
//Write the fixed header into the buffer
//Write the fixed header into the buffer
byteStream
[
0
]
=
first
;
byteStream
[
0
]
=
first
;
byteStream
.
set
(
mbi
,
1
);
byteStream
.
set
(
mbi
,
1
);
// If this is a PUBLISH then the variable header starts with a topic
// If this is a PUBLISH then the variable header starts with a topic
if
(
this
.
type
==
MESSAGE_TYPE
.
PUBLISH
)
if
(
this
.
type
==
MESSAGE_TYPE
.
PUBLISH
)
pos
=
writeString
(
pos
=
writeString
(
this
.
payloadMessage
.
destinationName
,
destinationNameLength
,
byteStream
,
pos
);
this
.
payloadMessage
.
destinationName
,
destinationNameLength
,
byteStream
,
pos
);
// If this is a CONNECT then the variable header contains the protocol name/version, flags and keepalive time
// If this is a CONNECT then the variable header contains the protocol name/version, flags and keepalive time
else
if
(
this
.
type
==
MESSAGE_TYPE
.
CONNECT
)
{
else
if
(
this
.
type
==
MESSAGE_TYPE
.
CONNECT
)
{
switch
(
this
.
mqttVersion
)
{
switch
(
this
.
mqttVersion
)
{
case
3
:
case
3
:
...
@@ -156,61 +152,41 @@ class WireMessage {
...
@@ -156,61 +152,41 @@ class WireMessage {
break
;
break
;
}
}
var
connectFlags
=
0
;
var
connectFlags
=
0
;
if
(
this
.
cleanSession
)
connectFlags
=
0x02
;
if
(
this
.
cleanSession
)
if
(
this
.
willMessage
!==
undefined
)
{
connectFlags
=
0x02
;
if
(
this
.
willMessage
!==
undefined
)
{
connectFlags
|=
0x04
;
connectFlags
|=
0x04
;
connectFlags
|=
this
.
willMessage
.
qos
<<
3
;
connectFlags
|=
(
this
.
willMessage
.
qos
<<
3
)
;
if
(
this
.
willMessage
.
retained
)
{
if
(
this
.
willMessage
.
retained
)
{
connectFlags
|=
0x20
;
connectFlags
|=
0x20
;
}
}
}
}
if
(
this
.
userName
!==
undefined
)
connectFlags
|=
0x80
;
if
(
this
.
userName
!==
undefined
)
if
(
this
.
password
!==
undefined
)
connectFlags
|=
0x40
;
connectFlags
|=
0x80
;
if
(
this
.
password
!==
undefined
)
connectFlags
|=
0x40
;
byteStream
[
pos
++
]
=
connectFlags
;
byteStream
[
pos
++
]
=
connectFlags
;
pos
=
writeUint16
(
this
.
keepAliveInterval
,
byteStream
,
pos
);
pos
=
writeUint16
(
this
.
keepAliveInterval
,
byteStream
,
pos
);
}
}
// Output the messageIdentifier - if there is one
// Output the messageIdentifier - if there is one
if
(
this
.
messageIdentifier
!==
undefined
)
if
(
this
.
messageIdentifier
!==
undefined
)
pos
=
writeUint16
(
this
.
messageIdentifier
,
byteStream
,
pos
);
pos
=
writeUint16
(
this
.
messageIdentifier
,
byteStream
,
pos
);
switch
(
this
.
type
)
{
switch
(
this
.
type
)
{
case
MESSAGE_TYPE
.
CONNECT
:
case
MESSAGE_TYPE
.
CONNECT
:
pos
=
writeString
(
pos
=
writeString
(
this
.
clientId
,
UTF8Length
(
this
.
clientId
),
byteStream
,
pos
);
this
.
clientId
,
UTF8Length
(
this
.
clientId
),
byteStream
,
pos
);
if
(
this
.
willMessage
!==
undefined
)
{
if
(
this
.
willMessage
!==
undefined
)
{
pos
=
writeString
(
pos
=
writeString
(
this
.
willMessage
.
destinationName
,
UTF8Length
(
this
.
willMessage
.
destinationName
),
byteStream
,
pos
);
this
.
willMessage
.
destinationName
,
pos
=
writeUint16
(
willMessagePayloadBytes
.
byteLength
,
byteStream
,
pos
);
UTF8Length
(
this
.
willMessage
.
destinationName
),
byteStream
,
pos
);
pos
=
writeUint16
(
willMessagePayloadBytes
.
byteLength
,
byteStream
,
pos
);
byteStream
.
set
(
willMessagePayloadBytes
,
pos
);
byteStream
.
set
(
willMessagePayloadBytes
,
pos
);
pos
+=
willMessagePayloadBytes
.
byteLength
;
pos
+=
willMessagePayloadBytes
.
byteLength
;
}
}
if
(
this
.
userName
!==
undefined
)
if
(
this
.
userName
!==
undefined
)
pos
=
writeString
(
pos
=
writeString
(
this
.
userName
,
UTF8Length
(
this
.
userName
),
byteStream
,
pos
);
this
.
userName
,
UTF8Length
(
this
.
userName
),
byteStream
,
pos
);
if
(
this
.
password
!==
undefined
)
if
(
this
.
password
!==
undefined
)
pos
=
writeString
(
pos
=
writeString
(
this
.
password
,
UTF8Length
(
this
.
password
),
byteStream
,
pos
);
this
.
password
,
UTF8Length
(
this
.
password
),
byteStream
,
pos
);
break
;
break
;
case
MESSAGE_TYPE
.
PUBLISH
:
case
MESSAGE_TYPE
.
PUBLISH
:
...
@@ -226,7 +202,7 @@ class WireMessage {
...
@@ -226,7 +202,7 @@ class WireMessage {
case
MESSAGE_TYPE
.
SUBSCRIBE
:
case
MESSAGE_TYPE
.
SUBSCRIBE
:
// SUBSCRIBE has a list of topic strings and request QoS
// SUBSCRIBE has a list of topic strings and request QoS
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
{
pos
=
writeString
(
this
.
topics
[
i
],
topicStrLength
[
i
],
byteStream
,
pos
);
pos
=
writeString
(
this
.
topics
[
i
],
topicStrLength
[
i
],
byteStream
,
pos
);
byteStream
[
pos
++
]
=
this
.
requestedQos
[
i
];
byteStream
[
pos
++
]
=
this
.
requestedQos
[
i
];
}
}
...
@@ -234,7 +210,7 @@ class WireMessage {
...
@@ -234,7 +210,7 @@ class WireMessage {
case
MESSAGE_TYPE
.
UNSUBSCRIBE
:
case
MESSAGE_TYPE
.
UNSUBSCRIBE
:
// UNSUBSCRIBE has a list of topic strings
// UNSUBSCRIBE has a list of topic strings
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
for
(
var
i
=
0
;
i
<
this
.
topics
.
length
;
i
++
)
pos
=
writeString
(
this
.
topics
[
i
],
topicStrLength
[
i
],
byteStream
,
pos
);
pos
=
writeString
(
this
.
topics
[
i
],
topicStrLength
[
i
],
byteStream
,
pos
);
break
;
break
;
...
@@ -243,8 +219,6 @@ class WireMessage {
...
@@ -243,8 +219,6 @@ class WireMessage {
}
}
return
buffer
;
return
buffer
;
}
};
}
export
default
WireMessage
;
export
default
WritableStream
\ No newline at end of file
\ No newline at end of file
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment