{"url":"http://public2.vulnerablecode.io/api/packages/458878?format=json","purl":"pkg:gem/spree@3.1.12","type":"gem","namespace":"","name":"spree","version":"3.1.12","qualifiers":{},"subpath":"","is_vulnerable":true,"next_non_vulnerable_version":"3.7.13","latest_non_vulnerable_version":"4.1.12","affected_by_vulnerabilities":[{"url":"http://public2.vulnerablecode.io/api/vulnerabilities/39402?format=json","vulnerability_id":"VCID-tv8v-rtrc-xybd","summary":"Ensure that doorkeeper_token is valid when authenticating requests in API v2 calls\n### Impact\nThe perpetrator who previously obtained an old expired user token could use it to access Storefront API v2 endpoints. \n\n### Patches\nPlease upgrade to 3.7.11, 4.0.4, or 4.1.11 depending on your used Spree version. \n\n### Workarounds\nIn your project directory create a decorator file `app/controllers/spree/api/v2/base_controller_decotatror.rb` with contents:\n\n```ruby\nmodule Spree\n  module Api\n    module V2\n      module BaseControllerDecorator\n        private\n\n        def spree_current_user\n          return nil unless doorkeeper_token\n          return @spree_current_user if @spree_current_user\n\n          doorkeeper_authorize!\n\n          @spree_current_user ||= ::Spree.user_class.find_by(id: doorkeeper_token.resource_owner_id)\n        end\n     end\n  end\nend\n\nSpree::Api::V2::BaseController.prepend(Spree::Api::V2::BaseControllerDecorator)\n```\n\n### For more information\nIf you have any questions or comments about this advisory:\n* Email us at [security@spreecommerce.org](mailto:security@spreecommerce.org)","references":[{"reference_url":"https://api.first.org/data/v1/epss?cve=CVE-2020-15269","reference_id":"","reference_type":"","scores":[{"value":"0.00257","scoring_system":"epss","scoring_elements":"0.49247","published_at":"2026-05-29T12:55:00Z"}],"url":"https://api.first.org/data/v1/epss?cve=CVE-2020-15269"},{"reference_url":"https://github.com/rubysec/ruby-advisory-db/blob/master/gems/spree/CVE-2020-15269.yml","reference_id":"","reference_type":"","scores":[{"value":"7.4","scoring_system":"cvssv3.1","scoring_elements":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N"},{"value":"HIGH","scoring_system":"generic_textual","scoring_elements":""}],"url":"https://github.com/rubysec/ruby-advisory-db/blob/master/gems/spree/CVE-2020-15269.yml"},{"reference_url":"https://github.com/spree/spree","reference_id":"","reference_type":"","scores":[{"value":"7.4","scoring_system":"cvssv3.1","scoring_elements":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N"},{"value":"HIGH","scoring_system":"generic_textual","scoring_elements":""}],"url":"https://github.com/spree/spree"},{"reference_url":"https://github.com/spree/spree/commit/e43643abfe51f54bd9208dd02298b366e9b9a847","reference_id":"","reference_type":"","scores":[{"value":"7.4","scoring_system":"cvssv3.1","scoring_elements":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N"},{"value":"HIGH","scoring_system":"generic_textual","scoring_elements":""}],"url":"https://github.com/spree/spree/commit/e43643abfe51f54bd9208dd02298b366e9b9a847"},{"reference_url":"https://github.com/spree/spree/security/advisories/GHSA-f8cm-364f-q9qh","reference_id":"","reference_type":"","scores":[{"value":"7.4","scoring_system":"cvssv3","scoring_elements":""},{"value":"7.4","scoring_system":"cvssv3.1","scoring_elements":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N"},{"value":"HIGH","scoring_system":"cvssv3.1_qr","scoring_elements":""},{"value":"HIGH","scoring_system":"generic_textual","scoring_elements":""}],"url":"https://github.com/spree/spree/security/advisories/GHSA-f8cm-364f-q9qh"},{"reference_url":"https://nvd.nist.gov/vuln/detail/CVE-2020-15269","reference_id":"","reference_type":"","scores":[{"value":"7.4","scoring_system":"cvssv3.1","scoring_elements":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N"},{"value":"HIGH","scoring_system":"generic_textual","scoring_elements":""}],"url":"https://nvd.nist.gov/vuln/detail/CVE-2020-15269"},{"reference_url":"https://github.com/advisories/GHSA-f8cm-364f-q9qh","reference_id":"GHSA-f8cm-364f-q9qh","reference_type":"","scores":[{"value":"HIGH","scoring_system":"cvssv3.1_qr","scoring_elements":""}],"url":"https://github.com/advisories/GHSA-f8cm-364f-q9qh"}],"fixed_packages":[{"url":"http://public2.vulnerablecode.io/api/packages/73175?format=json","purl":"pkg:gem/spree@3.7.11","is_vulnerable":true,"affected_by_vulnerabilities":[{"vulnerability":"VCID-fufy-pmm5-gyap"}],"resource_url":"http://public2.vulnerablecode.io/packages/pkg:gem/spree@3.7.11"},{"url":"http://public2.vulnerablecode.io/api/packages/73176?format=json","purl":"pkg:gem/spree@4.0.4","is_vulnerable":true,"affected_by_vulnerabilities":[{"vulnerability":"VCID-fufy-pmm5-gyap"}],"resource_url":"http://public2.vulnerablecode.io/packages/pkg:gem/spree@4.0.4"},{"url":"http://public2.vulnerablecode.io/api/packages/73177?format=json","purl":"pkg:gem/spree@4.1.11","is_vulnerable":true,"affected_by_vulnerabilities":[{"vulnerability":"VCID-fufy-pmm5-gyap"}],"resource_url":"http://public2.vulnerablecode.io/packages/pkg:gem/spree@4.1.11"}],"aliases":["CVE-2020-15269","GHSA-f8cm-364f-q9qh"],"risk_score":null,"exploitability":null,"weighted_severity":null,"resource_url":"http://public2.vulnerablecode.io/vulnerabilities/VCID-tv8v-rtrc-xybd"}],"fixing_vulnerabilities":[],"risk_score":null,"resource_url":"http://public2.vulnerablecode.io/packages/pkg:gem/spree@3.1.12"}