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

feat: implement renderer 2024 provider #177

Merged
merged 47 commits into from
Jun 13, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
61ed51f
feat: add compute hash utils
ldhyen99 Apr 26, 2024
034f537
feat: add prefix in compute hash function
ldhyen99 May 2, 2024
ca1e3f4
feat: create plugin that contain hash
ldhyen99 May 3, 2024
14fc4b8
test: add unit test for compute hash
ldhyen99 May 3, 2024
a49ee9c
feat: implement renderer 2024 provider
ducpm511 May 3, 2024
f02873d
feat: add plugin to agent.yml
ldhyen99 May 3, 2024
b572e1d
refactor: delete compute hash function in tools package
ldhyen99 May 3, 2024
fdac6c1
chore: update ts config file
ldhyen99 May 3, 2024
ec3746f
Merge branch 'feat/add_compute_hash_utils' into renderer2024
ducpm511 May 6, 2024
9a033de
feat: implement new UI for renderer on demo explorer
ducpm511 May 7, 2024
713e011
Merge branch 'next' into renderer2024
ducpm511 May 7, 2024
5afd5ab
feat: updated unit tests
ducpm511 May 7, 2024
caef6c5
feat: handled error
ducpm511 May 7, 2024
4001ef1
Merge branch 'next' into renderer2024
ducpm511 May 14, 2024
d3581cc
feat: updated according to feedback
ducpm511 May 14, 2024
2f05cca
feat: updated renderer to be able to use extractRendererMethod function
ducpm511 May 14, 2024
85b33a0
refactor: clean up renderer
ducpm511 May 17, 2024
7b4ac12
Merge branch 'next' into renderer2024
ducpm511 May 17, 2024
65b9a24
refactor: adding missing template
ducpm511 May 17, 2024
c55545e
Merge branch 'next' into renderer2024
ducpm511 May 17, 2024
fec182d
refactor: renamed provider name; replace context url
ducpm511 May 17, 2024
8891f63
Merge branch 'next' into renderer2024
ducpm511 May 17, 2024
edcfcc0
refactor: updated provider according to computeHash function changes
ducpm511 May 17, 2024
2e6ec77
refactor: implement to support mediaQuery and refactor code
ducpm511 May 21, 2024
360f777
refactor: enhance the performance by set documentLoader
namhoang1604 May 21, 2024
ac6094c
refactor: updated response type and rename test file
ducpm511 May 21, 2024
e3e78cc
refactor: updated default contexts for renderer
ducpm511 May 21, 2024
ac71f0b
fix: display rendered template on UI and return renderedTemplate fiel…
ldhyen99 May 24, 2024
607a359
refactor: update render template 2024
ducpm511 May 29, 2024
78445c2
feat: update demo-explorer to support render template 2024
ducpm511 Jun 4, 2024
e035b72
Merge branch 'next' into renderer2024
ducpm511 Jun 4, 2024
ab74283
chore: updated unit test corresponding to changes of render provider
ducpm511 Jun 6, 2024
d3bcc29
chore: fix renderer to address unit test
ducpm511 Jun 6, 2024
2080de3
Merge branch 'next' into renderer2024
ducpm511 Jun 6, 2024
ebca386
Merge branch 'next' into renderer2024
ducpm511 Jun 7, 2024
cce6eb6
chore: added more test case to increase the coverage
ducpm511 Jun 7, 2024
1d602ad
chore: added more unit test cases
ducpm511 Jun 7, 2024
5fbca74
Merge branch 'next' into renderer2024
ducpm511 Jun 7, 2024
46f7bcf
chore: reduced uncovered count for statement
ducpm511 Jun 10, 2024
c370dea
Merge branch 'next' into renderer2024
namhoang1604 Jun 12, 2024
a65aae1
chore: removed duplicate test case
ducpm511 Jun 12, 2024
d4e31b1
refactor: use the inline template if failed to fetch it from url.
ducpm511 Jun 12, 2024
75c4d42
fix: removed duplicate test case and implement mock fetch to simulate…
ducpm511 Jun 12, 2024
aa46d60
fix: wrong expected result
ducpm511 Jun 13, 2024
50c45c4
chore: removed meanless comment
ducpm511 Jun 13, 2024
ed4ec10
refactor: enhance the render template 2024
namhoang1604 Jun 13, 2024
25ff963
test: adjust to update the unit test of renderer plugin
namhoang1604 Jun 13, 2024
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
2 changes: 1 addition & 1 deletion jest.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ export default {
branches: 80,
functions: 80,
lines: 80,
statements: -10,
statements: -25,
},
},
};
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@
},
"resolutions": {
"@types/eslint": "^8.4.6",
"jsonld": "npm:@digitalcredentials/jsonld@^5.2.1"
"jsonld": "npm:@digitalcredentials/jsonld@5.2.1"
},
"engines": {
"node": "20.12.2"
Expand Down
23 changes: 22 additions & 1 deletion packages/core-types/src/plugin.schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -6183,12 +6183,33 @@
"documents": {
"type": "array",
"items": {
"type": "string"
"$ref": "#/components/schemas/IRenderDocument"
}
}
},
"required": [
"documents"
]
},
"IRenderDocument": {
"type": "object",
"properties": {
"type": {
"type": "string"
},
"renderedTemplate": {
"type": "string"
},
"name": {
"type": "string"
},
"id": {
"type": "string"
}
},
"required": [
"type",
"renderedTemplate"
],
"description": "Result of rendering a verifiable credential."
}
Expand Down
8 changes: 7 additions & 1 deletion packages/core-types/src/types/IRender.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,14 @@ export type IRendererContext = IAgentContext<
* Result of rendering a verifiable credential.
* @beta
*/
export interface IRenderDocument{
type: string;
renderedTemplate: string;
name?: string;
id?: string;
}
export interface IRenderResult {
documents: string[];
documents: IRenderDocument[];
}

