Skip to content

Bot-detector/bot_detector

Repository files navigation

Setup

Requirements

  • Docker

General Setup

  1. create an .env file from the .env.example contents

    PROXY_API_KEY=""
    KAFKA_BOOTSTRAP_SERVERS="kafka:9092"
    
  2. Build and start the Docker container:

    docker compose up --build

Other Setup

Web Scraper

  1. Generate an API key from Webshare.

  2. Copy the contents of .env.example to a new .env file.

  3. Replace <api key> in the .env file with your API key:

    PROXY_API_KEY="<api key>"
    KAFKA_BOOTSTRAP_SERVERS="kafka:9092"

The Polylith Architecture

Overview

The Polylith architecture is a modular approach to organizing codebases, aimed at improving maintainability, reducing duplication, and providing better oversight of projects. It is particularly well-suited for managing large, complex applications.

Why Use Polylith?

  1. Reduce Duplication: With many repositories, schemas and functionalities are often replicated, leading to inconsistencies and maintenance challenges. Polylith consolidates shared code into reusable components.
  2. Improve Oversight: Managing multiple repositories can obscure the overall project structure. Polylith centralizes the architecture, making it easier to navigate and understand.
  3. Streamline Onboarding: New developers can quickly understand the project structure without needing to navigate numerous repositories.

Documentation

For an in-depth guide on Polylith architecture, visit the Polylith Documentation.

Commands

Below are the essential commands for working with Polylith in your project.

Create a Base

A base serves as the foundation for your architecture, often containing shared logic or configurations.

uv run poly create base --name <base_name>

Create a Component

A component is a reusable, self-contained module that encapsulates specific functionality.

uv run poly create component --name <component_name>

Create a Project

A project is the entry point for your application, built using the base and components.

uv run poly create project --name <project_name>

get new_highscore_data

select highscore_data_latest

calculate highscore_data_delta

insert highscore_data_delta

insert highscore_data

insert highscore_data

# trigger after insert
	# insert highscore_data_latest on duplicate_key update
		# trigger after insert
			# calculate delta
			# insert delta

About

monorepo for bot detector microservices

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published