Skip to content

Commit

Permalink
added support for account number.
Browse files Browse the repository at this point in the history
  • Loading branch information
bunjik committed Jan 10, 2022
1 parent 10adadf commit b79dc49
Show file tree
Hide file tree
Showing 7 changed files with 210 additions and 149 deletions.
6 changes: 6 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
# aws-console-customize-extension

![Chrome Web Store](https://img.shields.io/chrome-web-store/v/cjpikjjajakahcpglopbmobcoiibcpcd.svg)

customize aws console chrome-extension

- Ver 1.0.2
- added support for account number.

- Ver 1.0.1
- change header area detection.

Expand Down
55 changes: 37 additions & 18 deletions css/extension.css
Original file line number Diff line number Diff line change
@@ -1,16 +1,11 @@
#ruleLabel {
position: fixed;
top: 6px;
left: 4px;
background-color: white;
color:black;
opacity:0.8;
font-size:15px;
padding: 4px 10px;
z-index: 9999;
font-weight:700;
border-radius: 5px;
pointer-events: none;
body.extension {
margin: 0px;
padding: 0px;
background-color: #FFFFFF;
min-height:240px;
height:auto !important;
height:100vh;
max-height: 100vh;
}

#previewLabel {
Expand All @@ -20,19 +15,43 @@
background-color: white;
color:black;
opacity:0.7;
font-size:15px;
padding: 4px 10px;
font-size:12px;
padding: 2px 10px;
z-index: 999;
font-weight:700;
border-radius: 5px;
pointer-events: none;
line-height: 1.6em;
font-family: sans-serif;
white-space: nowrap;
}

body.extension {
margin: 10px;
background-color: #FFFFFF;
.previewHeader {
display: flex;
align-items: center;
position: relative;
color: white;
line-height: 32px;
text-shadow: 0 1px 0 #000;
_width: 25em;
_max-width: calc(80vw - 4px);
_border-radius: 3px;
}

#nav-logo {
position:relative;
margin-left: .5em;
margin-right: .5em;
vertical-align: middle;
width: 40px;
height: 24px;
background-image:url('');
background-position:center;
_background-size:contain;
background-size: 24px;
text-indent: -9999em;
background-repeat: no-repeat;
float: left;
}

