IPFS interface definitions used by implementations for API compatibility
The primary goal of this module is to define and ensure that IPFS core implementations and their respective client libraries implement the same interface, so that developers can quickly change between a local and a remote node without having to change their applications.
It offers a set of typescript interface definitions that define the IPFS core API. Once your implementation implements those APIs you can use the tests found in the interface-ipfs-core module to validate your implementation.
In JavaScript land:
$ npm install ipfs-core-types
Install ipfs-core-types
as one of the dependencies of your project and use it to ensure your implementations API compatibility:
/**
* @implements {import('ipfs-core-types').IPFS}
*/
class MyImpl {
// your implementation goes here
}
import type { IPFS } from 'ipfs-core-types'
class MyImpl implements IPFS {
// your implementation goes here
}
In order to validate API compatibility you can run typescript over your implementation which will point out all the API compatibilities if there are some.
Feel free to join in. All welcome. Open an issue!
This repository falls under the IPFS Code of Conduct.
Generated using TypeDoc