mirror of
https://github.com/manualdousuario/marreta.git
synced 2025-09-01 10:10:14 +00:00
245 lines
7 KiB
Markdown
245 lines
7 KiB
Markdown
# 🛠️ Marreta
|
|
|
|
[](https://github.com/manualdousuario/marreta/blob/master/README.en.md)
|
|
[](https://github.com/manualdousuario/marreta/blob/master/README.md)
|
|
|
|
[](https://github.com/manualdousuario/marreta/network/members)
|
|
[](https://github.com/manualdousuario/marreta/stargazers)
|
|
[](https://github.com/manualdousuario/marreta/issues)
|
|
|
|
Marreta is a tool that removes access barriers and visual distractions!
|
|
|
|

|
|
|
|
Public instance at [marreta.pcdomanual.com](https://marreta.pcdomanual.com)!
|
|
|
|
## ✨ Features
|
|
|
|
- Automatically cleans and fixes URLs
|
|
- Removes annoying tracking parameters
|
|
- Forces HTTPS to keep everything secure
|
|
- Changes user agent to avoid blocks
|
|
- Smart DNS
|
|
- Keeps HTML clean and optimized
|
|
- Fixes relative URLs automatically
|
|
- Allows custom styles
|
|
- Removes unwanted elements
|
|
- Cache, cache!
|
|
- Blocks domains you don't want
|
|
- Allows custom headers and cookies configuration
|
|
- Everything with SSL/TLS
|
|
- PHP-FPM
|
|
- OPcache enabled
|
|
- Direct sharing via PWA on Chrome on Android
|
|
|
|
## 🐳 Docker
|
|
|
|
### Prerequisites
|
|
|
|
You only need:
|
|
- Docker and docker compose
|
|
|
|
### Production
|
|
|
|
`curl -o ./docker-compose.yml https://raw.githubusercontent.com/manualdousuario/marreta/main/docker-compose.yml`
|
|
|
|
If needed
|
|
|
|
`nano docker-compose.yml`
|
|
|
|
```
|
|
services:
|
|
marreta:
|
|
container_name: marreta
|
|
image: ghcr.io/manualdousuario/marreta:latest
|
|
ports:
|
|
- "80:80"
|
|
environment:
|
|
- SITE_NAME=
|
|
- SITE_DESCRIPTION=
|
|
- SITE_URL=
|
|
```
|
|
|
|
- `SITE_NAME`: Your Marreta's name
|
|
- `SITE_DESCRIPTION`: Tell what it's for
|
|
- `SITE_URL`: Where it will run, full address with `https://`. If you change the port in docker-compose (e.g., 8080:80), you must also include the port in SITE_URL (e.g., https://yoursite:8080)
|
|
- `DNS_SERVERS`: Which DNS servers to use `1.1.1.1, 8.8.8.8`
|
|
- `SELENIUM_HOST`: Selenium host server:PORT (e.g., selenium-hub:4444)
|
|
|
|
Now you can run `docker compose up -d`
|
|
|
|
#### Development
|
|
|
|
1. First, clone the project:
|
|
```bash
|
|
git clone https://github.com/manualdousuario/marreta/
|
|
cd marreta
|
|
```
|
|
|
|
2. Create the configuration file:
|
|
```bash
|
|
cp app/.env.sample app/.env
|
|
```
|
|
|
|
3. Configure it your way in `app/.env`:
|
|
```env
|
|
SITE_NAME="Marreta"
|
|
SITE_DESCRIPTION="Paywall hammer!"
|
|
SITE_URL=http://localhost
|
|
DNS_SERVERS=1.1.1.1,8.8.8.8
|
|
LOG_LEVEL=WARNING
|
|
SELENIUM_HOST=selenium-hub:4444
|
|
LANGUAGE=pt-br
|
|
```
|
|
|
|
4. Run everything:
|
|
```bash
|
|
docker-compose up -d
|
|
```
|
|
|
|
Done! It will be running at `http://localhost` 🎉
|
|
|
|
## ⚙️ Customization
|
|
|
|
The configurations are organized in `data/`:
|
|
|
|
- `domain_rules.php`: Site-specific rules
|
|
- `global_rules.php`: Rules that apply to all sites
|
|
- `blocked_domains.php`: List of blocked sites
|
|
|
|
### Translations
|
|
|
|
- `/languages/`: Each language is in its ISO id (`pt-br, en, es or de-de`) and can be defined in the `LANGUAGE` environment
|
|
|
|
### S3 Cache
|
|
|
|
Cache storage support in S3. Configure the following variables in your `.env`:
|
|
|
|
```env
|
|
S3_CACHE_ENABLED=true
|
|
|
|
S3_ACCESS_KEY=access_key
|
|
S3_SECRET_KEY=secret_key
|
|
S3_BUCKET=bucket_name
|
|
S3_REGION=us-east-1
|
|
S3_FOLDER_=cache/
|
|
S3_ACL=private
|
|
S3_ENDPOINT=
|
|
```
|
|
|
|
Possible configurations:
|
|
|
|
```
|
|
## R2
|
|
S3_ACCESS_KEY=access_key
|
|
S3_SECRET_KEY=secret_key
|
|
S3_BUCKET=bucket_name
|
|
S3_ENDPOINT=https://{TOKEN}.r2.cloudflarestorage.com
|
|
S3_REGION=auto
|
|
S3_FOLDER_=cache/
|
|
S3_ACL=private
|
|
|
|
## DigitalOcean
|
|
S3_ACCESS_KEY=access_key
|
|
S3_SECRET_KEY=secret_key
|
|
S3_BUCKET=bucket_name
|
|
S3_ENDPOINT=https://{REGION}.digitaloceanspaces.com
|
|
S3_REGION=auto
|
|
S3_FOLDER_=cache/
|
|
S3_ACL=private
|
|
```
|
|
|
|
### Selenium Integration
|
|
|
|
Selenium integration for processing websites that require javascript or have more advanced protection barriers. To use this functionality, you need to set up a Selenium environment with Firefox. Add the following configuration to your `docker-compose.yml`:
|
|
|
|
```yaml
|
|
services:
|
|
selenium-firefox:
|
|
container_name: selenium-firefox
|
|
image: selenium/node-firefox:4.27.0-20241204
|
|
shm_size: 2gb
|
|
environment:
|
|
- SE_EVENT_BUS_HOST=selenium-hub
|
|
- SE_EVENT_BUS_PUBLISH_PORT=4442
|
|
- SE_EVENT_BUS_SUBSCRIBE_PORT=4443
|
|
- SE_ENABLE_TRACING=false
|
|
- SE_NODE_MAX_SESSIONS=10
|
|
- SE_NODE_OVERRIDE_MAX_SESSIONS=true
|
|
entrypoint: bash -c 'SE_OPTS="--host $$HOSTNAME" /opt/bin/entry_point.sh'
|
|
depends_on:
|
|
- selenium-hub
|
|
|
|
selenium-hub:
|
|
image: selenium/hub:4.27.0-20241204
|
|
container_name: selenium-hub
|
|
environment:
|
|
- SE_ENABLE_TRACING=false
|
|
- GRID_MAX_SESSION=10
|
|
- GRID_BROWSER_TIMEOUT=10
|
|
- GRID_TIMEOUT=10
|
|
ports:
|
|
- 4442:4442
|
|
- 4443:4443
|
|
- 4444:4444
|
|
```
|
|
|
|
Important settings:
|
|
- `shm_size`: Sets the shared memory size for Firefox (2GB recommended)
|
|
- `SE_NODE_MAX_SESSIONS`: Maximum number of concurrent sessions per node
|
|
- `GRID_MAX_SESSION`: Maximum number of concurrent sessions in the hub
|
|
- `GRID_BROWSER_TIMEOUT` and `GRID_TIMEOUT`: Timeouts in seconds
|
|
|
|
After setting up Selenium, make sure to set the `SELENIUM_HOST` variable in your environment to point to the Selenium hub (typically `selenium-hub:4444`).
|
|
|
|
### Logging System
|
|
|
|
Logs are stored in `app/logs/app.log` with automatic 7-day rotation.
|
|
|
|
Log settings available in `.env` or docker:
|
|
|
|
```env
|
|
LOG_LEVEL=WARNING
|
|
```
|
|
|
|
Available log levels:
|
|
- DEBUG: Detailed information for debugging
|
|
- INFO: General operational information
|
|
- WARNING: Warnings that deserve attention (default)
|
|
- ERROR: Errors that don't stop operation
|
|
- CRITICAL: Critical errors that need immediate attention
|
|
|
|
## 🛠️ Maintenance
|
|
|
|
### Logs
|
|
|
|
View application logs:
|
|
```bash
|
|
docker-compose logs app
|
|
# or directly from the log file
|
|
cat app/logs/app.log
|
|
```
|
|
|
|
### Clearing the cache
|
|
|
|
When you need to clear:
|
|
```bash
|
|
docker-compose exec app rm -rf /app/cache/*
|
|
```
|
|
|
|
## 🚀 Integrations
|
|
|
|
- 🤖 **Telegram**: [Official Bot](https://t.me/leissoai_bot)
|
|
- 🦊 **Firefox**: Extension by [Clarissa Mendes](https://claromes.com/pages/whoami) - [Download](https://addons.mozilla.org/pt-BR/firefox/addon/marreta/) | [Source Code](https://github.com/manualdousuario/marreta-extensao)
|
|
- 🦋 **Bluesky**: Bot by [Joselito](https://bsky.app/profile/joseli.to) - [Profile](https://bsky.app/profile/marreta.pcdomanual.com) | [Source Code](https://github.com/manualdousuario/marreta-bot)
|
|
- 🍎 **Apple**: [Shortcuts](https://www.icloud.com/shortcuts/3594074b69ee4707af52ed78922d624f) integration
|
|
-
|
|
---
|
|
|
|
Made with ❤️! If you have questions or suggestions, open an issue and we'll help! 😉
|
|
|
|
Thanks to the project [https://github.com/burlesco/burlesco](Burlesco) and [https://github.com/nang-dev/hover-paywalls-browser-extension/](Hover) which was used as a basis for several rules!
|
|
|
|
## Star History
|
|
|
|
[](https://star-history.com/#manualdousuario/marreta&Date)
|