Create Architecture diagrams from your code.
npm install -g integraph
Map integrations adding @integraph
comments in your source code:
class ECommerce {
/**
* @integraph
* service: e-commerce
* integrations:
* - service: Payment gateway
* edgeDirection: RL
* group: External APIs
*/
processsPayment() {
// ...
}
}
Under your project root directory/repository, run the following command:
integraph
The generated diagram:
It will search for files containing @integraph
comments and mapping all integrations, and as results it generates the following files under the directory .integraph
:
-
diagram.js
- it contains the function
getDiagram
which returns themermaid
architeture diagram.
architecture-beta group externalapis[External APIs] service ecommerce(server)[e_commerce] service paymentgateway(server)[Payment gateway] in externalapis ecommerce:R -[ecommerce__paymentgateway]- L:paymentgateway
- it contains the function
-
integrations.js
- it contains the funciton
getIntegrations
which returns a json with all mappend integrations.
[ { "startPosition":{ "row":1, "column":4 }, "endPosition":{ "row":8, "column":7 }, "yaml":{ "service":"e-commerce", "integrations":[ { "service":"Payment gateway", "edgeDirection":"RL", "group":"External APIs" } ] }, "path":"diagrams/__tests__/fixtures/example_01.ts", "repo":"/~https://github.com/danilosampaio/integraph/blob/main", "sourceCode":"class ECommerce { ..." } ]
- it contains the funciton
-
arch.html
- a html page containing the diagram and a few actions such as
refresh
,show diagram source
, andshow integrations json
. Addtionally, it makes all edges clickable, adding the ability to open the souce file where the integration is defined.
- a html page containing the diagram and a few actions such as
-
main.css
- this is the css styles for the page
arch.html
- this is the css styles for the page
-
main.js
- this is the main
js
file which initialize mermaid library, render the diagram, etc.
- this is the main
/**
* @integraph
* service: <string> Service name. e.g Market Place, Payment API
* icon: <string> Icon name. e.g. server, database, logos:google-cloud, vscode-icons:file-type-mermaid
* group: <string> Group name. e.g. External APIs, Auth Services
* integrations: <object[]> list of integrations
* - service: <string> Service name. e.g Market Place, Payment API
* edgeDirection: <string> direction of the edge. e.g. RL, LR, TB, BT (see https://mermaid.js.org/syntax/architecture.html#edge-direction)
* group: <string> Group name. e.g. External APIs, Auth Services
* groupEdge: true (see https://mermaid.js.org/syntax/architecture.html#edges-out-of-groups)
* arrowedEdge: true (see https://mermaid.js.org/syntax/architecture.html#edges)
*/
class ECommerce {
/**
* @integraph
* service: e-commerce
* integrations:
* - service: Payment gateway
* edgeDirection: RL
*/
processsPayment() {
// ...
}
}
public class PaymentGateway {
/**
* @integraph
* service: Payment gateway
* group: External APIs
* integrations:
* - service: Bank API
* edgeDirection: RL
* - service: Fraud Detection
*/
public boolean postTransaction() {
// ...
}
}
"""
@integraph
service: Fraud Detection
group: AI Agents
integrations:
- service: Load AI Models
group: AI Agents
"""
def detectFraud():
print("all good!")
// @integraph
// service: Load AI Models
// group: AI Agents
// integrations:
// - service: chatgpt
//
fn loadModels() {
// ...
}
https://mermaid.js.org/syntax/architecture.html
https://icon-sets.iconify.design/logos/
https://unpkg.com/@iconify-json/logos@1/icons.json
https://unpkg.com/@iconify-json/ix@1.2.0/icons.json
https://unpkg.com/@iconify-json/vscode-icons@1.2.3/icons.json