Skip to content

Commit

Permalink
feat((background) added rule store to look up rules
Browse files Browse the repository at this point in the history
  • Loading branch information
shanmugharajk committed Aug 22, 2020
1 parent 07b50cd commit f636b53
Show file tree
Hide file tree
Showing 8 changed files with 81 additions and 7 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
# vue-chrome-interceptor
# vue-interceptor

A simple chrome extension which helps in url redirection, modify request/response headers written vue with vuetify.
A simple chrome/firefox extension which helps in url redirection, modify request/response headers written in vue with vuetify.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"name": "vue-chrome-interceptor",
"name": "vue-interceptor",
"version": "0.1.0",
"private": true,
"scripts": {
Expand Down
21 changes: 21 additions & 0 deletions src/background/background-script.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import { ruleStore } from './rules-store';
import { utils } from './utils';

class BackgroundScript {
init() {
try {
ruleStore.init();
browser.browserAction.onClicked.addListener(this.handleBrowserAction);
} catch (error) {
console.error(error);
}
}

// Handlers
handleBrowserAction() {
const optionsUrl = chrome.extension.getURL('options.html');
utils.openOptionsPage(optionsUrl);
}
}

export const backgroundScript = new BackgroundScript();
6 changes: 3 additions & 3 deletions src/background/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
browser.browserAction.onClicked.addListener(function() {
console.log('Hello from the background');
});
import { backgroundScript } from './background-script';

backgroundScript.init();
21 changes: 21 additions & 0 deletions src/background/rules-store.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import { Rule } from '@/libs';
import { RedirectRulesMap } from './types';
import { rulesRepository } from '../libs/storage/rules-repository';

class RuleStore {
allRules: Rule[] = [];
redirectRules: RedirectRulesMap = {};

async init() {
this.allRules = await this.fetchAll();
this.allRules.forEach(rule => {
console.log(rule);
});
}

async fetchAll() {
return await rulesRepository.fetchAll();
}
}

export const ruleStore = new RuleStore();
10 changes: 10 additions & 0 deletions src/background/types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
export interface RedirectRulesMap {
[fromUrl: string]: string;
}

export interface ModifyHeaderRulesMap {
[url: string]: {
key: string;
value: string | number;
};
}
22 changes: 22 additions & 0 deletions src/background/utils.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
class Utils {
openOptionsPage(optionsUrl: string) {
chrome.tabs.query({}, function(extensionTabs: chrome.tabs.Tab[]) {
let found = false;

for (let i = 0, len = extensionTabs.length; i < len; i++) {
if (optionsUrl === extensionTabs[i].url) {
found = true;
chrome.tabs.update(extensionTabs[i].id ?? Math.random(), {
selected: true
});
break;
}
}
if (found === false) {
chrome.tabs.create({ url: optionsUrl });
}
});
}
}

export const utils = new Utils();
2 changes: 1 addition & 1 deletion src/options/App.vue
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<v-app-bar-nav-icon>
<div class="logo"><span>VI</span></div>
</v-app-bar-nav-icon>
<v-toolbar-title>Vue Chrome Interceptor</v-toolbar-title>
<v-toolbar-title>Interceptor</v-toolbar-title>
</v-app-bar>

<v-main>
Expand Down

0 comments on commit f636b53

Please sign in to comment.