committed_chaincode – Manage an committed chaincode on a Hyperledger Fabric channel
Synopsis
Commit a chaincode definition on a Hyperledger Fabric channel.
This module works with the IBM Support for Hyperledger Fabric software or the Hyperledger Fabric Open Source Stack running in a Red Hat OpenShift or Kubernetes cluster.
Parameters
- api_endpoint (required)
The URL for the Fabric operations console.
Type: str- api_authtype (required)
basic- Authenticate to the Fabric operations console using basic authentication. You must provide both a valid API key using api_key and API secret using api_secret.Type: str- api_key (required)
The API key for the Fabric operations console.
Type: str- api_secret
The API secret for the Fabric operations console.
Only required when api_authtype is
basic.Type: str- api_timeout
The timeout, in seconds, to use when interacting with the Fabric operations console.
Type: intDefault value:60- state
absent- If a chaincode definition matching the specified name, version and configuration is committed, then an error will be thrown, as it is not possible to uncommit a chaincode definition.
present- Asserts that a chaincode definition matching the specified name, version and configuration is committed on the specified channel. If it is not committed, then the chaincode definition with the specified name, version and configuration will be committed on the specified channel.Type: strDefault value:present- peer (required)
The peer to use to manage the committed chaincode definition.
You can pass a string, which is the display name of a peer registered with the Fabric operations console.
You can also pass a dict, which must match the result format of one of the ERROR while parsing: While parsing “M(peer_info)” at index 76: Module name “peer_info” is not a FQCN or ERROR while parsing: While parsing “M(peer)” at index 92: Module name “peer” is not a FQCN modules.
Type: raw- identity (required)
The identity to use when interacting with the peer.
You can pass a string, which is the path to the JSON file where the enrolled identity is stored.
You can also pass a dict, which must match the result format of one of the ERROR while parsing: While parsing “M(enrolled_identity_info)” at index 76: Module name “enrolled_identity_info” is not a FQCN or ERROR while parsing: While parsing “M(enrolled_identity)” at index 105: Module name “enrolled_identity” is not a FQCN modules.
Type: raw- msp_id (required)
The MSP ID to use for interacting with the peer.
Type: str- hsm
The PKCS #11 compliant HSM configuration to use for digital signatures.
Only required if the identity specified in identity was enrolled using an HSM.
Type: dict
- pkcs11library
The PKCS #11 library that should be used for digital signatures.
Type: str- label
The HSM label that should be used for digital signatures.
Type: str- pin
The HSM pin that should be used for digital signatures.
Type: str- channel (required)
The name of the channel.
Type: str- organizations
The list of organizations to use to endorse the transaction for committing the chaincode definition.
The organizations must all be members of the channel, must all have approved the chaincode definition, and must all have at least one anchor peer defined.
You can pass strings, which are the names of organizations that are registered with the Fabric operations console.
You can also pass a dict, which must match the result format of one of the ERROR while parsing: While parsing “M(organization_info)” at index 76: Module name “organization_info” is not a FQCN or ERROR while parsing: While parsing “M(organization)” at index 100: Module name “organization” is not a FQCN modules.
Only required when state is
present.Type: listElements: raw- name (required)
The name of the chaincode definition.
Type: str- version (required)
The version of the chaincode definition.
Type: str- sequence (required)
The sequence number of the chaincode definition.
Type: int- endorsement_policy_ref
A reference to a channel policy to use as the endorsement policy for this chaincode definition, for example /Channel/Application/MyEndorsementPolicy.
Type: str- endorsement_policy
The endorsement policy for this chaincode definition.
Type: str- endorsement_plugin
The endorsement plugin for this chaincode definition.
Type: str- validation_plugin
The validation plugin for this chaincode definition.
Type: str- init_required
True if this chaincode definition requires called the Init method before the Invoke method, false otherwise.
Type: bool- init_json_str
The JSON string to pass to the Init method. If init_required is true, then the transaciton will be submitted immediately after the commit completes sucessfully. Note if the transaction fails and you wish to resubmit this will need to be done via other (non-ansible) methods
Type: string- collections_config
The path to the collections configuration file for the chaincode definition.
Type: str- orderer_name
The name of the ordering service node to get the tls-certificate from
Type: strDefault value:the tls_cert for the orderering service will be found from the channel configuration
Examples
- name: Commit the chaincode definition on the channel
  hyperledger.fabric_ansible_collection.committed_chaincode:
    state: present
    api_endpoint: https://console.example.org:32000
    api_authtype: basic
    api_key: xxxxxxxx
    api_secret: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    peer: Org1 Peer
    identity: Org1 Admin.json
    msp_id: Org1MSP
    channel: mychannel
    name: fabcar
    version: 1.0.0
    sequence: 1
- name: Commit the chaincode definition on the channel with an endorsement policy and collection configuration
  hyperledger.fabric_ansible_collection.committed_chaincode:
    state: present
    api_endpoint: https://console.example.org:32000
    api_authtype: basic
    api_key: xxxxxxxx
    api_secret: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    peer: Org1 Peer
    identity: Org1 Admin.json
    msp_id: Org1MSP
    channel: mychannel
    name: fabcar
    version: 1.0.0
    sequence: 1
    endorsement_policy: AND('Org1MSP.peer', 'Org2MSP.peer')
    collections_config: collections-config.json
- name: Ensure the chaincode definition is not committed on the channel
  hyperledger.fabric_ansible_collection.committed_chaincode:
    state: absent
    api_endpoint: https://console.example.org:32000
    api_authtype: basic
    api_key: xxxxxxxx
    api_secret: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
    peer: Org1 Peer
    identity: Org1 Admin.json
    msp_id: Org1MSP
    channel: mychannel
    name: fabcar
    version: 1.0.0
    sequence: 1
Return Values
- committed_chaincode
The committed chaincode definition.
Returned: when state ispresentType: dict
- channel
The name of the channel.
Type: strSample:mychannel- name
The name of the chaincode definition.
Type: strSample:fabcar- version
The version of the chaincode definition.
Type: strSample:1.0.0- sequence
The sequence number of the chaincode definition.
Type: intSample:1- endorsement_policy_ref
The reference to a channel policy used as the endorsement policy for this chaincode definition.
Type: strSample:/Channel/Application/MyEndorsementPolicy- endorsement_policy
The endorsement policy for this chaincode definition.
Type: str- endorsement_plugin
The endorsement plugin for this chaincode definition.
Type: str- validation_plugin
The validation plugin for this chaincode definition.
Type: str- init_required
True if this chaincode definition requires called the Init method before the Invoke method, false otherwise.
Type: bool- collections_config
The path to the collections configuration file for the chaincode definition.
Type: str