Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

First version #1

Merged
merged 43 commits into from
Nov 18, 2022
Merged
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
43 commits
Select commit Hold shift + click to select a range
d4e2a94
First version
scripthunter7 Nov 1, 2022
5042931
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1011…
scripthunter7 Nov 3, 2022
62045fd
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1011…
scripthunter7 Nov 3, 2022
55ef5d8
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1011…
scripthunter7 Nov 3, 2022
e177e88
Improve ESLint config, resolve https://github.com/AdguardTeam/AGLint/…
scripthunter7 Nov 3, 2022
be22994
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1011…
scripthunter7 Nov 3, 2022
897f737
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1011…
scripthunter7 Nov 3, 2022
79c2246
Improve Agents
scripthunter7 Nov 3, 2022
4afb94c
Fix typo, resolve https://github.com/AdguardTeam/AGLint/pull/1#discus…
scripthunter7 Nov 3, 2022
b5b1760
Improve network rule type, Resolve https://github.com/AdguardTeam/AGL…
scripthunter7 Nov 3, 2022
2538206
Improve modifier list type, resolve https://github.com/AdguardTeam/AG…
scripthunter7 Nov 3, 2022
d8497f8
Improve comment detection
scripthunter7 Nov 3, 2022
c704474
Improve code quality, complete JSDoc
scripthunter7 Nov 3, 2022
d80025b
Test cosmetic rule modifiers
scripthunter7 Nov 3, 2022
5ef546a
Update constants
scripthunter7 Nov 3, 2022
98fb7d7
Trim comments at main comment parser
scripthunter7 Nov 3, 2022
dc8a47d
CSSTree-related quality improvement
scripthunter7 Nov 3, 2022
d4a84ba
Update constants
scripthunter7 Nov 3, 2022
19f1b81
More CSSTree tests
scripthunter7 Nov 3, 2022
4b015e6
More tests
scripthunter7 Nov 3, 2022
a517c2e
Update readme
scripthunter7 Nov 3, 2022
e79f35f
Small improvements
scripthunter7 Nov 3, 2022
8f23f38
Consistent rule property ordering
scripthunter7 Nov 4, 2022
031402f
Improve preprocessor parser
scripthunter7 Nov 4, 2022
15ae8db
Add throws to JSDoc
scripthunter7 Nov 4, 2022
f5cb723
Update readme
scripthunter7 Nov 4, 2022
74a00b6
Use adblock syntax in MD
scripthunter7 Nov 4, 2022
22d08d4
Quality improvement
scripthunter7 Nov 4, 2022
49644f7
Checksum metadata
scripthunter7 Nov 4, 2022
8f0257f
Update src/parser/comment/agent.ts
scripthunter7 Nov 11, 2022
b5ac6cd
Update src/utils/cosmetic-rule-separator.ts
scripthunter7 Nov 11, 2022
3818df4
Update src/parser/cosmetic/cosmetic.ts
scripthunter7 Nov 11, 2022
4803d7d
Documentation of exported interfaces and classes
scripthunter7 Nov 11, 2022
9c7f38e
Test main parser interface
scripthunter7 Nov 11, 2022
8c1709e
Resolve https://github.com/AdguardTeam/AGLint/pull/1#discussion_r1020…
scripthunter7 Nov 11, 2022
4e8d9a7
Remove commented codes
scripthunter7 Nov 11, 2022
97a755e
Fix network rule separator order
scripthunter7 Nov 11, 2022
1d6ba5c
More detailed examples
scripthunter7 Nov 11, 2022
1be05c6
TODO: uBO responseheader
scripthunter7 Nov 11, 2022
9adafd5
Improve agents
scripthunter7 Nov 11, 2022
59e4be2
Improve ABP snippets parsing
scripthunter7 Nov 13, 2022
e43f6e5
Improve uBO options
scripthunter7 Nov 13, 2022
e8f2b8d
Basic dev docs - show commands
scripthunter7 Nov 13, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
36 changes: 32 additions & 4 deletions .eslintrc
Original file line number Diff line number Diff line change
@@ -1,10 +1,38 @@
{
"root": true,
"parser": "@typescript-eslint/parser",
"plugins": ["@typescript-eslint", "prettier"],
"extends": ["eslint:recommended", "plugin:@typescript-eslint/eslint-recommended", "plugin:@typescript-eslint/recommended", "prettier"],
"parserOptions": {
"project": "tsconfig.eslint.json"
},
"plugins": ["import", "@typescript-eslint", "prettier"],
"extends": [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"airbnb-typescript/base",
"plugin:jsdoc/recommended",
"prettier"
],
"rules": {
"no-console": 1,
"prettier/prettier": 2
"prettier/prettier": 2,

"max-len": [
"error",
{
"code": 120,
"comments": 120,
"tabWidth": 4,
"ignoreUrls": false,
"ignoreTrailingComments": false,
"ignoreComments": false
}
],
"indent": [
"error",
4,
{
"SwitchCase": 1
}
]
}
}
4 changes: 3 additions & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ jobs:
run: yarn install --frozen-lockfile

