CVE-2023-50713

Source
https://nvd.nist.gov/vuln/detail/CVE-2023-50713
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2023-50713.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2023-50713
Related
  • GHSA-xpf3-5q5x-3qwh
Published
2023-12-14T19:15:16Z
Modified
2025-01-08T15:24:10.146515Z
Severity
  • 5.0 (Medium) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L CVSS Calculator
Summary
[none]
Details

Speckle Server provides server, frontend, 3D viewer, and other JavaScript utilities for the Speckle 3D data platform. A vulnerability in versions prior to 2.17.6 affects users who: authorized an application which requested a 'token write' scope or, using frontend-2, created a Personal Access Token (PAT) with token write scope. When creating a new token an agent needs to authorise the request with an existing token (the 'requesting token'). The requesting token is required to have token write scope in order to generate new tokens. However, Speckle server was not verifying that other privileges granted to the new token were not in excess of the privileges of the requesting token. A malicious actor could use a token with only token write scope to subsequently generate further tokens with additional privileges. These privileges would only grant privileges up to the existing privileges of the user. This vulnerability cannot be used to escalate a user's privileges or grant privileges on behalf of other users.

This has been patched as of version 2.17.6. All operators of Speckle servers should upgrade their server to version 2.17.6 or higher. Any users who authorized an application with 'token write' scope, or created a token in frontend-2 with token write scope should review existing tokens and permanently revoke any they do not recognize, revoke existing tokens and create new tokens, and review usage of their account for suspicious activity. No known workarounds for this issue exist.

References

Affected packages

Git / github.com/specklesystems/speckle-server

Affected ranges

Type
GIT
Repo
https://github.com/specklesystems/speckle-server
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Fixed
Fixed

Affected versions

2.*

2.10.0
2.10.1
2.10.2
2.10.3
2.11.0
2.11.1
2.11.2
2.11.3
2.11.4
2.12.0
2.12.1
2.12.2
2.12.3
2.12.4
2.12.5
2.13.0
2.13.2
2.13.3
2.14.0
2.14.1
2.14.2
2.14.3
2.14.4
2.14.5
2.14.6
2.14.7
2.15.0
2.15.1
2.16.0
2.17.0
2.17.1
2.17.2
2.17.3
2.17.4
2.17.5
2.3.10
2.3.12
2.3.13
2.3.14
2.3.15
2.3.4
2.3.5
2.3.6
2.3.7
2.3.8
2.3.9
2.5.0
2.5.1
2.5.2
2.5.3
2.5.4
2.5.5
2.6.0
2.6.1
2.6.2
2.6.3
2.7.0
2.7.1
2.8.0
2.8.1
2.8.2
2.9.0
2.9.1

@speckle/fileimport-service@2.*

@speckle/fileimport-service@2.3.17
@speckle/fileimport-service@2.3.17-alpha.2830
@speckle/fileimport-service@2.3.17-alpha.2844
@speckle/fileimport-service@2.3.17-alpha.2856
@speckle/fileimport-service@2.3.17-alpha.2867
@speckle/fileimport-service@2.3.17-alpha.2878
@speckle/fileimport-service@2.3.17-alpha.2889

@speckle/frontend@2.*

@speckle/frontend@2.3.17
@speckle/frontend@2.3.17-alpha.2830
@speckle/frontend@2.3.17-alpha.2844
@speckle/frontend@2.3.17-alpha.2856
@speckle/frontend@2.3.17-alpha.2867
@speckle/frontend@2.3.17-alpha.2878
@speckle/frontend@2.3.17-alpha.2889

@speckle/objectloader@2.*

@speckle/objectloader@2.3.17-alpha.2830
@speckle/objectloader@2.3.17-alpha.2844
@speckle/objectloader@2.3.17-alpha.2856
@speckle/objectloader@2.3.17-alpha.2867
@speckle/objectloader@2.3.17-alpha.2878
@speckle/objectloader@2.3.17-alpha.2889
@speckle/objectloader@2.4.3

@speckle/preview-service@2.*

@speckle/preview-service@2.3.17-alpha.2830
@speckle/preview-service@2.3.17-alpha.2844
@speckle/preview-service@2.3.17-alpha.2856
@speckle/preview-service@2.3.17-alpha.2867
@speckle/preview-service@2.3.17-alpha.2878
@speckle/preview-service@2.3.17-alpha.2889
@speckle/preview-service@2.4.3

@speckle/server@2.*

@speckle/server@2.3.17
@speckle/server@2.3.17-alpha.2830
@speckle/server@2.3.17-alpha.2844
@speckle/server@2.3.17-alpha.2856
@speckle/server@2.3.17-alpha.2867
@speckle/server@2.3.17-alpha.2878
@speckle/server@2.3.17-alpha.2889

@speckle/viewer-sandbox@1.*

@speckle/viewer-sandbox@1.0.1

@speckle/viewer@2.*

@speckle/viewer@2.3.17-alpha.2830
@speckle/viewer@2.3.17-alpha.2844
@speckle/viewer@2.3.17-alpha.2856
@speckle/viewer@2.3.17-alpha.2867
@speckle/viewer@2.3.17-alpha.2878
@speckle/viewer@2.3.17-alpha.2889
@speckle/viewer@2.4.3

@speckle/webhook-service@2.*

@speckle/webhook-service@2.3.17
@speckle/webhook-service@2.3.17-alpha.2830
@speckle/webhook-service@2.3.17-alpha.2844
@speckle/webhook-service@2.3.17-alpha.2856
@speckle/webhook-service@2.3.17-alpha.2867
@speckle/webhook-service@2.3.17-alpha.2878
@speckle/webhook-service@2.3.17-alpha.2889

Other

list

test.*

test.1

v0.*

v0.0.1-test

v2.*

v2.2.0
v2.2.1
v2.2.10
v2.2.11
v2.2.12
v2.2.13
v2.2.14
v2.2.15
v2.2.16
v2.2.17
v2.2.18
v2.2.19
v2.2.2
v2.2.20
v2.2.21
v2.2.3
v2.2.4
v2.2.5
v2.2.6
v2.2.7
v2.2.8
v2.2.9
v2.3.0
v2.3.1
v2.3.2
v2.3.3