AI_botter/node_modules/biskviit/README.md
2024-04-30 17:46:10 -08:00

98 lines
No EOL
2.1 KiB
Markdown

# biskviit
Yet another node module for handling http cookies. This module parses `Set-Cookie` header, stores the data to memory and returns valid value for `Cookie` header once needed based on the stored cookie data.
> **NB** Requires iojs or Node v4+ to support some ES6 features used by this module. Might work with older Node versions as well but not tested
## Usage
Install from npm
npm install biskviit --save
Require as `Biskviit`
```javascript
var Biskviit = require('biskviit');
```
Create a cookie managing *biskviit* instance
```javascript
var biskviit = new Biskviit(options);
```
Where
* **options** is an optional options object with the following properties:
* **sessionTimeout** is the amount in seconds for default session length, used for cookies without an expire argument
**Example**
```javascript
var Biskviit = require('biskviit');
var biskviit = new Biskviit({
sessionTimeout: 5 * 60 // expire cookies after 5 minutes
});
```
### set
To add new cookies to the storage use `set`
```javascript
biskviit.set(cookieString, url)
```
Where
* **cookieString** is the value from the `Set-Cookie:` header
* **url** is the currently open URL that sent the cookie header
**Example**
```javascript
biskviit.set('theme=light', 'http://example.com/');
biskviit.set('sessionToken=abc123; Expires=Wed, 09 Jun 2021 10:18:14 GMT', 'http://example.com/');
```
### get
To list all available cookies for a specified URL use `get`
```javascript
var cookiesString = biskviit.get(url);
```
Where
* **url** is the URL the cookies are required for
**Example**
```javascript
var cookiesString = biskviit.get('http://example.com/');
// theme=light; sessionToken=abc123
```
### list
If you need to filter cookies as objects, use `list`
```javascript
var cookiesString = biskviit.list(url);
```
Where
* **url** is the URL the cookies are required for
**Example**
```javascript
var cookiesString = biskviit.list('http://example.com/');
// [{key: 'theme', value: 'light', expires: ...}, {key: 'sessionToken', value: 'abc123', expires: ...}]
```
## License
**MIT**