Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
converse.js
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
converse.js
Commits
e81eaf32
Commit
e81eaf32
authored
Jan 31, 2017
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prevent forging of messages via carbons.
parent
0cf99037
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
53 additions
and
2 deletions
+53
-2
docs/CHANGES.md
docs/CHANGES.md
+1
-0
spec/chatbox.js
spec/chatbox.js
+44
-1
src/converse-core.js
src/converse-core.js
+8
-1
No files found.
docs/CHANGES.md
View file @
e81eaf32
...
@@ -10,6 +10,7 @@
...
@@ -10,6 +10,7 @@
-
Bugfix. Login form wasn't rendered after logging out (when
`auto_reconnect`
is
`true`
). [jcbrand]
-
Bugfix. Login form wasn't rendered after logging out (when
`auto_reconnect`
is
`true`
). [jcbrand]
-
Bugfix. Properly disconnect upon "host-unknown" error. [jcbrand]
-
Bugfix. Properly disconnect upon "host-unknown" error. [jcbrand]
-
Bugfix. Minimized chats weren't removed when logging out. [jcbrand]
-
Bugfix. Minimized chats weren't removed when logging out. [jcbrand]
-
Security fix: Prevent message forging via carbons. (Thanks to ge0rg) [jcbrand]
## 2.0.4 (2016-12-13)
## 2.0.4 (2016-12-13)
-
#737: Bugfix. Translations weren't being applied. [jcbrand]
-
#737: Bugfix. Translations weren't being applied. [jcbrand]
...
...
spec/chatbox.js
View file @
e81eaf32
...
@@ -766,7 +766,7 @@
...
@@ -766,7 +766,7 @@
var
msgtext
=
'
This is a carbon message
'
;
var
msgtext
=
'
This is a carbon message
'
;
var
sender_jid
=
mock
.
cur_names
[
1
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
var
sender_jid
=
mock
.
cur_names
[
1
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
var
msg
=
$msg
({
var
msg
=
$msg
({
'
from
'
:
converse
.
bare
_jid
,
'
from
'
:
sender
_jid
,
'
id
'
:
(
new
Date
()).
getTime
(),
'
id
'
:
(
new
Date
()).
getTime
(),
'
to
'
:
converse
.
connection
.
jid
,
'
to
'
:
converse
.
connection
.
jid
,
'
type
'
:
'
chat
'
,
'
type
'
:
'
chat
'
,
...
@@ -844,6 +844,49 @@
...
@@ -844,6 +844,49 @@
expect
(
msg_txt
).
toEqual
(
msgtext
);
expect
(
msg_txt
).
toEqual
(
msgtext
);
}));
}));
it
(
"
will be discarded if it's a malicious message meant to look like a carbon copy
"
,
mock
.
initConverse
(
function
(
converse
)
{
test_utils
.
createContacts
(
converse
,
'
current
'
);
test_utils
.
openControlBox
();
test_utils
.
openContactsPanel
(
converse
);
/* <message from="mallory@evil.example" to="b@xmpp.example">
* <received xmlns='urn:xmpp:carbons:2'>
* <forwarded xmlns='urn:xmpp:forward:0'>
* <message from="alice@xmpp.example" to="bob@xmpp.example/client1">
* <body>Please come to Creepy Valley tonight, alone!</body>
* </message>
* </forwarded>
* </received>
* </message>
*/
spyOn
(
converse
,
'
log
'
);
var
msgtext
=
'
Please come to Creepy Valley tonight, alone!
'
;
var
sender_jid
=
mock
.
cur_names
[
1
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
var
impersonated_jid
=
mock
.
cur_names
[
2
].
replace
(
/ /g
,
'
.
'
).
toLowerCase
()
+
'
@localhost
'
;
var
msg
=
$msg
({
'
from
'
:
sender_jid
,
'
id
'
:
(
new
Date
()).
getTime
(),
'
to
'
:
converse
.
connection
.
jid
,
'
type
'
:
'
chat
'
,
'
xmlns
'
:
'
jabber:client
'
}).
c
(
'
received
'
,
{
'
xmlns
'
:
'
urn:xmpp:carbons:2
'
})
.
c
(
'
forwarded
'
,
{
'
xmlns
'
:
'
urn:xmpp:forward:0
'
})
.
c
(
'
message
'
,
{
'
xmlns
'
:
'
jabber:client
'
,
'
from
'
:
impersonated_jid
,
'
to
'
:
converse
.
connection
.
jid
,
'
type
'
:
'
chat
'
}).
c
(
'
body
'
).
t
(
msgtext
).
tree
();
converse
.
chatboxes
.
onMessage
(
msg
);
// Check that chatbox for impersonated user is not created.
var
chatbox
=
converse
.
chatboxes
.
get
(
impersonated_jid
);
expect
(
chatbox
).
not
.
toBeDefined
();
// Check that the chatbox for the malicous user is not created
chatbox
=
converse
.
chatboxes
.
get
(
sender_jid
);
expect
(
chatbox
).
not
.
toBeDefined
();
}));
it
(
"
received for a minimized chat box will increment a counter on its header
"
,
mock
.
initConverse
(
function
(
converse
)
{
it
(
"
received for a minimized chat box will increment a counter on its header
"
,
mock
.
initConverse
(
function
(
converse
)
{
test_utils
.
createContacts
(
converse
,
'
current
'
);
test_utils
.
createContacts
(
converse
,
'
current
'
);
test_utils
.
openControlBox
();
test_utils
.
openControlBox
();
...
...
src/converse-core.js
View file @
e81eaf32
...
@@ -1447,7 +1447,14 @@
...
@@ -1447,7 +1447,14 @@
}
}
$forwarded
=
$message
.
find
(
'
forwarded
'
);
$forwarded
=
$message
.
find
(
'
forwarded
'
);
if
(
$forwarded
.
length
)
{
if
(
$forwarded
.
length
)
{
$message
=
$forwarded
.
children
(
'
message
'
);
var
$forwarded_message
=
$forwarded
.
children
(
'
message
'
);
if
(
Strophe
.
getBareJidFromJid
(
$forwarded_message
.
attr
(
'
from
'
))
!==
from_jid
)
{
// Prevent message forging via carbons
//
// https://xmpp.org/extensions/xep-0280.html#security
return
true
;
}
$message
=
$forwarded_message
;
$delay
=
$forwarded
.
children
(
'
delay
'
);
$delay
=
$forwarded
.
children
(
'
delay
'
);
from_jid
=
$message
.
attr
(
'
from
'
);
from_jid
=
$message
.
attr
(
'
from
'
);
to_jid
=
$message
.
attr
(
'
to
'
);
to_jid
=
$message
.
attr
(
'
to
'
);
...
...
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