- name: Run tests
run: yarn lint
run: yarn test

build:
needs: test
Expand All @@ -66,6 +66,8 @@ jobs:
- name: Run build script
run: yarn build

# TODO: Artifact / Create release:

# - name: Create release artifact
scripthunter7 marked this conversation as resolved.
Show resolved Hide resolved
# uses: actions/upload-artifact@v3
# with:
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@ node_modules
dist
*.log
coverage
.vscode
2 changes: 1 addition & 1 deletion .prettierrc
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"tabWidth": 4,
"endOfLine": "lf",
"printWidth": 100,
"printWidth": 120,
"singleQuote": false
}
7 changes: 0 additions & 7 deletions .vscode/extensions.json

This file was deleted.

6 changes: 0 additions & 6 deletions .vscode/settings.json

This file was deleted.

97 changes: 88 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,24 +27,103 @@ Table of Contents:
### Parser

- Parsing ADG/UBO/ABP rules into AST (string → AST)
- Tolerant
- Filter out syntax errors
- Render rules as strings (AST → string)
- Serialize rules (AST → string)

Example:
#### Parser example

This code:

```typescript
import { RuleParser } from "aglint/parser";

console.log(RuleParser.generate(RuleParser.parse("!+ NOT_OPTIMIZED PLATFORM( windows , mac)")));
console.log(RuleParser.generate(RuleParser.parse("[$path=/path, sajt=2]example.com,~example.net##.ad > .valami")));
console.log(RuleParser.generate(RuleParser.parse("example.com,~example.net##:matches-path(/path) .ad")));
console.log(RuleParser.generate(RuleParser.parse("[$path=/path]example.com,~example.net#%#//scriptlet('scriptlet', \"arg0\")")));
console.log(RuleParser.generate(RuleParser.parse("[$path=/path]example.com,~example.net##+js(scriptlet, , arg1)")));
console.log(RuleParser.generate(RuleParser.parse("example.com#$#scriptlet1 arg0\\ arg0 arg1; scriptlet2; scriptlet3;")));
console.log(RuleParser.generate(RuleParser.parse("!#if (adguard)")));
const ast = RuleParser.parse("example.com,~example.net#%#//scriptlet('prevent-setInterval', 'check', '!300')");
scripthunter7 marked this conversation as resolved.
Show resolved Hide resolved
```

will gives you this AST:

```json
{
"category": "Cosmetic",
"type": "ScriptletRule",
"syntax": "AdGuard",
"exception": false,
"modifiers": [],
"domains": [
{
"domain": "example.com",
"exception": false
},
{
"domain": "example.net",
"exception": true
}
],
"separator": "#%#//scriptlet",
"body": {
"scriptlets": [
{
"scriptlet": {
"type": "SingleQuoted",
"value": "prevent-setInterval"
},
"parameters": [
{
"type": "SingleQuoted",
"value": "check"
},
{
"type": "SingleQuoted",
"value": "!300"
}
]
}
]
}
}
```

Then, you can serialize this AST:
```typescript
RuleParser.generate(ast);
```

Which returns the rule as string:
```adblock
example.com,~example.net#%#//scriptlet('prevent-setInterval', 'check', '!300')
```

#### Another parser example

