mirror of
https://github.com/calebstewart/pwncat.git
synced 2024-11-23 17:15:38 +01:00
updated documentation for pypi upload
This commit is contained in:
parent
4f0a884945
commit
b291439365
84
README.md
84
README.md
@ -43,6 +43,36 @@ the latest usage and development documentation!
|
|||||||
|
|
||||||
**pwncat requires Python 3.9+.**
|
**pwncat requires Python 3.9+.**
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
pwncat is available on PyPI as `pwncat-cs`. It exposes an entrypoints named
|
||||||
|
`pwncat`, `pcat` and `pc`. It **does** conflict with the `pwncat` package,
|
||||||
|
so if you need both, we recommend using a virtual environment. pwncat also
|
||||||
|
exposes an importable module named `pwncat` with full access to the internals
|
||||||
|
and automation. You can install from PyPi like so:
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
pip install pwncat-cs
|
||||||
|
```
|
||||||
|
|
||||||
|
pwncat uses [poetry](https://python-poetry.org) for dependency and build
|
||||||
|
management. For a development environment, install poetry as described on their
|
||||||
|
website, and then use it to manage your environment:
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
# Clone the repo
|
||||||
|
git clone https://github.com/calebstewart/pwncat
|
||||||
|
cd pwncat
|
||||||
|
# Enter/create the pwncat specific virtual environment
|
||||||
|
poetry shell
|
||||||
|
# Install dependencies
|
||||||
|
poetry install
|
||||||
|
# Use pwncat
|
||||||
|
pwncat --help
|
||||||
|
# Use `exit` to leave the virtual environment
|
||||||
|
exit
|
||||||
|
```
|
||||||
|
|
||||||
## Windows Support
|
## Windows Support
|
||||||
|
|
||||||
pwncat now supports windows starting at `v0.4.0a1`. The Windows platform
|
pwncat now supports windows starting at `v0.4.0a1`. The Windows platform
|
||||||
@ -67,21 +97,6 @@ the only provided default plugins are the C2 and an implementation of [BadPotato
|
|||||||
pwncat can reflectively load .Net binaries to be used a plugins for the C2.
|
pwncat can reflectively load .Net binaries to be used a plugins for the C2.
|
||||||
For more information on Windows C2 plugins, please see the [documentation].
|
For more information on Windows C2 plugins, please see the [documentation].
|
||||||
|
|
||||||
## Version Details
|
|
||||||
|
|
||||||
Currently, there are two versions of pwncat available. The last stable
|
|
||||||
version is `v0.3.1`. There is a tagged commit for that version. It does
|
|
||||||
not support multiple platforms or multi-session interaction. The
|
|
||||||
documentation for that version is still available on Read the Docs as
|
|
||||||
the `stable` version.
|
|
||||||
|
|
||||||
The current `master` branch is tentatively `v0.4.0a1`. This version has
|
|
||||||
overhauled a lot of the framework to support multiple platforms and
|
|
||||||
multisession environments. Documentation for this version is available
|
|
||||||
in the `latest` version on Read the Docs.
|
|
||||||
|
|
||||||
**v0.3.1 will not be updated further**
|
|
||||||
|
|
||||||
## Modules
|
## Modules
|
||||||
|
|
||||||
Recently, the architecture of the pwncat framework was redesigned to
|
Recently, the architecture of the pwncat framework was redesigned to
|
||||||
@ -92,45 +107,6 @@ post-exploitation platforms. You can utilize the familiar `run`, `search`
|
|||||||
and `info` commands and enter module contexts with the `use` command.
|
and `info` commands and enter module contexts with the `use` command.
|
||||||
Refer to the documentation for more information.
|
Refer to the documentation for more information.
|
||||||
|
|
||||||
## Install
|
|
||||||
|
|
||||||
`pwncat` only depends on a working Python development environment. In order
|
|
||||||
to install some of the packages required with `pip`, you will likely need
|
|
||||||
your distribution's "Python Development" package. On Debian based systems,
|
|
||||||
this is `python-dev`. For Arch, the development files are shipped with the
|
|
||||||
main Python repository. For Enterprise Linux, the package is named
|
|
||||||
`python-devel`.
|
|
||||||
|
|
||||||
`pwncat` is configured as a standard python package with `distutils`. You
|
|
||||||
can install `pwncat` directly from GitHub with:
|
|
||||||
|
|
||||||
```shell script
|
|
||||||
pip install git+https://github.com/calebstewart/pwncat.git
|
|
||||||
```
|
|
||||||
|
|
||||||
Or, you can install after cloning the repository with:
|
|
||||||
|
|
||||||
```shell script
|
|
||||||
python setup.py install
|
|
||||||
```
|
|
||||||
|
|
||||||
It is recommended to install pwncat from a virtual environment.
|
|
||||||
|
|
||||||
```shell script
|
|
||||||
python3 -m venv pwncat-env
|
|
||||||
source pwncat-env/bin/activate
|
|
||||||
python setup.py install
|
|
||||||
```
|
|
||||||
|
|
||||||
If you would like to develop custom privilege escalation or persistence
|
|
||||||
modules, we recommend you use the `develop` target vice the `install` target
|
|
||||||
for `setup.py`. This allows changes to the local repository to immediately
|
|
||||||
be observed with your installed package.
|
|
||||||
|
|
||||||
The setup script will install three binaries. They are all identical, but
|
|
||||||
provide convenience aliases for pwncat. The three binaries are: `pwncat`,
|
|
||||||
`pc` and `pcat`.
|
|
||||||
|
|
||||||
### Connecting to a Victim
|
### Connecting to a Victim
|
||||||
|
|
||||||
The command line parameters for pwncat attempt to be flexible and accept
|
The command line parameters for pwncat attempt to be flexible and accept
|
||||||
|
@ -4,20 +4,23 @@ Installation
|
|||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: -1
|
:maxdepth: -1
|
||||||
|
|
||||||
The only system dependency for pwncat is ``python3`` and ``pip``. For ``pip`` to install all Python dependencies,
|
The only system dependency for pwncat is ``python3`` and ``pip``. For ``pip`` to install all Python dependencies, you will likely need your distributions Python Development package (``python3-dev`` for Debian-based distributions). A virtual environment is recommended, but not required.
|
||||||
you will likely need your distributions Python Development package (``python3-dev`` for Debian-based distributions).
|
|
||||||
Once you have a working ``pip`` installation, you can install pwncat with the provided setup script:
|
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
:caption: Install pwncat w/ Virtual Environment
|
||||||
|
|
||||||
# A virtual environment is recommended
|
# A virtual environment is recommended
|
||||||
python -m venv /opt/pwncat
|
python -m venv /opt/pwncat
|
||||||
# Install pwncat within the virtual environment
|
# Install pwncat within the virtual environment
|
||||||
# Replace `latest` with a versioned tag if needed (e.g. `v0.4.0`)
|
/opt/pwncat/bin/pip install pwncat-cs
|
||||||
/opt/pwncat/bin/pip install 'git+https://github.com/calebstewart/pwncat@latest#egg=pwncat'
|
|
||||||
# This allows you to use pwncat outside of the virtual environment
|
# This allows you to use pwncat outside of the virtual environment
|
||||||
ln -s /opt/pwncat/bin/pwncat /usr/local/bin
|
ln -s /opt/pwncat/bin/pwncat /usr/local/bin
|
||||||
|
|
||||||
|
.. code-block:: bash
|
||||||
|
:caption: Install pwncat without Virtual Environment
|
||||||
|
|
||||||
|
pip install pwncat-cs
|
||||||
|
|
||||||
After installation, you can use pwncat via the installed script:
|
After installation, you can use pwncat via the installed script:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
@ -95,15 +98,11 @@ builtin plugins from the GitHub releases page. You can then extract it into your
|
|||||||
Development Environment
|
Development Environment
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
If you would like to develop modules for pwncat (such as privilege escalation or persistence module), you can use
|
pwncat utilizes the Poetry dependency and build manager. After installing poetry, you can use it to manage a local development environment.
|
||||||
the ``setuptools`` "develop" target instead of "install". This installs pwncat via symlinks, which means any
|
|
||||||
modifications of the local code will be reflected in the installed package:
|
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
||||||
git clone https://github.com/calebstewart/pwncat.git
|
git clone https://github.com/calebstewart/pwncat.git
|
||||||
cd pwncat
|
cd pwncat
|
||||||
python -m venv env
|
poetry shell
|
||||||
. env/bin/activate
|
poetry install
|
||||||
python setup.py develop
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user