0.0.11 • Published 3 years ago
manual-data-masking v0.0.11
A super light javascript library for manual datamasking.
Manual data masking ?
Manual data masking is an operation that label and hide sensitive data, create new text that hides (masks) sensitive information.
Imagine that there is a customer comment which includes sensitive data like swear word, person name, home address...
e.g.
Damn it, The phone i just bought last week has been broken 😠, I need refund
right now, Call me on this phone number: 080808080.By using manual-data-masking you can do manual data masking job like this:
Of course, data masked and text after data masking will be generated by manual-data-masking at the same time:
data masked:
[
  {
    content: "Damn it",
    category: "Person Name",
    start: 0, // start index in text string
    end: 7, // start index in text string
  },
  {
    content: "080808080",
    category: "Phone Number",
    start: 120,
    end: 129,
  },
];text after data masking:
*******, The phone i just bought last week has been broken 😠, I need refund
right now, Call me on this phone number: *********.How to use in your project
ES modules
npm install manual-data-maskingimport { create as createManualDataMasking } from "manual-data-masking";
const dataMasked = [
  {
    "content": "Damn it",
    "category": "Person Name",
    "start": 0,
    "end": 7
  }
]
const categories = [
  {
    "value": "Person Name",
    "color": "#b6656c"
  },
  {
    "value": "Swear Word",
    "color": "#577eba"
  },
  {
    "value": "Phone Number",
    "color": "#3e6146"
  }
]
const text = "Damn it, The phone i just bought last week has been broken 😠, \n I need refund right now, Call me on this phone number: 080808080."
const $manualDataMasking = createManualDataMasking({
  container: document.getElementById("demo"),
  text,
  dataMasked,
  categories,
  replaceCharactor: "*",
  dataMaskingCharactor: "X",
  maxHeight: 100
})
$manualDataMasking.on("afterDataMasking", (dataMasked, textAfterDataMasking) => {
  console.log(JSON.stringify(dataMasked));
  console.log(textAfterDataMasking);
})
</script>Script tag:
<script src="https://unpkg.com/manual-data-masking"></script>
<script>
  const dataMasked = [
    {
      content: "Damn it",
      category: "Person Name",
      start: 0,
      end: 7,
    },
  ];
  const categories = [
    {
      value: "Person Name",
      color: "#b6656c",
    },
    {
      value: "Swear Word",
      color: "#577eba",
    },
    {
      value: "Phone Number",
      color: "#3e6146",
    },
  ];
  const text =
    "Damn it, The phone i just bought last week has been broken 😠, \n I need refund right now, Call me on this phone number: 080808080.";
  const $manualDataMasking = manualDataMasking.create({
    container: document.getElementById("demo"),
    text,
    dataMasked,
    categories,
    replaceCharactor: "*",
    dataMaskingCharactor: "X",
    maxHeight: 100,
  });
  $manualDataMasking.on(
    "afterdataMasking",
    (dataMasked, textAfterDataMasking) => {
      console.log(JSON.stringify(dataMasked));
      console.log(textAfterDataMasking);
    }
  );
</script>Options
| Property | Description | Type | Required | Default | 
|---|---|---|---|---|
| categories | Categories of sensitive data. e.g. { value: "Person Name", color: "#3e6146" }, { value: "Bad word"} // if you don't set color property, the default color will be #577eba | array | true | null | 
| container | Container dom element. | Dom Element Object | true | null | 
| dataMasked | Sensitive data been masked.e.g.{ content: "Damn it", category: "Person Name", start: 0, // start index in text string end: 7, // end index in text string } | array | false | [] | 
| dataMaskingCharactor | Charactor in data masking. entity | string | false | '●' | 
| maxHeight | Max height of container, you can scroll the content if the height of container is over maxHeight. | number | false | null | 
| replaceCharactor | Charactor be used to replace the sensitive. data | string | false | "*" | 
| text | Origin text content.  Notice: please use \nin where you want to wrap a new line | string | true | null | 
Instance functions
| Name | Description | 
|---|---|
| getDataMasked | Get sensitive data been masked $manualDataMasking.getDataMasked() | 
| getTextAfterDataMasking | Get text after data masking $manualDataMasking.getTextAfterDataMasking() | 
Events
| Event Name | Description | 
|---|---|
| afterDataMasking | Registered callback functions will be triggered when new sensitive data been masked. Value of text after masking and data msked can be used inside of the callback function. $manualDataMasking.on( "afterdataMasking", (dataMasked, textAfterDataMasking) => { console.log(JSON.stringify(dataMasked)); console.log(textAfterDataMasking);}); | 
Build Setup
# install dependencies
npm install
# serve with hot reload at localhost:8080
npm run dev
# build for production with minification
npm run build