Skip to content

Lor-Saba/Code-Injector

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

55 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Code-Injector

A WebExtensions based addon which let the user inject code into the websites

This is an add-on which requires a minimum of knowledge of web programming to be able to properly use it.

Purpose

There are several sites with invasive popups / login screens, a messy layout or some missing capabilities.
I was usually getting around these boring stuff by opening the browser console to edit the DOM style and structure but it was starting to get tiring doing it everytime, so why not making and extension which do it by itself in background?

Video & Screenshots

screenshot screenshot screenshot screenshot screenshot screenshot screenshot screenshot

Injection flow

The injection starts when a navigation is committed. (when the DOM is still loading)
Anyway, a rule can be set up to be injected on page load.
(after the document and all its resources have finished loading)

The rules whose path match with the page address will be selected and queued for injection. (from top to bottom)

Each rule may contain JavaScript, CSS, HTML and Files and will be splitted and injected with following order:

  1. Files (from top to bottom)
  2. CSS
  3. HTML
  4. JavaScript

Each rule will inherit the previous injected code. (same for files)

Import / Export

IMPORTANT :
Because of a security restriction the addon cannot create and save a file directly to the user system. For this reason the export is handled by using the user clipboard so that the user can save it by himself.

You can import and export from the settings page.

  • To export press on the export button.
    If successful you should have in your clipboard a JSON describing the rules list. Paste and save it where you want.

  • To import press on the import button.
    Navigate into your system and select a file containing a valid JSON of rules list.

( a message should appear to tell whether the operation is successful or not )

Installation

You can find and install this extension from the browsers store pages:

otherwise you can download, build and install the repository manually.

  • download the repository,

  • launch npm install to download the dev-dependencies,

  • launch grunt to build the extension,

  • a dist folder should have been generated containing the local version of Code-injector,

  • load that folder into your browser:

    • Firefox:
      go to about:debugging and load it as temporary extension

    • Chrome:
      Options > More tools > Extensions > Load unpacked extension...

    • Opera:
      Extensions > Developer mode > Load unpacked extension...

    • Edge:
      ???

    • Safari:
      ???

Files

Each rule can contain a list of files.

While typing the file path, an icon should appear on the right side of the input area indicating whether the file is remote or local and it's type (js/css/html) in blue.
If the file extension is not recognized as one of the 3 types mentioned above then the icon will show a red "X" on the edge and the file won't be injected.

Note:
You can force the file type by clicking on the icon and selecting the supposed language from the dropdown menu.

URL pattern

The URL pattern specifies in what pages the rule should be applied.

When a page is opened, the pattern will be matched against the full address of the new page, if the pattern corresponds with that address, then the code contained in the rule will be injected into the page.

The URL pattern follows the ECMAScript (a.k.a. JavaScript) regular expressions syntax, see here for more detailed information.

The add-on helps you on checking whether the pattern is correct by highlighting it in blue if it matches with the address of the current page and highlight it in red if it is invalid.

In depth example in case of google as url pattern:
(this example is just for knowledge purposes)

    // the URL pattern "google" is passed 
    // as argument to the RegExp constructor.
    new RegExp("google");

    // resulting in..
    /google/

    // assuming https://www.google.com as page address:
    /google/.test("https://www.google.com");

    // if TRUE the rule will be injected

Note:
Because the URL pattern text box is meant to contain only a regular expression, the forward slashes / used as delimiters in the JavaScript language are not needed.
You should therefore write hello world instead of /hello world/.

What's next

I would like to make it more and more easy to use so that even who's new to programming can use this add-on with ease.

Changelog

1.0.0 ( ?? / ?? / ???? )

  • base release of Code-Injector

Credits

Info

Web Injector is written and maintained by L.Sabatelli
Licenze: GPL