sxw.js
4.0.0
dotnet add package sxw.js --version 4.0.0
NuGet\Install-Package sxw.js -Version 4.0.0
<PackageReference Include="sxw.js" Version="4.0.0" />
paket add sxw.js --version 4.0.0
#r "nuget: sxw.js, 4.0.0"
// Install sxw.js as a Cake Addin #addin nuget:?package=sxw.js&version=4.0.0 // Install sxw.js as a Cake Tool #tool nuget:?package=sxw.js&version=4.0.0
SXW.js
SXW.js is a javascript library that is used to display console warnings against Self XSS attacks.
Usage
Using nuget
- Install the nuget package
- Include the sxw.js file from the content folder into your website.
- At the end of the HTML document call the printWarning function in
window.sxwjs
similar to the one mentioned above.
Using npm
- Install the npm package using
npm i @sxwjs/sxwjs
- Import sxwjs module
- Call the required function inside sxwjs module
import sxwjs from '@sxwjs/sxwjs'; ... ... sxwjs.printWarning();
Using js file directly
- Include the sxw.js file in your website.
- The script will register built-in functions into
window.sxwjs
object. - At the end of the HTML document call the printWarning function in
window.sxwjs
as shown in the sample code.<script> window.sxwjs.printWarning(); </script>
Customizations
Sections
The warning displayed in console contains three sections.
- A huge STOP sign
- A caution text in bold
- A detailed message saying that this section is intented for developers only. It also warns aginst copy pasting content in the console.
Configuration
SXW.js has a config object with the following variables,
Variable name | Default value | Description |
---|---|---|
stopColor | red | the colour of the stop sign |
stopFontWeight | bold | Font weight for stop sign |
cautionFontWeight | bold | Font weight for caution sign |
cautionFontSize | 15px | Font size for caution sign |
Example js object:
var config = {
stopColor: "red",
stopFontWeight: "bold",
cautionFontWeight: "bold",
cautionFontSize: "15px",
};
Content
SXW.js has a predefined object with the following variables for defining the content to be displayed,
Variable name | Default value | Description |
---|---|---|
stopText | * based stop sign text |
The text used to print STOP sign |
cautionText | Caution: DO NOT PROCEED. | Text for caution notice |
warningText | This section is intended for developers only. Don't copy paste anything in this area.\nIf someone told you to copy and paste something here, it is a scam and will give them access to your account. In that case, kindly report this to our support team. | The content of the detailed error message |
var content = {
en: {
stopText: "********* ********* ********* *********\n*** *** *** *** *** ***\n*** *** *** *** *** ***\n********* *** *** *** *********\n *** *** *** *** ***\n *** *** *** *** ***\n********* *** ********* ***",
cautionText: "Caution: DO NOT PROCEED.",
warningText: "This section is intended for developers only. Don't copy paste anything in this area.\nIf someone told you to copy and paste something here, it is a scam and will give them access to your account. In that case, kindly report this to our support team."
}
};
You can define content in multiple languages as shown here. Just pass the appropriate language code to the printing function.
Functions
There are three functions in the library that will be available into the window.sxwjs
object.
printStop
- Prints just the huge stop sign.printCautionNotice
- Prints the caution notice.printWarningText
- Prints the the detailed error message.printWarning
- Prints all the three sections.setConfig
- Assigns the provided configuration.getConfig
- Retrives the configuration.setContent
- Can be used to modifiy the content such as warningText, cautionNotice, etc...getContent
- Retrives the content that will be displayed on the console.
None of these functions are called by default. You can choose to call them as you wish.
Example Usage:
window.sxwjs.setConfig(myConfig);
window.sxwjs.printWarning('en');
window.sxwjs.printStop('en');
window.sxwjs.printCautionNotice('en');
Learn more about Target Frameworks and .NET Standard.
This package has no dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.