Blockchaindeveloper
Blockchaindeveloper

Reputation: 117

Chaincode not building - Go program error - Cannot refer to unexported name

I am getting an error while building my go code on an Ubuntu machine. I have check GOPATH variables and everything seems fine. Below is stack trace of error I am getting:

/go/src/Chaincodeexample$ go build # _/home/ubuntu/go/src/Chaincodeexample

./Samplesupplychain.go:13:14: cannot refer to unexported name shim.logger
./Samplesupplychain.go:91:5: syntax error: non-declaration statement outside function body

Below is my code :

import(
"errors"
"fmt"

"encoding/json"

"github.com/hyperledger/fabric/core/chaincode/shim"

)

var logger = shim.logger("my logger")
//Create a struct for these 2 values
type testuser struct{
    Username string `json:"username"`
    Fileuploaded string `json:"fileuploaded"`
}

//A function to create a user on the ledger

func CreateUser(stub shim.ChaincodeStubInterface, args []string) ([]byte, error){
    if len(args) < 2 {
        logger.Error("Invalid number of args")
        return nil, errors.New("Expected atleast 1 argument for user creation")
    }

    var Username = args[0]
    var UsernameInput = args[1]
    //trying to understand
    err := stub.PutState(Username, []byte(UsernameInput))
    if err != nil {
        logger.Error("Could not save new User to ledger", err)
        return nil, err
    }

    var customEvent = "{eventType: 'UserCreation', description:" + Username + "' Successfully created'}"
    err = stub.SetEvent("evtSender", []byte(customEvent))
    if err != nil {
        return nil, err
    }
    logger.Info("Successfully saved a supply chain user")
    return nil, nil


}

func Checkuploadstatus(stub shim.ChaincodeStubInterface, args []string) ([]byte, error) {
    logger.Debug("Entering supply-chain application")

    if len(args) < 1 {
        logger.Error("Invalid number of arguments")
        return nil, errors.New("Missing details")
    }



    var Fileuploadedstatus = args[0] 

    bytes, err := stub.GetState(Fileuploadedstatus) 
    if err != nil {
        logger.Error("Could not fetch Fileuploadedstatus with "+ Fileuploadedstatus +" from ledger", err)
        return nil, err
    }
    return bytes, nil
}

func (t *testuser) Init(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    return nil, nil


}

func (t *testuser) Query(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    if function == "Checkuploadstatus" {
        return Checkuploadstatus(stub, args)
    }
    return nil, nil
}



func (t *testuser) Invoke(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {
    if function == "CreateUser" {
        return CreateUser(stub, args)
        } else {
            return nil, errors.New(username + " does not have access to create a User")
        }

    }
    return nil, nil
}

Give me idea to resolve this.

Upvotes: 0

Views: 2274

Answers (1)

gonutz
gonutz

Reputation: 5582

In Go only you can only access names in other packages if they start with an upper-case letter. This is kind of like using public and private in Java or C++.

Call your type Logger instead of logger and it will work.

Upvotes: 3

Related Questions