https://github.com/jsantell/chrome-api-definitions
Definition generator for Chrome Platform APIs
https://github.com/jsantell/chrome-api-definitions
Last synced: 8 months ago
JSON representation
Definition generator for Chrome Platform APIs
- Host: GitHub
- URL: https://github.com/jsantell/chrome-api-definitions
- Owner: jsantell
- License: mit
- Created: 2015-04-20T20:37:31.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2016-10-04T10:01:20.000Z (about 9 years ago)
- Last Synced: 2024-12-30T05:49:24.310Z (10 months ago)
- Language: C++
- Homepage:
- Size: 572 KB
- Stars: 5
- Watchers: 5
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# chrome-api-definitions
[](https://travis-ci.org/jsantell/chrome-api-definitions)
[](https://www.npmjs.org/package/chrome-api-definitions)Definition generator for Chrome Platform APIs.
Uses the Chromium extension definitions (both [common](https://code.google.com/p/chromium/codesearch#chromium/src/extensions/common/api/) and [chrome](https://code.google.com/p/chromium/codesearch#chromium/src/chrome/common/extensions/api/) definitions) for the [Chrome Platform APIs](https://developer.chrome.com/extensions/api_index) and constructs a manifest of all available platform APIs for extensions.
While the [original manifests](https://code.google.com/p/chromium/codesearch#chromium/src/chrome/common/extensions/api/_api_features.json) defines permissions, allowable contexts, and other metadata describing the namespace (sometimes a specific method inside a namespace also has this meta), the full definition of the available methods, types and objects exposed in the API is defined by either JSON or (Blink's version of) WebIDL. This constructs a structure listing all available APIs with their appropriate meta from the manifest, as well as the available entities inside of that namespace.
Parsing the Blink WebIDL here is a horrible hack to get it similar to the APIs with JSON definitions, but gets us close enough.
## Output
Pretty much an array of all specified APIs (by `filter` config), using the [JSON definitions](https://github.com/jsantell/chrome-api-definitions/blob/master/api/chrome/tabs.json) from Chromium if they exist, or otherwise using the WebIDL version for something that attempts to get pretty close.
Root APIs (like `alarms` or `devtools.inspectedWindow`) also now have properties of `permissions` and `content_script`, if these were defined in the Chromium manifest, for example:
```
{
"namespace": "storage",
"dependencies": ["permission:storage"],
"content_script": true
}
```When defined in the manifest, an API's methods can also have this additional information (only `runtime` and `extensions` API have individual methods in the manifest, AFAIK).
```
{
"namespace": "runtime",
...
"functions": [{
"name": "sendMessage",
"content_script": true
}, {
...
}]
}```
View [built output of stable APIs](https://github.com/jsantell/chrome-api-definitions/blob/master/output/stable.json) for the most illumination.
## API
#### getDefinitions(options)
Returns the definition for the specified APIs as an object. Options:
* `filter` - provide an array of namespaces to filter by, or use a string to specify a preset in `api-names.json`. Defaults to the preset `"stable"`.
* `apiRoot` - path to the directory containing both `common` and `chrome` APIs. Uses the directory in `./api` by default. Not tested.#### saveDefinitions(options)
Same as `getDefinitions()` except it just saves to disk. Takes the same options as `getDefinitions()`, plus:
* `dest` - path of where the definition should be saved.
## License
For chrome-api-defintions: *MIT License, Copyright (c) 2015 Jordan Santell*
For API manifests from Chromium source: *Modified BSD License, Copyright 2014 The Chromium Authors. All rights reserved.*