Skip to main content

yawgbot - yet another wg bot

Project description

yawgbot

PyPI version Code style: black

Yet Another WG helper bot. WG stands for Wohngemeinschaft, a German word that refers to a living arrangement in which several tenants share an apartment. It is aimed to automate the extremely complex and time-consuming task of finding a room or an apartment to rent. Initially it was only working for wg-gesucht.de, now it's a plugin-based system ready to be extended for every platform to find accommodation.

From a technical standpoint yawgbot is a simple tool that runs different plugins. A plugin either scrapes websites using requests and beautifulsoup4 or uses APIs (both public and undocumented) both to search for listings and to contact landlords. It uses a SQLite database to save contacted ads and to perform fewer requests to platforms. It also comes with a simple web UI to track your progress and gather your findings across different platforms.
The database is stored:

  • on GNU/Linux at ~/.local/share/yawgbot/yawgbot.sqlite
  • on Windows at %USERPROFILE%\AppData\Local\rcastellotti\yawgbot\yawgbot.sqlite
  • on macOS at ~/Library/Application Support/yawgbot/yawgbot.sqlite

running manually

To run the bot manually:

  • install the package with pip3 install yawgbot (a virtual environment is suggested)
  • configure .config.myl, stored
    • on GNU/Linux at ~/.config/yawgbot/config.yml
    • on Windows at %USERPROFILE%\AppData\Local\rcastellotti\yawgbot\config.yml
    • on macOS at ~/Library/Preferences/yawgbot/config.yml
  • create a new file named bot.py with the following content and run it:
from yawgbot import Bot
import logging

logging.basicConfig(level=logging.INFO)
bot = Bot(platforms=["wg-gesucht"])
bot.run()

running periodically with celery

Running in background at time intervals is achieved using Celery to schedule tasks. It is configured to use SQLite as both backend and broker, to know more read the docs. The file run_yawgbot.py, for example, runs the bot each 5 minutes, to use it:

  • run celery -A run_yawgbot.celery worker --loglevel=INFO to run the worker
  • run celery -A run_yawgbot.celery beat to schedule the bot

web UI

To start the web UI simply run yawgbot-web

plugins

creating a plugin

Extending yawgbot is a pretty straightforward process. A plugin is a simple module extending the PluginBase class, an example is wg-gesucht.py, supported plugins can be used just by instantiating Bot with the platforms argument. Custom plugins can be registered using the Bot.register_plugin() method.
To start creating a template you can use this boilerplate code:

from yawgbot.pluginBase import PluginBase


class YawgbotPlugin(PluginBase):
    def __init__(self):
        pass

    def get_ads(self, url):
        pass

    def parse_ad(self, ad):
        pass

    def contact_ad(self, slug):
        pass

    def run(self):
        pass

If you develop a plugin, consider creating a PR, I will be more than happy to work with you to make it an official plugin and ship it with yawgbot.

Each plugin should load configuration values using the static Bot.config() method.
To better understand plugins you can read the code in src/yawgbot/plugins.

wg-gesucht

config

wg-gesucht:
  username: ""
  password: ""
  message_template: ""
  base_url: ""

When configuring for use go on https://wg-gesucht.de and copy the url you are using to look for accommodation, then replace the last number with {} in order to be able to search across multiple pages, for example, if looking for apartments in Munich: base url is https://www.wg-gesucht.de/1-zimmer-wohnungen-in-Munchen.90.1.1.1.html , replace the last 1 as follows: https://www.wg-gesucht.de/1-zimmer-wohnungen-in-Munchen.90.1.1.{}.html

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

yawgbot-0.0.7.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

yawgbot-0.0.7-py3-none-any.whl (11.2 kB view details)

Uploaded Python 3

File details

Details for the file yawgbot-0.0.7.tar.gz.

File metadata

  • Download URL: yawgbot-0.0.7.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.7

File hashes

Hashes for yawgbot-0.0.7.tar.gz
Algorithm Hash digest
SHA256 32c8da9fc7b82ad5d3080c0e4e2b1a58fae40d780d6e859c228b980f373e9594
MD5 f703a9740c184b0c7b130eb17aeca70f
BLAKE2b-256 50bbec0d5443b9223377db26e9975083aeae67fafc23bc652b6632df3ca6ea14

See more details on using hashes here.

File details

Details for the file yawgbot-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: yawgbot-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 11.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.7

File hashes

Hashes for yawgbot-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 fa5ae9d062753905eb42b07c6a07e7837a38ba9670d4cae6ba2d687d5d4f434b
MD5 a874ea5adeb954a196bde73df5305e47
BLAKE2b-256 8fc90c0dfd4006514d92746695b656d736282899510ae1cd89d34a5d317f8f29

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page