2017-01-03 13:07:48 +00:00
<!-- If you edit this, then please make the same changes to layout_for_doc_website.html, as that is used for the web
doc site generation which we put analytics tracking on to identify any potential problem pages -->
2016-11-29 11:38:52 +00:00
<!DOCTYPE html>
<!-- [if IE 8]><html class="no - js lt - ie9" lang="en" > <![endif] -->
<!-- [if gt IE 8]><! --> < html class = "no-js" lang = "en" > <!-- <![endif] -->
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< title > Network permissioning — R3 Corda latest documentation< / title >
< link rel = "stylesheet" href = "_static/css/custom.css" type = "text/css" / >
< link rel = "top" title = "R3 Corda latest documentation" href = "index.html" / >
2016-11-29 18:44:59 +00:00
< link rel = "next" title = "Writing a contract" href = "tutorial-contract.html" / >
2016-11-29 11:38:52 +00:00
< link rel = "prev" title = "Node Explorer" href = "node-explorer.html" / >
< script src = "_static/js/modernizr.min.js" > < / script >
< / head >
< body class = "wy-body-for-nav" role = "document" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side" >
< div class = "wy-side-scroll" >
< div class = "wy-side-nav-search" >
< a href = "index.html" class = "icon icon-home" > R3 Corda
< / a >
< div class = "version" >
latest
< / div >
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / div >
< br >
2017-01-19 17:11:18 +00:00
API reference: < a href = "api/kotlin/corda/index.html" > Kotlin< / a > / < a href = "api/javadoc/index.html" > JavaDoc< / a >
2017-01-03 13:07:48 +00:00
< br >
< a href = "https://discourse.corda.net" > Discourse Forums< / a >
< br >
< a href = "http://slack.corda.net" > Slack< / a >
< br >
2016-11-29 11:38:52 +00:00
< / div >
< div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "main navigation" >
< p class = "caption" > < span class = "caption-text" > Getting started< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "inthebox.html" > What’ s included?< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "getting-set-up.html" > Getting set up< / a > < / li >
2017-01-06 17:38:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "getting-set-up-fault-finding.html" > Troubleshooting< / a > < / li >
2016-11-29 11:38:52 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "running-the-demos.html" > Running the demos< / a > < / li >
2016-11-29 18:44:59 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "CLI-vs-IDE.html" > CLI vs IDE< / a > < / li >
2016-11-29 11:38:52 +00:00
< / ul >
< p class = "caption" > < span class = "caption-text" > Key concepts< / span > < / p >
< ul >
2017-01-26 16:57:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts.html" > Overview< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-ecosystem.html" > Corda ecosystem< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-data-model.html" > Data model< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-core-types.html" > Core types< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-financial-model.html" > Financial model< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-flow-framework.html" > Flow framework< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-consensus-notaries.html" > Consensus and notaries< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-vault.html" > Vault< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "key-concepts-security-model.html" > Security model< / a > < / li >
2016-11-29 18:44:59 +00:00
< / ul >
< p class = "caption" > < span class = "caption-text" > CorDapps< / span > < / p >
< ul >
2017-01-06 17:38:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "creating-a-cordapp.html" > CorDapp basics< / a > < / li >
2017-02-08 16:08:46 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-cordapp.html" > The example CorDapp< / a > < / li >
2016-11-29 11:38:52 +00:00
< / ul >
< p class = "caption" > < span class = "caption-text" > The Corda node< / span > < / p >
< ul class = "current" >
< li class = "toctree-l1" > < a class = "reference internal" href = "clientrpc.html" > Client RPC< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "messaging.html" > Networking and messaging< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "persistence.html" > Persistence< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "node-administration.html" > Node administration< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "corda-configuration-file.html" > Node configuration< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "corda-plugins.html" > The Corda plugin framework< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "node-services.html" > Brief introduction to the node services< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "node-explorer.html" > Node Explorer< / a > < / li >
< li class = "toctree-l1 current" > < a class = "current reference internal" href = "#" > Network permissioning< / a > < ul >
2017-02-22 10:59:02 +00:00
< li class = "toctree-l2" > < a class = "reference internal" href = "#initial-registration" > Initial Registration< / a > < / li >
< li class = "toctree-l2" > < a class = "reference internal" href = "#starting-the-registration" > Starting the Registration< / a > < / li >
2016-11-29 11:38:52 +00:00
< / ul >
< / li >
< / ul >
< p class = "caption" > < span class = "caption-text" > Tutorials< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-contract.html" > Writing a contract< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-contract-clauses.html" > Writing a contract using clauses< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-test-dsl.html" > Writing a contract test< / a > < / li >
2017-02-22 10:59:02 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "contract-upgrade.html" > Upgrading Contracts< / a > < / li >
2017-01-06 17:38:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-integration-testing.html" > Integration testing< / a > < / li >
2016-11-29 11:38:52 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-clientrpc-api.html" > Client RPC API tutorial< / a > < / li >
2017-01-06 17:38:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-building-transactions.html" > Building transactions< / a > < / li >
2016-11-29 11:38:52 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "flow-state-machines.html" > Writing flows< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "flow-testing.html" > Writing flow tests< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "running-a-notary.html" > Running a notary service< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "using-a-notary.html" > Using a notary service< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "oracles.html" > Writing oracle services< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "tutorial-attachments.html" > Using attachments< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "event-scheduling.html" > Event scheduling< / a > < / li >
< / ul >
< p class = "caption" > < span class = "caption-text" > Other< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "network-simulator.html" > Network Simulator< / a > < / li >
2017-01-26 16:57:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "clauses.html" > Clauses< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "merkle-trees.html" > Transaction tear-offs< / a > < / li >
2016-11-29 11:38:52 +00:00
< / ul >
< p class = "caption" > < span class = "caption-text" > Component library< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "contract-catalogue.html" > Contract catalogue< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "contract-irs.html" > Interest rate swaps< / a > < / li >
< / ul >
< p class = "caption" > < span class = "caption-text" > Appendix< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "loadtesting.html" > Load testing< / a > < / li >
2017-01-06 17:38:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "setting-up-a-corda-network.html" > What is a corda network?< / a > < / li >
2016-11-29 11:38:52 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "secure-coding-guidelines.html" > Secure coding guidelines< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "release-process.html" > Release process< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "release-notes.html" > Release notes< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "codestyle.html" > Code style guide< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "building-the-docs.html" > Building the documentation< / a > < / li >
2017-01-26 16:57:23 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "further-notes-on-kotlin.html" > Further notes on Kotlin< / a > < / li >
2017-01-03 13:07:48 +00:00
< li class = "toctree-l1" > < a class = "reference internal" href = "publishing-corda.html" > Publishing Corda< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "azure-vm.html" > Working with the Corda Demo on Azure Marketplace< / a > < / li >
2016-11-29 11:38:52 +00:00
< / ul >
< p class = "caption" > < span class = "caption-text" > Glossary< / span > < / p >
< ul >
< li class = "toctree-l1" > < a class = "reference internal" href = "glossary.html" > Glossary< / a > < / li >
< / ul >
< / div >
< / div >
< / nav >
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" >
< nav class = "wy-nav-top" role = "navigation" aria-label = "top navigation" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "index.html" > R3 Corda< / a >
< / nav >
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "breadcrumbs navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "index.html" > Docs< / a > » < / li >
< li > Network permissioning< / li >
< li class = "wy-breadcrumbs-aside" >
< a href = "_sources/permissioning.txt" rel = "nofollow" > View page source< / a >
< / li >
< / ul >
< hr / >
< / div >
< div role = "main" class = "document" itemscope = "itemscope" itemtype = "http://schema.org/Article" >
< div itemprop = "articleBody" >
< div class = "section" id = "network-permissioning" >
< h1 > Network permissioning< a class = "headerlink" href = "#network-permissioning" title = "Permalink to this headline" > ¶< / a > < / h1 >
< p > The keystore located in < code class = "docutils literal" > < span class = "pre" > < workspace> /certificates/sslkeystore.jks< / span > < / code > is required to connect to the Corda network securely.
2017-01-03 13:07:48 +00:00
In development mode (when < code class = "docutils literal" > < span class = "pre" > devMode< / span > < span class = "pre" > =< / span > < span class = "pre" > true< / span > < / code > , see < a class = "reference internal" href = "corda-configuration-file.html" > < span class = "doc" > Node configuration< / span > < / a > for more information) a pre-configured
keystore will be used if the keystore does not exist. This is to ensure developers can get the nodes working as quickly
as possible.< / p >
< p > However this is not secure for the real network. This documentation will explain the procedure of obtaining a signed
certificate for TestNet.< / p >
2016-11-29 11:38:52 +00:00
< div class = "admonition warning" >
< p class = "first admonition-title" > Warning< / p >
2017-02-22 10:59:02 +00:00
< p class = "last" > The TestNet has not been setup yet as of Milestone 8 release. You will not be able to connect to the
2017-01-03 13:07:48 +00:00
certificate signing server.< / p >
2016-11-29 11:38:52 +00:00
< / div >
2017-02-22 10:59:02 +00:00
< div class = "section" id = "initial-registration" >
< h2 > Initial Registration< a class = "headerlink" href = "#initial-registration" title = "Permalink to this headline" > ¶< / a > < / h2 >
< p > The certificate signing request will be created based on node information obtained from the node configuration.
The following information from the node configuration file is needed to generate the request.< / p >
2016-11-29 11:38:52 +00:00
< table class = "docutils field-list" frame = "void" rules = "none" >
< col class = "field-name" / >
< col class = "field-body" / >
< tbody valign = "top" >
2017-01-03 13:07:48 +00:00
< tr class = "field-odd field" > < th class = "field-name" > myLegalName:< / th > < td class = "field-body" > < p class = "first" > Your company’ s legal name. e.g. “ Mega Corp LLC” . This needs to be unique on the network. If another node
has already been permissioned with this name then the permissioning server will automatically reject the request. The
request will also be rejected if the name contains a < code class = "docutils literal" > < span class = "pre" > =< / span > < / code > or < code class = "docutils literal" > < span class = "pre" > ,< / span > < / code > .< / p >
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
2017-01-06 17:38:23 +00:00
< p class = "last" > In a future version the uniqueness requirement will be relaxed to a X.500 name. This will allow differentiation
2017-01-03 13:07:48 +00:00
between entities with the same name.< / p >
< / div >
< / td >
2016-11-29 11:38:52 +00:00
< / tr >
2017-01-03 13:07:48 +00:00
< tr class = "field-even field" > < th class = "field-name" > nearestCity:< / th > < td class = "field-body" > < p class = "first" > e.g. “ London” < / p >
< / td >
2016-11-29 11:38:52 +00:00
< / tr >
2017-01-03 13:07:48 +00:00
< tr class = "field-odd field" > < th class = "field-name" > emailAddress:< / th > < td class = "field-body" > < p class = "first" > e.g. “ < a class = "reference external" href = "mailto:admin%40company.com" > admin< span > @ < / span > company< span > . < / span > com< / a > “ < / p >
< / td >
2016-11-29 11:38:52 +00:00
< / tr >
< tr class = "field-even field" > < th class = "field-name" colspan = "2" > certificateSigningService:< / th > < / tr >
2017-01-03 13:07:48 +00:00
< tr class = "field-even field" > < td > < / td > < td class = "field-body" > < p class = "first last" > Certificate signing server URL. A certificate signing server will be hosted by R3 in the near
future. e.g.” < a class = "reference external" href = "https://testnet.certificate.corda.net" > https://testnet.certificate.corda.net< / a > “ < / p >
< / td >
2016-11-29 11:38:52 +00:00
< / tr >
< / tbody >
< / table >
2017-02-22 10:59:02 +00:00
< p > A new pair of private and public keys generated by the Corda node will be used to create the request.< / p >
2016-11-29 11:38:52 +00:00
< p > The utility will submit the request to the network permissioning server and poll for a result periodically to retrieve the certificates.
2017-02-22 10:59:02 +00:00
Once the request has been approved and the certificates downloaded from the server, the node will create the keystore and trust store using the certificates and the generated private key.< / p >
2016-11-29 11:38:52 +00:00
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
2017-01-06 17:38:23 +00:00
< p class = "last" > You can exit the utility at any time if the approval process is taking longer than expected. The request process will resume on restart.< / p >
2016-11-29 11:38:52 +00:00
< / div >
2017-02-22 10:59:02 +00:00
< p > This process only is needed when the node connects to the network for the first time, or when the certificate expires.< / p >
2016-11-29 11:38:52 +00:00
< / div >
2017-02-22 10:59:02 +00:00
< div class = "section" id = "starting-the-registration" >
< h2 > Starting the Registration< a class = "headerlink" href = "#starting-the-registration" title = "Permalink to this headline" > ¶< / a > < / h2 >
2016-11-29 11:38:52 +00:00
< p > You will need to specify the working directory of your Corda node using < code class = "docutils literal" > < span class = "pre" > --base-dir< / span > < / code > flag. This is defaulted to current directory if left blank.
You can also specify the location of < code class = "docutils literal" > < span class = "pre" > node.conf< / span > < / code > with < code class = "docutils literal" > < span class = "pre" > --config-file< / span > < / code > flag if it’ s not in the working directory.< / p >
2017-02-22 10:59:02 +00:00
< p > < strong > To start the registration< / strong > :< / p >
< div class = "highlight-kotlin" > < div class = "highlight" > < pre > < span > < / span > < span class = "n" > java< / span > < span class = "p" > -< / span > < span class = "n" > jar< / span > < span class = "n" > corda< / span > < span class = "p" > .< / span > < span class = "n" > jar< / span > < span class = "p" > --< / span > < span class = "n" > initial< / span > < span class = "p" > -< / span > < span class = "n" > registration< / span > < span class = "p" > --< / span > < span class = "n" > base< / span > < span class = "p" > -< / span > < span class = "n" > dir< / span > < span class = "p" > < < < / span > < span class = "n" > optional< / span > < span class = "p" > > > < / span > < span class = "p" > --< / span > < span class = "n" > config< / span > < span class = "p" > -< / span > < span class = "n" > file< / span > < span class = "p" > < < < / span > < span class = "n" > optional< / span > < span class = "p" > > > < / span >
2016-11-29 11:38:52 +00:00
< / pre > < / div >
< / div >
< p > A < code class = "docutils literal" > < span class = "pre" > certificates< / span > < / code > folder containing the keystore and trust store will be created in the base directory when the process is completed.< / p >
< div class = "admonition warning" >
< p class = "first admonition-title" > Warning< / p >
< p class = "last" > The keystore is protected by the keystore password from the node configuration file. The password should kept safe to protect the private key and certificate.< / p >
< / div >
< div class = "admonition note" >
< p class = "first admonition-title" > Note< / p >
< p class = "last" > Password encryption in node configuration will be supported in subsequent release.< / p >
< / div >
< / div >
< / div >
< / div >
< / div >
< footer >
< div class = "rst-footer-buttons" role = "navigation" aria-label = "footer navigation" >
2016-11-29 18:44:59 +00:00
< a href = "tutorial-contract.html" class = "btn btn-neutral float-right" title = "Writing a contract" accesskey = "n" > Next < span class = "fa fa-arrow-circle-right" > < / span > < / a >
2016-11-29 11:38:52 +00:00
< a href = "node-explorer.html" class = "btn btn-neutral" title = "Node Explorer" accesskey = "p" > < span class = "fa fa-arrow-circle-left" > < / span > Previous< / a >
< / div >
< hr / >
< div role = "contentinfo" >
< p >
2016-11-29 18:44:59 +00:00
© Copyright 2016, R3 Limited.
2016-11-29 11:38:52 +00:00
< / p >
< / div >
Built with < a href = "http://sphinx-doc.org/" > Sphinx< / a > using a < a href = "https://github.com/snide/sphinx_rtd_theme" > theme< / a > provided by < a href = "https://readthedocs.org" > Read the Docs< / a > .
< / footer >
< / div >
< / div >
< / section >
< / div >
< script type = "text/javascript" >
var DOCUMENTATION_OPTIONS = {
URL_ROOT:'./',
VERSION:'latest',
COLLAPSE_INDEX:false,
FILE_SUFFIX:'.html',
HAS_SOURCE: true
};
< / script >
< script type = "text/javascript" src = "_static/jquery.js" > < / script >
< script type = "text/javascript" src = "_static/underscore.js" > < / script >
< script type = "text/javascript" src = "_static/doctools.js" > < / script >
< script type = "text/javascript" src = "_static/js/theme.js" > < / script >
< script type = "text/javascript" >
jQuery(function () {
SphinxRtdTheme.StickyNav.enable();
});
< / script >
< / body >
< / html >