nodeannotations
is a library to bring the support of Annotations in NodeJS.
nodeannotations
provides a set of functions and classes to parse any annotated file.
It can be used to develop other libraries which can use Annotation to achieve dynamic and hassel-free Class, Method or Variable Level configurations.
- Clone the example repository
SSH :git clone git@github.com:anupam-git/nodeannotations-example.git
HTTPS :git clone https://github.com/anupam-git/nodeannotations-example.git
- Install Dependencies
npm install
- Test the Parser
node testParser.js
npm install --save nodeannotations
Create the annotations and place them in a folder, say [project root]/myannotations
myannotations/Path.js
const {Annotation} = require("nodeannotations");
class Path extends Annotation {
constructor() {
super("Path");
}
dir() { return this.dir; }
param() { return this.param; }
}
module.exports = Path;
myannotations/Request.js
const {Annotation} = require("nodeannotations");
class Request extends Annotation {
constructor() {
super("Request");
}
}
module.exports = Request;
annotatedFile.js
/**
* @Request("/controller/endpoint/param")
* @Path(dir="/home/user1", param="somevalue")
*/
function test() {
// Function Body
}
/**
* @Request("/controller1/endpoint1/param1")
*/
class Test {
constructor() {
/**
* @Request("/controller2/endpoint2/param2")
*/
let a;
/**
* @Path(dir="/home/user2", param="someothervalue")
*/
const b;
/**
* @Request("/controller3/endpoint3/param3")
*/
var c;
}
/**
* @Path(dir="/home", param="test123")
*/
testFunction(req) {
// Function Body
}
}
Parse the annotated file by calling parse
function with arguments
filePath
: Path of the Annotated File to be Parsed. In this case, it should be the absolute path to theannotatedFile.js
file.annotationsPath
: Path of the directory containing the Annotations. In this case, it should be the absolute path to themyannotations
directory.
const {AnnotationParser} = require("nodeannotations");
try {
let annotatedElements = AnnotationParser.parse(__dirname+"/annotatedFile.js", __dirname+"/myannotations/");
console.log("Example to Loop through all the annotated Elements :");
// Loop through all elements (Class, Method, Variable) that are annotated
/*
OUTPUT :
test : Method
{"value":"","objectOf":"Simple"}
{"value":"/controller/endpoint/param","objectOf":"Request"}
{"value":null,"objectOf":"Path","dir":"/home/user1","param":"somevalue"}
Test : Class
{"value":"/controller1/endpoint1/param1","objectOf":"Request"}
a : Variable
{"value":"/controller2/endpoint2/param2","objectOf":"Request"}
b : Variable
{"value":null,"objectOf":"Path","dir":"/home/user2","param":"someothervalue"}
c : Variable
{"value":"/controller3/endpoint3/param3","objectOf":"Request"}
testFunction : Method
{"value":null,"objectOf":"Path","dir":"/home","param":"test123"}
*/
annotatedElements.forEach((annotatedElement) => {
console.log("\t"+annotatedElement.getName()+" : "+annotatedElement.getType());
// Loop and Print All annotations of the current Element
annotatedElement.getAnnotations().forEach((annotation) => {
console.log("\t\t"+JSON.stringify(annotation));
});
console.log();
});
console.log("\n\nExample to Loop through the elements which are annotated with @Path() :");
// Loop through the elements which are annotated with @Request()
/*
OUTPUT :
test : Method
{"value":"","objectOf":"Simple"}
{"value":"/controller/endpoint/param","objectOf":"Request"}
{"value":null,"objectOf":"Path","dir":"/home/user1","param":"somevalue"}
Test : Class
{"value":"/controller1/endpoint1/param1","objectOf":"Request"}
a : Variable
{"value":"/controller2/endpoint2/param2","objectOf":"Request"}
c : Variable
{"value":"/controller3/endpoint3/param3","objectOf":"Request"}
*/
annotatedElements.filterBy("Request").forEach((annotatedElement) => {
console.log("\t"+annotatedElement.getName()+" : "+annotatedElement.getType());
// Loop and Print All annotations of the current Element
annotatedElement.getAnnotations().forEach((annotation) => {
console.log("\t\t"+JSON.stringify(annotation));
});
console.log();
});
console.log("\n\nExample to Loop through the elements which are annotated with @Path():");
// Loop through the elements which are annotated with @Path()
/*
OUTPUT :
test : Method
dir: /home/user1
b : Variable
dir: /home/user2
testFunction : Method
dir: /home
*/
annotatedElements.filterBy("Path").forEach((annotatedElement) => {
console.log("\t"+annotatedElement.getName()+" : "+annotatedElement.getType());
// Loop and Print the "dir" value of the @Path annotation
console.log("\t\tdir: "+annotatedElement.getAnnotation("Path").dir);
console.log();
});
} catch (err) {
console.log(err);
}
Find the Complete Example Here : nodeannotations-example
Stores the value
of the Annotation
/**
* @Annotation("someValue")
*/
function test() {
//Function Body
}
value
will have the data someValue
for the function test()
Stores the value of the parameter param
of the Annotation
/**
* @Annotation(param1="someValue1", param2="someValue2")
*/
function test() {
//Function Body
}
param1
will have the data someValue1
for the function and param2
will have the data someValue2
for the function test()
Stores the type of the Annotation
/**
* @Annotation("someValue")
*/
function test() {
//Function Body
}
objectOf
will have the data Annotation
for the function test()
Returns the name of the Element
/**
* @Annotation("someValue")
*/
function test() {
//Function Body
}
getName()
will return "test"
for the function test()
Returns the Type of the Element (Variable, Method or Class)
/**
* @Annotation("someValue")
*/
function test() {
//Function Body
}
getType()
will return "Method"
for the function test()
Returns the Annotation
object which is an instance of objectOf
/**
* @Annotation("someValue")
*/
function test() {
//Function Body
}
getAnnotation("Annotation")
will return {"value":"someValue","objectOf":"Annotation"}
for the function test()
Returns all the annotations of an AnnotatedElement
/**
* @Annotation("someValue")
* @AnotherAnnotation("someMoreValue")
*/
function test() {
//Function Body
}
getAnnotations()
will return [{"value":"someValue","objectOf":"Annotation"}, {"value":"someMoreValue","objectOf":"AnotherAnnotation"}]
for the function test()
Constant value 0
representing the AnnotatedElement
as a Class
Constant value 1
representing the AnnotatedElement
as a Method
Constant value 2
representing the AnnotatedElement
as a Variable
Parses a file for Annotations and returns annotatedElements
object.
filePath
is the Absolute Path of File to be Parsed for Annotations.annotationsPath
is the Absolute Path of Directory containing all theAnnotation
Classes.
annotatedElements
is the result returned after parsing the file with path filePath
. annotatedElements
is the array of all the elements that are Annotated with the Annotations available at annotationsPath
. The Array Object also has method filterBy(objectOf)
filterBy
returns the array of Elements Annotated with objectOf
type of Annotation
let annotatedElements = AnnotationParser.parse(__dirname+"/annotatedFile.js", __dirname+"/myannotations/");
annotatedElements.forEach((annotatedElement) => {
console.log("\t"+annotatedElement.getName()+" : "+annotatedElement.getType());
// Loop and Print All annotations of the current Element
annotatedElement.getAnnotations().forEach((annotation) => {
console.log("\t\t"+JSON.stringify(annotation));
});
console.log();
});
// Loop through the elements which are annotated with @Annotation()
annotatedElements.filterBy("Annotation").forEach((annotatedElement) => {
console.log("\t"+annotatedElement.getName()+" : "+annotatedElement.getType());
// Loop and Print All annotations of the current Element
annotatedElement.getAnnotations().forEach((annotation) => {
console.log("\t\t"+JSON.stringify(annotation));
});
console.log();
});