/**
Expand Down
28 changes: 25 additions & 3 deletions packages/core-types/src/types/IRendererProvider.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import { IRendererContext } from './IRender';

/**
* The document to render.
* @public
Expand All @@ -13,9 +15,29 @@ export type RenderDocument = {
export interface IRendererProvider {
/**
* Render a verifiable credential using the specified render methods.
* @param template - The template to render.
* @param document - The document to render.
* @param data - The render method data.
* @param context - The context.
* @returns A promise that resolves to the rendered document.
*/
renderCredential(template: string, document: RenderDocument): Promise<string>;
renderCredential({
data,
context,
document,
}: {
data: any;
context?: IRendererContext;
document: RenderDocument;
}): Promise<IRenderedResult>;

extractData(data: any): { [k: string]: any };
}
/**
* The result of rendering
* @public
*/
export interface IRenderedResult {
id?: string;
name?: string;
renderedTemplate?: string;
errorMessages?: string;
}
6 changes: 2 additions & 4 deletions packages/core-types/src/types/vc-data-model.ts
Original file line number Diff line number Diff line change
Expand Up @@ -212,8 +212,6 @@ export enum RenderingType {
* @beta This API may change without prior notice.
*/
export interface RenderMethodPayload {
'@id'?: string;
'@type': RenderingType;

[x: string]: any; // Additional properties can be added dynamically
type: string;
data: any;
}
1 change: 1 addition & 0 deletions packages/demo-explorer/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
"agent-explore": "./bin/bin.js"
},
"scripts": {
"postinstall": "pnpm add --ignore-scripts ../../.tmp_npm/veramo/packages/credential-w3c/",
"dev": "craco start",
"build": "pnpm run build:explorer",
"build:explorer": "craco build",
Expand Down
78 changes: 41 additions & 37 deletions packages/demo-explorer/src/components/CredentialRender.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,13 @@
import { ProCard } from '@ant-design/pro-components'
import { QrCodeDocumentWrapper } from '@vckit/react-components'
import { Renderer, WebRenderingTemplate2022 } from '@vckit/renderer'
import {
Renderer,
WebRenderingTemplate2022,
RenderTemplate2024,
} from '@vckit/renderer'
import { useVeramo } from '@veramo-community/veramo-react'
import { VerifiableCredential } from '@veramo/core'
import { Button, Spin } from 'antd'
import { Button, Spin, Tabs } from 'antd'
import html2canvas from 'html2canvas'
import { CSSProperties, useCallback, useEffect, useState } from 'react'
import { useQuery } from 'react-query'
Expand Down Expand Up @@ -33,7 +37,7 @@ const CredentialRender: React.FC<CredentialRenderProps> = ({
hash,
}) => {
const { agent } = useVeramo()
const [documents, setDocuments] = useState<string[]>([])
const [documents, setDocuments] = useState<Array<any>>([])
const [qrCodeValue, setQrCodeValue] = useState<string>('')
const [isLoading, setIsLoading] = useState<boolean>(false)
const encryptedEndpoint = process.env.REACT_APP_ENCRYPTED_ENDPOINT
Expand All @@ -60,18 +64,14 @@ const CredentialRender: React.FC<CredentialRenderProps> = ({
const renderCredential = useCallback(async () => {
setIsLoading(true)
try {
const renderer = new Renderer({
providers: {
WebRenderingTemplate2022: new WebRenderingTemplate2022(),
},
defaultProvider: 'WebRenderingTemplate2022',
let documents = await agent?.renderCredential({credential})

documents = documents.documents.map((doc: any) => {
return {
...doc,
renderedTemplate: convertBase64ToString(doc.renderedTemplate),
}
})

let { documents }: { documents: string[] } =
await renderer.renderCredential({
credential,
})
documents = documents.map((doc) => convertBase64ToString(doc))
setDocuments(documents)
} catch (e) {}
setIsLoading(false)
Expand Down Expand Up @@ -116,29 +116,33 @@ const CredentialRender: React.FC<CredentialRenderProps> = ({

return (
<Spin tip="Loading..." spinning={isLoading || credentialLoading}>
<ProCard
style={proCardStyle}
title={<IdentifierProfile did={getIssuerDID(credential)} />}
>
<div id="render">
<QrCodeDocumentWrapper qrCodeValue={qrCodeValue}>
{!isLoading && !credentialLoading ? (
documents.length !== 0 ? (
documents.map((doc, i) => (
<div key={i} dangerouslySetInnerHTML={{ __html: doc }}></div>
))
) : (
<pre style={jsonStyle}>
{JSON.stringify(credential, null, 2)}
</pre>
)
) : (
<></>
)}
</QrCodeDocumentWrapper>
</div>
<Button onClick={printdiv}>Print</Button>
</ProCard>
{!isLoading && !credentialLoading ? (
documents.length !== 0 ? (
<Tabs
items={documents.map((doc, i) => ({
key: i.toString(),
label: `${doc.type}`,
children: (
<ProCard
style={proCardStyle}
title={<IdentifierProfile did={getIssuerDID(credential)} />}
>
<QrCodeDocumentWrapper qrCodeValue={qrCodeValue}>
<div
key={i}
dangerouslySetInnerHTML={{ __html: doc.renderedTemplate }}
></div>
</QrCodeDocumentWrapper>
</ProCard>
),
}))}
/>
) : (
<pre style={jsonStyle}>{JSON.stringify(credential, null, 2)}</pre>
)
) : (
<></>
)}
</Spin>
)
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
{
"@context": [
"https://www.w3.org/ns/credentials/v2",
"https://www.w3.org/ns/credentials/examples/v2",
"https://vckit-contexts.s3.ap-southeast-2.amazonaws.com/render-template-context-2024.json"
],
"id": "http://example.edu/credentials/3732",
"type": ["VerifiableCredential", "UniversityDegreeCredential"],
"issuer": "did:web:7703-42-119-80-19.ap.ngrok.io",
"issuanceDate": "2010-01-01T00:00:00Z",
"credentialSubject": {
"id": "did:example:ebfeb1f712ebc6f1c276e12ec21",
"name": "John Doe",
"degree": {
"type": "BachelorDegree",
"name": "Bachelor of Computer Science",
"degreeSchool": "Example University"
}
},
"renderMethod": [
{
"template": "<div style=\"width:300px; height:300px; border: 2px solid black; text-align:center\"> \n\t<h2>Certificate</h2>\n <p>Of Completion</p>\n <div> This is to certify that </div> \n <strong style=\"font-size: 16px\"> {{credentialSubject.name}} </strong>\n <div>has completed the {{credentialSubject.degree.name}}</div>\n <div> by {{credentialSubject.degree.degreeSchool}}. </div>\n</div>",
"@type": "RenderTemplate2024",
"mediaQuery": "@media (min-width: 1024px) {\n .title {\n font-weight: bold;\n color: #223675;\n }\n}",
"mediaType": "text/html",
"url": "",
"digestMultibase": "zQmXPqSNrf6ZR2R5VVdYRpPxQREDCW1i3h98NAHLdAwLBxx"
},
{
"template": "<div style=\"width:300px; height:100px; border: 2px solid black; text-align:center\">\n <div>\n This {{credentialSubject.degree.name}} is conferred to\n </div>\n <strong style=\"font-size: 16px\">\n {{credentialSubject.name}}\n </strong>\n <div>\n by {{credentialSubject.degree.degreeSchool}}.\n </div>\n</div>",
"@type": "WebRenderingTemplate2022"
}
]
}
12 changes: 12 additions & 0 deletions packages/example-documents/src/examples/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ import VerifiableBusinessCard from './VerifiableBusinessCard.json' assert { type
import VerifiablePostmanCollection from './VerifiablePostmanCollection.json' assert { type: 'json' };
import VerifiableScorecard from './VerifiableScorecard.json' assert { type: 'json' };
import UniversityDegreeCredential from './UniversityDegreeCredential.json' assert { type: 'json' };
import UniversityDegreeCredentialNewRenderer from './UniversityDegreeCredentialNewRenderer.json' assert { type: 'json' };

import TradeTrustInvoice from './TradeTrustInvoice.json' assert { type: 'json' };

Expand Down Expand Up @@ -758,4 +759,15 @@ export const credentialsIssueExamples = {
2
),
},
UniversityDegreeCredentialNewRenderer: {
description: 'UniversityDegreeCredentialNewRenderer',
value: JSON.stringify(
{
credential: UniversityDegreeCredentialNewRenderer,
proofFormat: 'lds',
},
null,
2
),
},
};
8 changes: 7 additions & 1 deletion packages/renderer/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,13 @@ To implement a new render provider, follow these steps:

2. Save the provider file in the `packages/renderer/src/providers` folder, using a name that corresponds to the render type. For example, if you want to implement a provider for `WebRenderingTemplate2022`, name the provider file as `web-rendering-template-2022.ts`.

3. Add the provider to the agent.yml file, as shown in the following example:
3. Delete `tsconfig.tsbuildinfo` and run build the plugin by running this command
```bash
pnpm build
```
To test it locally, you need to restart your vckit server.

4. Add the provider to the agent.yml file, as shown in the following example:

```yaml
renderer:
Expand Down
Loading
Loading