-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathINFO
53 lines (38 loc) · 4.49 KB
/
INFO
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# Binary Ninja Community Plugins
Plugins in this repository are provided by the community. Vector 35, Inc. makes no guarantees to the quality, safety or efficacy of the plugins herein.
## Official Plugins
This repository tracks third-party plugins, but many official plugins are provided by Vector 35 that offer additional functionality:
- [Example Plugins](https://github.com/Vector35/binaryninja-api/tree/dev/python/examples) are included with all installs of Binary Ninja and can [be installed](https://github.com/Vector35/binaryninja-api/tree/dev/python/examples#loading-plugins) from there
- [Official Samples](https://github.com/Vector35/official-plugins) a fully formed repository of official plugins
- [Sample Plugin](https://github.com/Vector35/sample_plugin) if you're looking for a template to build a new plugin from
## Installing Plugins
To install plugins, you can either use the Plugin Manager in the UI or clone the repositories linked here in into your [plugin folder](https://github.com/Vector35/binaryninja-api/tree/dev/python/examples#loading-plugins).
## Contributing Plugins
1. Create a new repository (Optionally, just copy it from the [sample plugin](https://github.com/Vector35/sample_plugin))
1. Fill out a [`plugin.json`](https://github.com/Vector35/sample_plugin/blob/master/plugin.json). Optionally you can use the `generate_plugininfo.py -p` to interactively walk you through setting the required fields. The `plugin.json` must pass all the checks when run through `generate_plugininfo.py -v plugin.json`. `generate_plugininfo.py` can also generate your `README.md` and your `LICENSE` file with the `-r`, `-l`, or `-a` (all) options. Below is a list of the required and recommended fields.
1. Create and push a git tag with the version of your plugin (e.g. `v1.1`). Create a release, optionally attaching build artifacts as required. We recommend using our [release helper](https://github.com/Vector35/release_helper) which simplifies this process.
1. File an [issue](https://github.com/Vector35/community-plugins/issues) with a link to your repo.
1. To update your plugin, simply do a new release! For future updates we'll automatically detect and add the new release to the plugin manager for you! (This previously was a manual step that has been since automated)
### Required Fields
To be displayed in the plugin loader, your `plugin.json` MUST have the following fields:
- `pluginmetadataversion` - The current version is the integer `2`
- `name` - Good names do not use "Binary Ninja" or "Binja" neither do they use the words "plugin" or "extension". So instead of "Binja 6502 Architecture Plugin" simply use "6502 Architecture"
- `author` - Your name, handle, or company name.
- `api` - A list of supported architectures. Currently only `python3` is supported.
- `license` - A json object with `name` and `text` keys.
- `description` - This is a short (<50 character) description of the plugin.
- `version` - Version string
- `minimumBinaryNinjaVersion` - An integer _build number_ so instead of `1.1.555` use `555`.
- `platforms` - A list of strings one for each supported platform. Valid platforms are `Darwin`, `Linux`, and `Windows`
### Recommended Fields
- `longdescription` - A longer Markdown formatted description of the plugin including hyperlinks and images as needed. This will be shown in the plugin preview in the plugin manager and images are highly recommended. If not specified or if empty, the [README file](https://github.com/Vector35/community-plugins/blob/master/generate_index.py#L104) from your repository will be automatically used instead.
- `type` - A list of strings of the following types: `core`, `ui`, `architecture`, `binaryview`, and `helper`.
- `helper` - Plugin that adds some base functionality to Binary Ninja. Most plugins will be of this type.
- `ui` - The plugin extends the UI is some way.
- `architecture` - The plugin adds an architecture (e.g. `x86`, `ARM`, `MIPS`).
- `binaryview` - The plugin adds a new BinaryView (e.g. `PE`, `MachO`, `ELF`).
- `core` - Plugin that extends the core's analysis. Your plugin probably isn't one of these.
- `sync` - A plugin that synchronizes data with an external tool.
- `installinstructions` - A json object with keys for each supported platform listed in `platforms` and text Markdown formatted.
## License
Note that content contained in the root of this repository itself is Copyright 2016-2024, Vector 35, Inc. and [available](LICENSE) under an MIT license, but each individual plugin may be released under a different license.