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

https://github.com/joe12387/detectincognito

JavaScript detection of Incognito & other private browsing modes on Chrome, Edge, Safari, Brave, Firefox, Opera and MSIE.
https://github.com/joe12387/detectincognito

browser chrome edge firefox incognito incognito-browsing incognito-mode incognito-window internet-explorer javascript private-browsing safari

Last synced: 20 days ago
JSON representation

JavaScript detection of Incognito & other private browsing modes on Chrome, Edge, Safari, Brave, Firefox, Opera and MSIE.

Awesome Lists containing this project

README

        

Shameless plug: [Looking for a user tracking or bot detection solution?](https://overpoweredjs.com/)

# detectIncognito.js

detectIncognito.js can be used to detect incognito mode & other private browsing modes on most modern browsers as of 2025.

- Detects Incognito mode on Google Chrome
- Detects Private Windows on Safari for macOS
- Detects Private Tabs on Safari for iOS
- Detects Private Windows in Firefox
- Detects InPrivate Windows on Microsoft Edge
- Detects InPrivate Windows on Microsoft Internet Explorer
- Detects Private Windows in Brave (see notes)
- Detects Private Windows in Opera

## Demo

https://detectincognito.com/

## Usage

Get script from CDN (may be blocked by adblockers, see notes)

```html

```

Or install from NPM

```bash
npm i detectincognitojs
```

```javascript
import { detectIncognito } from "detectincognitojs";
```

Run the detect function

```javascript
detectIncognito().then((result) => {
console.log(result.browserName, result.isPrivate);
});
```

## Supported Browsers

| Browser | Platform(s) | Versions | Notes |
| --------------- | :---------- | :-----------------: | :------------------------------- |
| Safari | iOS | 8 to 18.4 | |
| Safari | macOS | ≤ 18.4 | |
| Chrome/Chromium | All | 50 to 137 Beta | `predictable-reported-quota` flag currently breaks detection (see [Issue #49](https://github.com/Joe12387/detectIncognito/issues/49)) |
| Edge | All | 15 to 18; 79 to 136 | |
| Firefox | All | 44 to 138 | |
| Brave | All | ≤ 1.76 | CDN is blocked if shields are up |
| MSIE | Windows | 11 | Promise polyfill required |

Please note that although this script works on almost all modern browsers, detecting private modes in browsers is very much an arms race. As such, I cannot guarantee that this script will continue to work into the future. However, I will continue to actively maintain this script to support as many browsers as is possible.

If you are aware of any modern browsers this script does not work with, please let me know by creating an issue.

## Notes

- There will be a false positive in certain browser configurations, as well as in Chrome's Guest mode. ([Issue #21](https://github.com/Joe12387/detectIncognito/issues/21)).
- This script does not detect Container Tabs on Firefox as they work differently compared to private mode.
- An error will be thrown if the browser cannot be identified.
- The script only works remotely on a web server using HTTPS. Running the script locally or with HTTP may produce a false result, or it may not run at all.
- Brave and uBlock Origin currently block the script from loading from the CDN. Hosting the script elsewhere should bypass this.

## Similar Projects

- [OverpoweredJS](https://overpoweredjs.com/ "OverpoweredJS") - An overpowered browser fingerprinting & bot detection solution.

## License

Copyright (c) 2025 Joe Rutkowski

Released under [MIT License](https://opensource.org/license/mit-0/)