Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lu4p/ToRat
ToRat is a Remote Administation tool written in Go using Tor as a transport mechanism and RPC for communication
https://github.com/lu4p/ToRat
command-and-control cross-platform golang keylogger linux payload persistence post-exploitation privilege-escalation rat remote-admin-tool reverse-shell reverse-shells rpc shell-reverse tor transport uac-bypass uacbypass windows
Last synced: 3 months ago
JSON representation
ToRat is a Remote Administation tool written in Go using Tor as a transport mechanism and RPC for communication
- Host: GitHub
- URL: https://github.com/lu4p/ToRat
- Owner: lu4p
- License: unlicense
- Archived: true
- Created: 2019-01-19T11:44:01.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-13T08:56:55.000Z (almost 2 years ago)
- Last Synced: 2024-08-03T17:12:08.939Z (5 months ago)
- Topics: command-and-control, cross-platform, golang, keylogger, linux, payload, persistence, post-exploitation, privilege-escalation, rat, remote-admin-tool, reverse-shell, reverse-shells, rpc, shell-reverse, tor, transport, uac-bypass, uacbypass, windows
- Language: Go
- Homepage: https://lu4p.github.io/ToRat
- Size: 419 KB
- Stars: 961
- Watchers: 40
- Forks: 198
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-tor - ToRat - Cross-platform remote administration tool written in Go using Tor as a transport mechanism. (Uncategorized / Uncategorized)
- awesome-csirt - ToRat
README
#
[![License](https://img.shields.io/github/license/lu4p/ToRat.svg)](https://unlicense.org/)
[![CircleCI](https://circleci.com/gh/lu4p/ToRat.svg?style=svg)](https://circleci.com/gh/lu4p/ToRat)
[![Go Report Card](https://goreportcard.com/badge/github.com/lu4p/ToRat)](https://goreportcard.com/report/github.com/lu4p/ToRat)
[![Docker Cloud Build Status](https://img.shields.io/docker/cloud/build/lu4p/torat)](https://hub.docker.com/repository/docker/lu4p/torat)A Cross Platform Remote Administration tool written in Go using Tor as its transport mechanism
currently supporting Windows, Linux, MacOS clients.## DISCLAIMER
USE FOR EDUCATIONAL PURPOSES ONLY## Wiki
[How to use ToRat Docker Image](https://github.com/lu4p/ToRat/wiki/How-to-use-the-ToRat-Docker-Image)### Client Commands
Command | Info
--- | ---
**cd** | change the working directory of the client
**ls** | list the content of the working directory of the client
**shred** | delete files/ directories unrecoverable
**screen** | take a Screenshot of the client
**cat** | view Textfiles from the client including .docx, .rtf, .pdf, .odt
**alias** | give the client a custom alias
**down** | download a file from the client
**up** | upload a file to the client
**speedtest** | speedtest a client's internet connection
**hardware** | collects a variety of hardware specs from the client
**netscan** | scans a clients entire network for online devices and open ports
**gomap** | scan a local ip on a clients network for open ports and services
**escape** | escape a command and run it in a native shell on the client
**reconnect** | tell the client to reconnect
**help** | lists possible commands with usage info
**exit** | background current session and return to main shell### Server Commands
Command | Info
--- | ---
**select** | select client to interact with
**list** | list all connected clients
**alias** | select client to give an alias
**cd** | change the working directory of the server
**help** | lists possible commands with usage info
**exit** | exit the server## Current Features
### Architecture
- RPC (Remote procedure Call) based communication for easy addition of new functionality
- Automatic upx leads to client binaries of ~6MB with embedded Tor
- sqlite via gorm for storing information about the clients
- client is obfuscated via [garble](https://github.com/burrowers/garble)## Server Shell
- Cross Platform reverse shell (Windows, Linux, Mac OS)
- Supports multiple connections
- Welcome Banner
- Colored Output
- Tab-Completion of:
- Commands
- Files/ Directories in the working directory of the server- Unique persistent ID for every client
- give a client an Alias
- all Downloads from client get saved to ./$ID/$filename## Persistence
- Windows:
- [ ] Multiple User Account Control Bypasses (Privilege escalation)
- [ ] Multiple Persistence methods (User, Admin)- Linux:
- [ ] Multiple Persistence methods (User, Admin)## Tor
- Fully embedded Tor within go- the ToRAT_client communicates over TLS encrypted RPC proxied through Tor with the ToRat_server (hidden service)
- [x] anonymity of client and server
- [x] end-to-end encryption- optional transport without Tor e.g. Use Tor2Web, a DNS Hostname or public/ local IP
- [x] smaller binary ~3MB upx'ed
- [ ] anonymity of client and server## Upcoming Features
- [ ] Bulk Commands
- [ ] Persistence and privilege escalation for Linux
- [ ] Persistence and privilege escalation for Mac OS
- [ ] Support for Android and iOS (needs fix of https://github.com/ipsn/go-libtor/issues/12)
- [ ] [File-less Persistence on Windows](https://github.com/ewhitehats/InvisiblePersistence)## Contribution
All contributions are welcome you don't need to be an expert in Go to contribute.You may want to join the `#torat` channel over at the [Gophers Slack](https://invite.slack.golangbridge.org/)
## Credits
- [Tor](https://www.torproject.org/)
- [Tor controller library](https://github.com/cretz/bine)
- [Python Uacbypass and Persistence Techniques](https://github.com/rootm0s/WinPwnage)
- [Modern Cli](https://github.com/abiosoft/ishell)
- [Colored Prints](https://github.com/fatih/color)
- [Screenshot library](https://github.com/vova616/screenshot)
- [TLS Certificate generator](https://github.com/lu4p/genCert)
- [Shred library](https://github.com/lu4p/shred)
- [Extract Text from Documents](https://github.com/lu4p/cat)
- [RPC](https://golang.org/pkg/net/rpc/)
- [UPX](https://upx.github.io/)
- [Obfuscation](https://github.com/burrowers/garble)