Skip to content

Latest commit

 

History

History
133 lines (106 loc) · 4.75 KB

Committee-Guide.md

File metadata and controls

133 lines (106 loc) · 4.75 KB

Chain of Trust - Committee Procedures

This file contains the necessary steps for the committee to:

  • Add a new member into the Public Directory Smart Contract and
  • Add a member into the Chain of Trust Smart Contract.

Requirements

  • Please follow these instructions here to make sure you have the required setup before continuing

  • The "manager" is the owner of the Public Directory Smart Contract and has also privileges for adding members into the Chain of Trust Smart Contract, so make sure this step is accomplished before continuing.

    • the manager address must be the owner of the Public Directory Smart Contract
    • NOTE: if public direcctory has a multisignature owner scheme then this api will not have a method to allow interacting with the public directory.
    • You can verify you have privileges for the Public Directory Smart Contract by checking against the public directory api method, that will return a 200 status code otherwise will throw an exception.
    api_url=http://localhost:3002 # Set LACChain Trust url
    get_public_directory_manager="$api_url/api/v1/public-directory/get-manager"
    curl -X 'GET' \
    $get_public_directory_manager \
    -H 'accept: application/json'
  • You have access to a terminal from where you can execute some commands to interact with the contracts via the API client.

Operations

Onboarding a new member

Onboarding a Type-1 member into the Public Directory

requirements
  • You must have:
    1. The DID (Decentralized Identifier)
    2. New Member's Metadata
api_url=http://localhost:3002 # Set LACChain Trust url
validDays=500
expires=true
# metadata
did="did:lac1:1iT5Bd7Df76GVtsWfHEQpCE6461Coy1e9ijvWHMAxoVaBm7vpXTJWyPZzoeMsnUyth5V"
legalName="Acme Corp"
domainName="example.com" # optional
identificationData='{"id":'\"$did\"',"legalName":'\"$legalName\"',"domainName": '\"$domainName\"'}'

# process
add_type1_member_to_public_directory_url="$api_url"/api/v1/public-directory/add-type1-member
data='{"validDays":'$validDays', "expires":'$expires',"identificationData":'$identificationData'}'
curl -X 'POST' ${add_type1_member_to_public_directory_url} -H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d "$data"

Onboarding a Type-2 member into the Public Directory

  • You must have:
    1. The DID (Decentralized Identifier)
    2. New Member's Metadata
    3. The SCA to use
api_url=http://localhost:3002 # Set LACChain Trust url
path_to_public_cacrt=../certs/SCA/SCA.crt # you should point to the public Certificate Authority pem
validDays=500
expires=true
# metadata
did="did:lac1:1iT58jc7tEP4Y8zbf9Ma8dpdiGKZjzYmjtmFEZZ8Dias9rbBpAYS39dAekAZupNDdgGb"
legalName="Ministry Of Country CHL"
countryCode="CHL" #urn:iso:std:iso:3166
url="https://lacnet.lacchain.net"
identificationData='{"id":'\"$did\"',"legalName":'\"$legalName\"',"countryCode": '\"$countryCode\"', "url": '\"$url\"'}'

# process
add_member_to_public_directory_url="$api_url"/api/v1/public-directory/add-type2-member
data='{"validDays":'$validDays', "expires":'$expires',"identificationData":'$identificationData'}'
curl -X 'POST' ${add_member_to_public_directory_url} -H 'accept: application/json' -F caCert=@$path_to_public_cacrt -F data=$data

Onboarding a Type-3 member into the Public Directory

  • You must have:
    1. The DID (Decentralized Identifier)
    2. New Member's Metadata according to type-3 data type
api_url=http://localhost:3002 # Set LACChain Trust url
validDays=500
expires=false
# metadata
did="did:lac1:1iT58jc7tEP4Y8zbf9Ma8dpdiGKZjzYmjtmFEZZ8Dias9rbBpAYS39dAekAZupNDdgGb"
legalName="Ministry Of Country CHL"
countryCode="CHL" #urn:iso:std:iso:3166
url="https://lacnet.lacchain.net"
identificationData='{"id":'\"$did\"',"legalName":'\"$legalName\"',"countryCode": '\"$countryCode\"', "url": '\"$url\"'}'

# process
add_type3_member_to_public_directory_url="$api_url"/api/v1/public-directory/add-type3-member
data='{"validDays":'$validDays', "expires":'$expires',"identificationData":'$identificationData'}'

curl -X 'POST' ${add_type3_member_to_public_directory_url} -H 'accept: application/json' \
-H 'Content-Type: application/json' \
-d "$data"

Onboarding a member into the Chain of Trust

# Input variables:
memberEntityAddress="0x41476C85Cd3d099175574F07490Dc6421f8fc9BB"
entityDid="did:lac1:1iT5LZxdDHmra8e33FfEfyS1BjqR9J2PwZN8JastL9YsBgvpxgjTnuKMi8HkRCvuRLYh"
validDays=100

# process
data='{
  "memberEntityAddress": '\"$memberEntityAddress\"',
  "entityDid": '\"$entityDid\"',
  "validDays": '$validDays'
}'
add_or_update_member="$api_url"/api/v1/chain-of-trust/add-or-update-member
curl -X 'POST' ${add_or_update_member} -H 'accept: application/json' \
  -H 'Content-Type: application/json' \
  -d "$data"