.disable_rule {
Expand Down
124 changes: 69 additions & 55 deletions extension.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,61 +2,75 @@
* AWS Console Customize Extension
* Created by fumiharu kinoshita
*/
const agent = window.navigator.userAgent.toLowerCase();
const SETTING_KEY = 'awsconsole';

function getStorage() {
if (agent.indexOf("chrome") != -1) {
// chrome extension
return new Promise((resolve, reject) => {
chrome.storage.sync.get(SETTING_KEY, (ruleList) => {
if (chrome.runtime.lastError) {
reject(chrome.runtime.lastError);
} else {
resolve(ruleList);
}
})
});
} else {
// other browser
return browser.storage.sync.get(SETTING_KEY);
}
}

function applyRule(rule) {
// header
$('header > nav').css('background-color', rule.color);
$('.globalNav-0366 > a').css('background-color', rule.color);

// footer
$('#console-nav-footer-inner').css('background-color', rule.color);

// label
if (rule.showLabel && rule.label != null && rule.label.length > 0) {
$('body').prepend('<span id="ruleLabel">' + rule.label + '</span>');
}
}


$(function() {
// get username, account number, region

var nameElm = $("#nav-usernameMenu span:first span:first");
//var nameElm = $(".ThRjn7o-KwO0459UzmvoU.w8Kxy2XztOAkWobGpdJLt span:first");
if (nameElm.length == 0) {
// old layout
nameElm = $("#nav-usernameMenu");
}
var name = nameElm.text();
//console.log(name);

var acctElm = $("span[data-testid='aws-my-account-details']");
var acct = acctElm.text();

var regions = location.search.match(/region=(.*?)(&|$)/);
var region = "";
if (regions != null && regions.length > 1) {
region = regions[1];
}

// show/hide label
$('#consoleNavHeader').hover(
() => $('#ruleLabel').css('visibility', 'hidden'),
() => $('#ruleLabel').css('visibility', '')
);

// load setting.
chrome.storage.sync.get(['awsconsole'], function(ruleList) {
ruleList.awsconsole.some(rule => {
var re = new RegExp(rule.user);
if (rule.enableRule && (re.test(name) || re.test(acct))) {
if (region == rule.region || "all-region" == rule.region) {
// apply rule.

// for old layout
$('#nav-menubar').css('background-color', rule.color);
$('.nav-menu').css('background-color', rule.color);
$('#nav-menu-right').css('background-color', rule.color);
$('#console-nav-footer').css('background-color', rule.color);

// for new layout
$('#awsc-nav-header').css('background-color', rule.color);
$('#console-nav-footer-inner').css('background-color', rule.color);

// update layout
//$('.globalNav-0324').css('background-color', rule.color);
$('header > nav').css('background-color', rule.color);

if (rule.showLabel && rule.label != null && rule.label.length > 0) {
$('body').prepend('<span id="ruleLabel">' + rule.label + '</span>');
}
return true;
}
}
});
// get username, accountId, region
var name = $("span[data-testid='awsc-nav-account-menu-button'] span:first").text();
var acct = $("div[data-testid='account-detail-menu'] span:nth-child(2)").text();
acct = acct.replaceAll('-', '');
//console.log(name, accountId);

var regions = location.search.match(/region=(.*?)(&|$)/);
var region = "";
if (regions != null && regions.length > 1) {
region = regions[1];
}

// show/hide label
$('#consoleNavHeader').hover(
() => $('#ruleLabel').css('visibility', 'hidden'),
() => $('#ruleLabel').css('visibility', '')
);

// load setting.
getStorage().then(ruleList => {
ruleList[SETTING_KEY].some(rule => {
var re = new RegExp(rule.user);
if (rule.enableRule && (re.test(name) || re.test(acct))) {
if (region == rule.region || "all-region" == rule.region) {
// apply rule.
applyRule(rule);
return true;
}
}
});
},
err => {
console.error(err);
});
});
42 changes: 42 additions & 0 deletions js/common.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@

const agent = window.navigator.userAgent.toLowerCase();
const SETTING_KEY = 'awsconsole';

function getStorage() {
if (agent.indexOf("chrome") != -1) {
// chrome extension
return new Promise((resolve, reject) => {
chrome.storage.sync.get(SETTING_KEY, (ruleList) => {
if (chrome.runtime.lastError) {
reject(chrome.runtime.lastError);
} else {
resolve(ruleList);
}
})
});
} else {
// other browser
return browser.storage.sync.get(SETTING_KEY);
}
}

function setStorage(val) {
var data = {};
data[SETTING_KEY] = val;
if (agent.indexOf("chrome") != -1) {
// chrome extension
return new Promise((resolve, reject) => {
chrome.storage.sync.set(data, () => {
if (chrome.runtime.lastError) {
reject(chrome.runtime.lastError);
} else {
resolve();
}
});
});
} else {
// other browser
return browser.storage.sync.set(data);
}
}

37 changes: 15 additions & 22 deletions js/options.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
var app = angular.module('awsConsoleModApp', ['ui.bootstrap', 'ui.sortable', 'colorpicker.module']);

//directive
// directive
app.directive('fileModel',function($parse){
return{
restrict: 'A',
Expand All @@ -18,7 +18,10 @@ app.directive('fileModel',function($parse){
// translate filter
app.filter('translate', function() {
return function(key) {
var res = chrome.i18n.getMessage(key.replace(/-/g, '_'));
var res = key;
if (agent.indexOf("chrome") != -1) {
res = chrome.i18n.getMessage(key.replace(/-/g, '_'));
}
return res != '' ? res : key;
}
});
Expand Down Expand Up @@ -67,24 +70,20 @@ app.controller('appCtrl', ['$scope', '$filter', function ($scope, $filter) {
$scope.previewRule = defaultRule;

$scope.ruleList = [];

//$scope.orgRulelist = [];
//$scope.prevIdx = -99;
$scope.orgRuleList = [];

$scope.loadSetting = function() {
//console.log("loadSetting...");

chrome.storage.sync.get(['awsconsole'], function(result) {
$scope.ruleList = result.awsconsole || [];
if ($scope.ruleList.length == 0) {
$scope.ruleList.push(angular.copy(defaultRule));
}
//$scope.orgRulelist = angular.copy($scope.ruleList);
$scope.$applyAsync();
getStorage().then(result => {
$scope.ruleList = result.awsconsole || [];
if ($scope.ruleList.length == 0) {
$scope.ruleList.push(angular.copy(defaultRule));
}
$scope.orgRulelist = angular.copy($scope.ruleList);
$scope.$applyAsync();
});
}

// check modified rule
// check modified rule.
$scope.checkModified = function() {
}

Expand Down Expand Up @@ -116,8 +115,7 @@ app.controller('appCtrl', ['$scope', '$filter', function ($scope, $filter) {

// save rule.
$scope.apply = function() {
chrome.storage.sync.set({ awsconsole: angular.copy($scope.ruleList) }, function() {
});
setStorage(angular.copy($scope.ruleList)).then(() => console.log("saved"));
}

// export rule.
Expand Down Expand Up @@ -160,11 +158,6 @@ app.controller('appCtrl', ['$scope', '$filter', function ($scope, $filter) {
} else {
$scope.previewRule = defaultRule;
}
// check modified
//if (idx != $scope.prevIdx) {
// console.log("check modify. [" + idx + "]");
// $scope.prevIdx = idx;
//}
}

$scope.sortableOptions = {
Expand Down
9 changes: 7 additions & 2 deletions manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,21 @@
"manifest_version": 2,
"name": "__MSG_ext_name__",
"description": "__MSG_ext_description__",
"version": "1.0.1",
"version": "1.0.2",
"default_locale": "en",
"content_scripts": [
{
"run_at":"document_end",
"matches": ["https://*.console.aws.amazon.com/*"],
"js": ["js/jquery.min.js", "extension.js"],
"css": ["css/extension.css"]
}
],
"options_page": "options.html",
"options_ui": {
"browser_style": true,
"open_in_tab": true,
"page": "options.html"
},
"permissions": [
"storage"
],
Expand Down
Loading

0 comments on commit b79dc49

Please sign in to comment.