
Research
/Security News
10 npm Typosquatted Packages Deploy Multi-Stage Credential Harvester
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.
@nuxt/devalue
Advanced tools
Forked from devalue to log errors on non-serializable properties rather than throwing
Error.
Like JSON.stringify, but handles
obj.self = obj)[value, value])undefined, Infinity, NaN, -0Map and Set.toJSON() method for non-POJOsTry it out on runkit.com.
import devalue from '@nuxt/devalue';
let obj = { a: 1, b: 2 };
obj.c = 3;
devalue(obj); // '{a:1,b:2,c:3}'
obj.self = obj;
devalue(obj); // '(function(a){a.a=1;a.b=2;a.c=3;a.self=a;return a}({}))'
If devalue encounters a function or a non-POJO, it will throw an error.
Say you're server-rendering a page and want to serialize some state, which could include user input. JSON.stringify doesn't protect against XSS attacks:
const state = {
userinput: `</script><script src='https://evil.com/mwahaha.js'>`
};
const template = `
<script>
// NEVER DO THIS
var preloaded = ${JSON.stringify(state)};
</script>`;
Which would result in this:
<script>
// NEVER DO THIS
var preloaded = {"userinput":"</script><script src='https://evil.com/mwahaha.js'>"};
</script>
Using devalue, we're protected against that attack:
const template = `
<script>
var preloaded = ${devalue(state)};
</script>`;
<script>
var preloaded = {userinput:"\\u003C\\u002Fscript\\u003E\\u003Cscript src=\'https:\\u002F\\u002Fevil.com\\u002Fmwahaha.js\'\\u003E"};
</script>
This, along with the fact that devalue bails on functions and non-POJOs, stops attackers from executing arbitrary code. Strings generated by devalue can be safely deserialized with eval or new Function:
const value = (0,eval)('(' + str + ')');
While devalue prevents the XSS vulnerability shown above, meaning you can use it to send data from server to client, you should not send user data from client to server using the same method. Since it has to be evaluated, an attacker that successfully submitted data that bypassed devalue would have access to your system.
When using eval, ensure that you call it indirectly so that the evaluated code doesn't have access to the surrounding scope:
{
const sensitiveData = 'Setec Astronomy';
eval('sendToEvilServer(sensitiveData)'); // pwned :(
(0,eval)('sendToEvilServer(sensitiveData)'); // nice try, evildoer!
}
Using new Function(code) is akin to using indirect eval.
serialize-javascript is a library that serializes JavaScript objects into a JSON-compliant string. It supports functions, dates, regexes, and more. Compared to @nuxt/devalue, serialize-javascript is more focused on JSON compliance and may not handle some complex data structures as gracefully.
json-stringify-safe is a library that provides a safe version of JSON.stringify, handling circular references gracefully. While it doesn't offer the same level of serialization for complex data types as @nuxt/devalue, it is useful for avoiding errors with circular references.
flatted is a library that allows you to serialize and parse circular JSON structures. It is similar to @nuxt/devalue in that it can handle complex data structures, but it is specifically designed for circular references.
FAQs
Gets the job done when JSON.stringify can't
The npm package @nuxt/devalue receives a total of 772,604 weekly downloads. As such, @nuxt/devalue popularity was classified as popular.
We found that @nuxt/devalue demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Research
/Security News
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.