> *Please note that unnecessary spaces will disappear and CSS selectors will be regenerated according to uniform formatting*

```typescript
import { RuleParser } from "aglint/parser";

// General rules (ADG/uBO/ABP)
console.log(RuleParser.generate(RuleParser.parse("##.ad")));
console.log(RuleParser.generate(RuleParser.parse("##.ad:-abp-has(> .something)")));
console.log(RuleParser.generate(RuleParser.parse("-banner-350px-")));
console.log(RuleParser.generate(RuleParser.parse("/ad.js$script,third-party")));

// AdGuard-specific rules:
console.log(RuleParser.generate(RuleParser.parse("!+ NOT_OPTIMIZED PLATFORM(windows, mac)")));
console.log(RuleParser.generate(RuleParser.parse("!+ NOT_OPTIMIZED PLATFORM( windows, mac )")));
console.log(RuleParser.generate(RuleParser.parse("[$app=com.apple.Safari]example.org#%#//scriptlet('prevent-setInterval', 'check', '!300')")));
console.log(RuleParser.generate(RuleParser.parse("example.com,~example.net#@$?#@media (min-width: 1024px) { body:-abp-has(.ad) { padding: 0; } }")));
console.log(RuleParser.generate(RuleParser.parse("!#if (adguard)")));
console.log(RuleParser.generate(RuleParser.parse(`@@||example.org^$replace=/(<VAST[\\s\\S]*?>)[\\s\\S]*<\\/VAST>/v\\$1<\\/VAST>/i`)));

// uBlock-specific rules:
console.log(RuleParser.generate(RuleParser.parse("example.com,~example.net##:matches-path(/path) .ad")));
console.log(RuleParser.generate(RuleParser.parse("example.com,~example.net#@#:matches-path(/path) body:style(padding: 0;)")));
console.log(RuleParser.generate(RuleParser.parse("example.com##^script:has-text(something)")));
console.log(RuleParser.generate(RuleParser.parse("example.com##+js(scriptlet0, , arg0)")));

// Adblock Plus specific rules:
console.log(RuleParser.generate(RuleParser.parse("example.com#$#scriptlet1 arg0 arg1")));
console.log(RuleParser.generate(RuleParser.parse("example.com#$#scriptlet1 arg0\\ arg0 arg1; scriptlet2; scriptlet3;")));
```

### Converter (WIP)
Expand Down
5 changes: 0 additions & 5 deletions TODO.md

This file was deleted.

3 changes: 3 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,10 @@
"@typescript-eslint/eslint-plugin": "^5.27.0",
"@typescript-eslint/parser": "^5.27.0",
"eslint": "^8.24.0",
"eslint-config-airbnb-typescript": "^17.0.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-import": "^2.26.0",
"eslint-plugin-jsdoc": "^39.6.2",
"eslint-plugin-prettier": "^4.2.1",
"jest": "^29.1.2",
"node-fetch": "^3.2.10",
Expand Down
9 changes: 1 addition & 8 deletions src/converter/agents.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,2 @@
/**Known adblock agents */
export const ADBLOCK_AGENTS = [
"AdBlock",
"Adblock Plus",
"AdGuard",
"uBlock",
"uBlock Origin",
"AdBlocker Ultimate",
];
export const ADBLOCK_AGENTS = ["AdBlock", "Adblock Plus", "AdGuard", "uBlock", "uBlock Origin", "AdBlocker Ultimate"];
5 changes: 5 additions & 0 deletions src/converter/cosmetic-modifiers.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
/** Known AdGuard cosmetic rule modifiers */
export const ADG_COSMETIC_MODIFIERS = ["app", "domain", "path", "url"];

/** Known uBO cosmetic rule modifiers */
export const UBO_COSMETIC_MODIFIERS = ["matches-path"];
1 change: 1 addition & 0 deletions src/converter/metadata.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/**Known metadata headers */
export const METADATA_HEADERS = [
"Checksum",
"Description",
"Expires",
"Homepage",
Expand Down
2 changes: 1 addition & 1 deletion src/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/** AGLint */
/** AGLint root */

// TODO: Import all modules here
export * from "./parser/index";
Loading