-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #12 from ESTOS/feature/BUILDSYS-389
BUILDSYS-389 Add Extension Element to the schema to announce extendable structures like with ... in asn1
- Loading branch information
Showing
14 changed files
with
1,957 additions
and
928 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -46,3 +46,4 @@ jobs: | |
uses: coverallsapp/github-action@master | ||
with: | ||
github-token: ${{ secrets.GITHUB_TOKEN }} | ||
parallel: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
{ | ||
"folders": [ | ||
{ | ||
"path": "." | ||
} | ||
], | ||
"settings": { | ||
"tslint.enable": false, | ||
"eslint.enable": true, | ||
"javascript.preferences.quoteStyle": "double", | ||
"typescript.preferences.quoteStyle": "double", | ||
"editor.tabCompletion": "on", | ||
"eslint.alwaysShowStatus": true, | ||
"editor.codeActionsOnSave": { | ||
"source.fixAll.eslint": "explicit" | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
import { ViewWriter } from "./ViewWriter"; | ||
import { ValueBlock, ValueBlockJson } from "./ValueBlock"; | ||
import { BaseBlock } from "./BaseBlock"; | ||
import { ETagClass, EUniversalTagNumber, typeStore } from "./TypeStore"; | ||
|
||
/** | ||
* It is possible to add a ... to the asn1 Schema for objects that are extendable (The other side may add attributes) | ||
* In order to handle that properly we define a dummy type inside of a schema and this dummy type tells us whether a structure may be larger than expecteed (contains a ... in the ans1 Definitions) | ||
* | ||
* This will value will never get encoded or decoded as there is no such type in any encoding | ||
*/ | ||
export class Extension extends BaseBlock<ValueBlock, ValueBlockJson> { | ||
static { | ||
typeStore.Extension = this; | ||
} | ||
|
||
public static override NAME = "NULL"; | ||
public static override defaultIDs = {tagClass: ETagClass.UNIVERSAL, tagNumber: EUniversalTagNumber.Extension}; | ||
|
||
constructor() { | ||
super({idBlock: Extension.defaultIDs}, ValueBlock); | ||
|
||
} | ||
|
||
public getValue(): null { | ||
return null; | ||
} | ||
|
||
public setValue(value: number): void { | ||
} | ||
|
||
public override fromBER(inputBuffer: ArrayBuffer | Uint8Array, inputOffset: number, inputLength: number): number { | ||
throw new Error("An extension attribute should never get decoded... It´s just for schema validation"); | ||
} | ||
|
||
public override toBER(sizeOnly?: boolean, writer?: ViewWriter): ArrayBuffer { | ||
throw new Error("An extension attribute should never get encoded... It´s just for schema validation"); | ||
} | ||
|
||
protected override onAsciiEncoding(): string { | ||
return `${(this.constructor as typeof Extension).NAME}`; | ||
} | ||
|
||
/** | ||
* A typeguard that allows to validate if a certain asn1.js object is of our type | ||
* | ||
* @param obj The object we want to match against the type of this class | ||
* @returns true if obj is of the same type as our class | ||
*/ | ||
public static typeGuard(obj: unknown | undefined): obj is Extension { | ||
return this.matches(obj); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.