mirror of
https://github.com/corda/corda.git
synced 2025-01-15 09:20:22 +00:00
2416ceaee4
* Sketch initial identity docs * Restructure confidential identity docs to better fit structure * Split confidential identities into API and concepts * Further expansion on basic identity conceptS * Merge Party type into api-identity.rst * Address feedback on written content * Rework inline code with literalinclude * Start addressing feedback from Richard * Clarify use of "counterparty" * Address comments on key concepts * Correct back to US english * Clarify distribution/publishing of identities * Update changelog around confidential identities
61 lines
2.3 KiB
ReStructuredText
61 lines
2.3 KiB
ReStructuredText
API
|
|
===
|
|
|
|
This section describes the APIs that are available for the development of CorDapps:
|
|
|
|
.. toctree::
|
|
:maxdepth: 1
|
|
|
|
api-states
|
|
api-persistence
|
|
api-contracts
|
|
api-vault-query
|
|
api-transactions
|
|
api-flows
|
|
api-identity
|
|
api-core-types
|
|
|
|
Before reading this page, you should be familiar with the :doc:`key concepts of Corda <key-concepts>`.
|
|
|
|
Internal APIs and stability guarantees
|
|
--------------------------------------
|
|
|
|
.. warning:: For Corda 1.0 we do not currently provide a stable wire protocol or support for database upgrades.
|
|
Additionally, the JSON format produced by the client-jackson module may change in future.
|
|
Therefore, you should not expect to be able to migrate persisted data from 1.0 to future versions.
|
|
|
|
Additionally, it may be necessary to recompile applications against future versions of the API until we begin offering
|
|
ABI stability as well. We plan to do this soon after the release of Corda 1.0.
|
|
|
|
Finally, please note that the 1.0 release has not yet been security audited. You should not run it in situations
|
|
where security is required.
|
|
|
|
As of Corda 1.0, the following modules export public API that we promise to maintain backwards compatibility for,
|
|
unless an incompatible change is required for security reasons:
|
|
|
|
* core
|
|
* client-rpc
|
|
* client-jackson
|
|
|
|
The following modules don't yet have a completely stable API, but we will do our best to minimise disruption to
|
|
developers using them until we are able to graduate them into the public API:
|
|
|
|
* the Gradle plugins (cordformation)
|
|
* node-driver
|
|
* confidential-identities
|
|
* test-utils
|
|
* client-jfx, client-mock
|
|
* finance
|
|
* anything under the experimental directory (sub-components here may never graduate)
|
|
|
|
We hope to graduate the node-driver, test-utils and confidential-identities modules in the next feature release
|
|
after 1.0. The bulk of the Corda API is found in the core module. Other modules should be assumed to be fully internal.
|
|
|
|
The web server module will be removed in future: you should build web frontends for CorDapps using standard frameworks
|
|
like Spring Boot, J2EE, Play, etc.
|
|
|
|
Code that falls into the following package namespaces are for internal use only and not public. In a future release the
|
|
node will not load any CorDapp which uses them.
|
|
|
|
* Any package in the ``net.corda`` namespace which contains ``.internal``
|
|
* ``net.corda.node`` |