Skip to content

Latest commit

 

History

History
122 lines (86 loc) · 4.43 KB

README.md

File metadata and controls

122 lines (86 loc) · 4.43 KB

Automated Scripting Tool

A powerful tool to automate any website with minimal effort! This script enables you to interact with websites manually and automatically generates a request-based automation script based on your actions.

Features

Core Functionalities

  • Ease of Use: Open a Puppeteer page, interact with the website as you normally would, and let the script do the rest.
  • Request-Based Automation: The script intercepts and analyzes all network requests to identify the sequence needed for automation.
  • JSON Mapping: Automatically generates a JSON file containing:
    • The mapped requests.
    • Indexes indicating the start and end points of the sequence.
  • Happy Path Generation: Send the JSON file along with a prompt to ChatGPT, and it will generate a complete automation script for you.

Who Benefits?

  • Beginner Automators: Those with limited knowledge of automation but want to streamline repetitive tasks.
  • Automation Experts: Professionals looking to reduce the time spent on creating automation workflows.
  • Lazy Developers: Developers who hate repetitive, mundane tasks.

Planned Improvements

  • Direct ChatGPT Integration: Automate the step of sending JSON to ChatGPT for script generation.
  • Enhanced Request Mapping: Improve the accuracy of request identification and testing across diverse websites.
  • Connected Requests by Cookies: Integrate flow detection using cookies.
  • Header-Based Mapping: Add logic to map requests based on headers.
  • Configuration File Support: Add a config file for custom settings.

How to Use

Prerequisites

  • Ensure you have Node.js installed on your system.

Installation

  1. Clone the repository:

    git clone https://github.com/Taha-daboussi/AutomatedScripting.git
    cd AutomatedScripting
  2. Install dependencies:

    npm install

Usage

  1. Open the Main.ts file and configure the following:

    • valuesToScrape: Define an array of strings representing the data you want to scrape.
    • starting URL: Set the initial URL of the target website.
  2. Run the script:

    npm start
  3. Interact with the website:

    • The Puppeteer browser will open.
    • Perform the flow of actions you want to automate.
  4. Finalize:

    • When you reach the final page that responds with the valuesToScrape, close the browser.
  5. JSON Generation:

    • The script will analyze intercepted requests and generate a JSON file containing:
      • Mapped requests.
      • Start and end indexes of the request sequence.
  6. Generate the Happy Path:

    • Use the JSON file with the following prompt (or a similar one) in ChatGPT:

      "Using the following JSON file, create a request-based automation script to replicate the flow."


How It Works

  1. Intercept Requests: The script tracks all network requests made during your interaction.
  2. Map Values: Matches the requests that respond with valuesToScrape.
  3. Request Linking: Maps the flow of requests, considering cookies, headers, and other identifiers.
  4. JSON Output: Generates a comprehensive JSON file to facilitate script generation.

How the Data Looks

Here are examples of the data generated by the script:

  1. Request Response Data: Request Response Data

    • This image showcases the raw data that will be scraped from Puppeteer.
  2. Mapped Related Requests: Mapped Related Requests

    • This illustrates the final result of mapping related requests.

Example Prompt for ChatGPT

Using this JSON file, generate a request-based automation script. The automation should replicate the flow of requests while ensuring it starts from the index specified and ends at the appropriate endpoint.

Contributing

Contributions are welcome! Here’s how you can help:

  • Test the tool on different websites.
  • Suggest improvements or report issues.
  • Implement features such as cookie-based mapping, header-based mapping, or a configuration file.

PS

I wrote this a couple of months ago during lunch breaks at work, so the code may not always work perfectly. There are many bugs and improvements that can be made.

Feel free to contact me if you need any help:

  • Discord: Blacken.eth
  • Twitter: Blacken_X