Metadata-Version: 2.1
Name: depth-armory
Version: 1.0.0
Summary: Armory is a tool meant to take in a lot of external and discovery data from a lot of tools, add it to a database and correlate all of related information.
Home-page: https://github.com/depthsecurity/armory
Author: Depth Security
Author-email: info@depthsecurity.com
License: UNKNOWN
Keywords: pentesting security
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Information Technology
Classifier: Intended Audience :: System Administrators
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Description-Content-Type: text/markdown
Requires-Dist: configparser
Requires-Dist: sqlalchemy
Requires-Dist: sqlalchemy-mixins
Requires-Dist: tld
Requires-Dist: dnspython
Requires-Dist: netaddr
Requires-Dist: pyperclip
Requires-Dist: requests
Requires-Dist: ipwhois
Requires-Dist: whois
Requires-Dist: fuzzywuzzy[speedup]
Requires-Dist: xmltodict
Requires-Dist: bs4
Requires-Dist: thready
Requires-Dist: argcomplete
Requires-Dist: tldextract
Requires-Dist: ipaddr
Requires-Dist: mysqlclient
Requires-Dist: lxml
Requires-Dist: IPython (<6.0,>5.0) ; python_version < "3.1"
Requires-Dist: subprocess32 ; python_version < "3.3"
Requires-Dist: IPython ; python_version > "3.1"
Provides-Extra: dev
Requires-Dist: check-manifest ; extra == 'dev'
Requires-Dist: tox ; extra == 'dev'
Provides-Extra: test
Requires-Dist: coverage ; extra == 'test'
Requires-Dist: mock ; (python_version < "3.4") and extra == 'test'


```
       _                                                          
      dM.                                                         
     ,MMb                                                         
     d'YM.   ___  __ ___  __    __     _____  ___  __ ____    ___ 
    ,P `Mb   `MM 6MM `MM 6MMb  6MMb   6MMMMMb `MM 6MM `MM(    )M' 
    d'  YM.   MM69 "  MM69 `MM69 `Mb 6M'   `Mb MM69 "  `Mb    d'  
___,P____Mb___MM______MM____MM____MM_MM_____MM_MM_______YM.__,P___
   d'    YM.  MM      MM    MM    MM MM     MM MM        MM  M    \ 
__,MMMMMMMMb__MM______MM____MM____MM_MM_____MM_MM________`Mbd'_____\
  d'      YM. MM      MM    MM    MM YM.   ,M9 MM         YMP      
_dM_     _dMM_MM_    _MM_  _MM_  _MM_ YMMMMM9 _MM_         M      
                                                          d'      
                                                      (8),P       
                                                       YMM        

```

# Description

Armory is a tool meant to take in a lot of external and discovery data from a lot of tools, add it to a database and correlate all of related information. It isn't meant to replace any specific tool. It is meant to take the output from various tools, and use it to feed other tools.

Additionally, it is meant to be easily extendable. Don't see a module for your favorite tool? Write one up! Want to export data in just the right format for your reporting? Create a new report!

# Installation

## Prerequisites

First, set up some kind of virtual environment. I like virtualenvwrapper:

http://virtualenvwrapper.readthedocs.io/en/latest/install.html

## Actually installing

Clone the repo:

`git clone https://github.com/depthsecurity/armory`

Install the module:

`python setup.py install`

You will want to run `armory` at least once in order to create the default config directory: `~/.armory` with the default `settings.ini` and settings for each of the modules.

Next edit *settings.ini* and modify the **base_path** option. This should point to the root path you are using *for your current project*. You should change this with every project, so you will always be using a clean database. All files generated by modules will be created in here, as well as the sqlite3 database. **By default it will be within the current directory-`.`**

# Usage

Usage is split into **modules** and **reports**. 

## Modules

Modules run tools, ingest output, and write it to the database. To see a list of available modules, type:

`armory -lm`

To see a list of module options, type:

`armory -m <module> -M`


## Reports

Reports are similar to modules, except they are meant to pull data from the database, and display it in a usable format. To view all of the available reports:

`armory -lr`

To view available report options:

`armory -r <report> -R`


## Interactive Shell

There is also an interactive shell which uses [IPython](https://ipython.org/) as the base and will allow you to run commands or change database values. It can be launched with: `armory-shell`.
By default, the following will be available: `Domain, BaseDomains, IPAddresses, CIDRs, Users, Creds, Vulns, Ports, Urls, ScopeCIDRs`.


