An open API service indexing awesome lists of open source software.

https://github.com/taitems/email-to-name

Generate a name from an email address based on common patterns
https://github.com/taitems/email-to-name

email-identifier email-validation hacktoberfest user-experience user-identification

Last synced: about 2 months ago
JSON representation

Generate a name from an email address based on common patterns

Awesome Lists containing this project

README

        

[![Tests](https://github.com/taitems/email-to-name/actions/workflows/actions.yml/badge.svg)](https://github.com/taitems/email-to-name/actions/workflows/actions.yml)
![npm bundle size](https://img.shields.io/bundlephobia/min/email-to-name)
![npm](https://img.shields.io/npm/v/email-to-name)

# Email to Name

A Node.js and web browser compatible script that takes an email address and tries to generate a name.

![image](https://i.imgur.com/dgshroz.png)

## Company Names

Privacy conscious individuals often use the name of website as the email identifier. If Jane Smith has her own domain name with an email server, she might sign up as `[email protected]`. That way if "Suspicious Website" ends up selling her email address on to a third party, if they send this exact email address spam, it's possible to see who leaked her email address.

It's also therefore possible to invert this method and detect the personal domain if the email identifier matches your company/website name.

**No Company Names**

- `emailToName.process('[email protected]')`
- Output: `Acloudguru`

**With Company Names**

- `emailToName.process('[email protected]', { companyNames: ['acg', 'acloudguru'] })`
- Output: `Janesmith`

## Common Email Identifiers

Users who operate a personal email domain sometimes use prefixes like `contact`, `hello`, `me` and others. This script also tries to invert those.

## Parameters

| Value | Default | Example (Input) | Example (On) | Example (Off) |
| -------------------------------- | ------- | ------------------------------- | --------------------- | --------------------- |
| `removePlusWords` | `true` | `[email protected]` | `Tait Brown` | `Tait Brown+test` |
| `removeNumbers` | `true` | `[email protected]` | `Tait` | `Tait123` |
| `titleCase` | `true` | `[email protected]` | `Tait Brown` | `tait brown` |
| `caseMc` | `true` | `[email protected]` | `John McKim` | `John Mckim` |
| `caseLetterApostrophe` | `true` | `flannery.o'[email protected]` | `Flannery O'Connor` | `Flannery O'connor` |
| `uppercaseGenerationalNumbers` | `true` | `[email protected]` | `Tait Brown III` | `Tait Brown Iii` |
| `commaPrependGenerationalPhrase` | `true` | `[email protected]` | `Tait Brown, Jr.` | `Tait Brown Jr` |
| `appendPeriodToTitlePrefix` | `true` | `[email protected]` | `Prof. Tait Brown` | `Prof Tait Brown` |
| `lowercaseFamilyParticle` | `true` | `[email protected]` | `Dutch van der Linde` | `Dutch Van Der Linde` |

## Default Values

#### Common Personal Identifiers

Attempt to use the domain name as the personal identifier when these common email identifiers are used `'hello', 'me', 'email', 'contact'`

#### Generational Suffixes

Prepend a comma and append a period for the following, when at the end of a string and preceded by a space `'jr', 'jnr', 'sr', 'snr'`

#### Generational Numbers

Uppercase these whe at the end of a string and preceded by a space `'ii', 'iii', 'iv'`

#### Titles

Append a period when the following occur at the beginning of a string and are followed by a space `'mr', 'mrs', 'ms', 'dr', 'prof'`

## Development

Run tests. Requires yarn.

`yarn test`

## Contributors

- [@taitems](https://github.com/taitems) - Package creator, maintainer
- [@felipehertzer](https://github.com/felipehertzer) - Added types

## Changelog

- `2.0.7` - Added types (thanks [@felipehertzer](https://github.com/felipehertzer) )
- `2.0.[1..6]` - Adding `release` task wasted commits
- `2.0.0` - Building with `esbuild` with browser targets `chrome58,firefox57,safari11,edge16`
- `1.1.0` - Borrowed heavily from `namecase` libraries
- **ADDED:** Various lowercase conjunctions "son/daughter of" as per namecase
- `1.0.0` **Breaking Change:** Relocated company names and common personal identifiers to `params`
- `0.2.0` **Bugfix:** Couldn't use in browser due to `module` check
- `0.1.0` added generational handling (Jr, Sr, III etc) as well as titles (Mr, Mrs, Dr, Prof)
- `0.0.0` init commit