Skip to content

Commit

Permalink
Merge pull request #45 from JustaName-id/staging
Browse files Browse the repository at this point in the history
Staging
  • Loading branch information
Ghadi8 authored Oct 15, 2024
2 parents 3dc0207 + 6947b13 commit c474f55
Showing 1 changed file with 243 additions and 55 deletions.
298 changes: 243 additions & 55 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,96 +1,284 @@
# Justanid
# JustVerified

<a alt="Nx logo" href="https://nx.dev" target="_blank" rel="noreferrer"><img src="https://raw.githubusercontent.com/nrwl/nx/master/images/nx-logo.png" width="45"></a>
This repository contains a Verifiable Credentials Management API built with NestJS. It allows users to generate and verify verifiable credentials (VCs) using social accounts (GitHub, Twitter, Discord, Telegram), email verification, and integrates with the Ethereum Name Service (ENS). The API supports generating VCs, verifying VCs, and managing records on ENS names.

✨ Your new, shiny [Nx workspace](https://nx.dev) is ready ✨.
## Features

[Learn more about this workspace setup and its capabilities](https://nx.dev/getting-started/intro#learn-nx?utm_source=nx_project&amp;utm_medium=readme&amp;utm_campaign=nx_projects) or run `npx nx graph` to visually explore what was created. Now, let's get you up to speed!
- **Verifiable Credentials Generation**: Generate verifiable credentials using social accounts (GitHub, Twitter, Discord, Telegram) and email verification.
- **ENS Integration**: Manage ENS subdomain records, append VCs to ENS records, and verify records.
- **Authentication**: Authenticate users using Ethereum addresses and ENS domains.
- **Credential Verification**: Verify the validity of VCs and ensure they are issued by trusted issuers.
- **Social Account Verification**: Integrate with social platforms for account verification.
- **Email Verification**: Send OTPs to verify email addresses.

## Run tasks
## Architecture

To run tasks with Nx use:
The application is built using the NestJS framework, following a modular architecture. Key components include:

```sh
npx nx <target> <project-name>
- **Controllers**: Handle incoming HTTP requests and return responses.
- **Services**: Contain business logic and interact with external services or databases.
- **Resolvers**: Resolve data for VCs, including social accounts and email.
- **Agents**: Use [Veramo](https://veramo.io/) to create and verify verifiable credentials.
- **Mappers**: Map data between different formats and layers.
- **Filters**: Handle exceptions and errors.

## Prerequisites


## Getting Started

### Installation

1. Clone the repository:

```bash
git clone https://github.com/JustaName-id/JustVerified.git
cd JustVerified
```

2. Install the dependencies:

```bash
yarn
```

### Environment Variables

Create a .env file in the root directory and set the environment variables similar to the .env.example file.

### Running the Application

Start the application in development mode:

```bash
nx serve vc-api
```

The application will be available at http://localhost:3000/verifications/v1.

## API Documentation

### Authentication

#### Get Nonce

**Endpoint**: `GET /auth/nonce`

**Description**: Generates a nonce for signing in.

**Response**:

```json
{
"nonce": "1234567890abcdef"
}
```
#### Sign In

**Endpoint**: `POST /auth/signin`

**Description**: Authenticates a user by verifying their Ethereum signature.

**Request Body**:

```json
{
"message": "<Signed_Nonce_Message>",
"signature": "<Ethereum_Signature>"
}
```

**Response**:

```json
{
"ens": "user.yourdomain.eth",
"address": "0xYourEthereumAddress",
"chainId": 1
}
```

#### Get Current Session
**Endpoint**: `GET /auth/current`

**Description**: Retrieves the current authenticated session.

**Response**:

```json
{
"ens": "user.yourdomain.eth",
"address": "0xYourEthereumAddress",
"chainId": 1
}
```

For example:
#### Sign out

**Endpoint**: `POST /auth/signout`

```sh
npx nx build myproject
**Description**: Signs out the current user.

**Response**:

```json
{
"message": "You have been signed out"
}
```

These targets are either [inferred automatically](https://nx.dev/concepts/inferred-tasks?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) or defined in the `project.json` or `package.json` files.
### Credentials

#### Get Social Auth URL

**Endpoint**: `GET /credentials/social/:authName`

**Description**: Generates an authentication URL for social platforms.

**Parameters:

- `authName`: The name of the social platform (e.g., `github`, `twitter`, `discord`, `telegram`).

**Response**:

Streamed response with the authentication URL.

#### Social Callback

**Endpoint**: `GET /credentials/social/:authName/callback`

**Description**: Callback endpoint for social authentication.

[More about running tasks in the docs &raquo;](https://nx.dev/features/run-tasks?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
**Parameters:
- `authName`: The name of the social platform (e.g., `github`, `twitter`, `discord`, `telegram`).

## Add new projects
**Query Parameters:**
- `code`: The authorization code from the social platform.
- `state`: Encrypted state containing user information.

While you could add new projects to your workspace manually, you might want to leverage [Nx plugins](https://nx.dev/concepts/nx-plugins?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) and their [code generation](https://nx.dev/features/generate-code?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) feature.
**Response**:
HTML response indicating success or failure.

To install a new plugin you can use the `nx add` command. Here's an example of adding the React plugin:
```sh
npx nx add @nx/react
#### Generate Email OTP

**Endpoint**: `POST /credentials/email`

**Description**: Sends an OTP to the specified email address for verification.

**Query Parameters:**
- `email`: The email address to verify.

**Response**:
```json
{
"state": "<Encrypted_State>"
}
```

Use the plugin's generator to create new projects. For example, to create a new React app or library:
#### Resend Email OTP

```sh
# Genenerate an app
npx nx g @nx/react:app demo
**Endpoint**: `POST /credentials/email/resend`

# Generate a library
npx nx g @nx/react:lib some-lib
**Description**: Resends the OTP to the email address.

**Request Body**:
```json
{
"state": "<Encrypted_State>"
}
```

You can use `npx nx list` to get a list of installed plugins. Then, run `npx nx list <plugin-name>` to learn about more specific capabilities of a particular plugin. Alternatively, [install Nx Console](https://nx.dev/getting-started/editor-setup?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) to browse plugins and generators in your IDE.
**Response**:
HTTP 200 OK

#### Verify Email OTP

**Endpoint**: `POST /credentials/email/verify`

**Description**: Verifies the OTP provided by the user.

[Learn more about Nx plugins &raquo;](https://nx.dev/concepts/nx-plugins?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) | [Browse the plugin registry &raquo;](https://nx.dev/plugin-registry?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
**Request Body**:
```json
{
"state": "<Encrypted_State>",
"otp": "<User_Entered_OTP>"
}
```

## Set up CI!
**Response**:

```json
{
"dataKey": "email_yourdomain.eth",
"verifiedCredential": {
"@context": [...],
"type": [...],
"credentialSubject": {
"email": "[email protected]",
"did": "did:ens:user.yourdomain.eth#<Public_Key>"
},
"issuer": {
"id": "did:ens:yourdomain.eth#<Public_Key>"
},
"proof": {...},
"expirationDate": "2024-10-15T12:34:56Z",
"issuanceDate": "2023-10-15T12:34:56Z"
}
}
```
#### Clear Email State

### Step 1
**Endpoint**: `POST /credentials/email/clear`

To connect to Nx Cloud, run the following command:
**Description**: Clears the email verification state.

```sh
npx nx connect
**Request Body**:
```json
{
"state": "<Encrypted_State>"
}
```

Connecting to Nx Cloud ensures a [fast and scalable CI](https://nx.dev/ci/intro/why-nx-cloud?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects) pipeline. It includes features such as:
**Response**:
HTTP 200 OK

### Verify Records

#### Verify Records

- [Remote caching](https://nx.dev/ci/features/remote-cache?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
- [Task distribution across multiple machines](https://nx.dev/ci/features/distribute-task-execution?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
- [Automated e2e test splitting](https://nx.dev/ci/features/split-e2e-tasks?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
- [Task flakiness detection and rerunning](https://nx.dev/ci/features/flaky-tasks?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
**Endpoint**: `GET /verify-records`

### Step 2
**Description**: Verifies the records associated with an ENS name.

Use the following command to configure a CI workflow for your workspace:
**Query Parameters:**
- `ens`: The ENS name to verify.
- `chainId`: The chain ID (1 for Mainnet, 11155111 for Sepolia).
- `credentials`: An array of VCs to verify.
- `matchStandard`(optional): Whether to match to the user set records. Default is false.
- `issuer`(optional): The issuer domain. Defaults to `justverified.eth`.

```sh
npx nx g ci-workflow
**Response**:

```json
{
"records": {
"com.twitter": true,
"com.github": false,
"email": true
}
}
```

[Learn more about Nx on CI](https://nx.dev/ci/intro/ci-with-nx#ready-get-started-with-your-provider?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
## Contributing

Contributions are welcome! Please open an issue or submit a pull request for any changes.

When contributing, please follow the existing code style and conventions.


## Install Nx Console

Nx Console is an editor extension that enriches your developer experience. It lets you run tasks, generate code, and improves code autocompletion in your IDE. It is available for VSCode and IntelliJ.

[Install Nx Console &raquo;](https://nx.dev/getting-started/editor-setup?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)

## Useful links

Learn more:

- [Learn more about this workspace setup](https://nx.dev/getting-started/intro#learn-nx?utm_source=nx_project&amp;utm_medium=readme&amp;utm_campaign=nx_projects)
- [Learn about Nx on CI](https://nx.dev/ci/intro/ci-with-nx?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
- [Releasing Packages with Nx release](https://nx.dev/features/manage-releases?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)
- [What are Nx plugins?](https://nx.dev/concepts/nx-plugins?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)

And join the Nx community:
- [Discord](https://go.nx.dev/community)
- [Follow us on X](https://twitter.com/nxdevtools) or [LinkedIn](https://www.linkedin.com/company/nrwl)
- [Our Youtube channel](https://www.youtube.com/@nxdevtools)
- [Our blog](https://nx.dev/blog?utm_source=nx_project&utm_medium=readme&utm_campaign=nx_projects)

0 comments on commit c474f55

Please sign in to comment.