代码拉取完成,页面将自动刷新
/*
Copyright DTCC 2016 All Rights Reserved.
SPDX-License-Identifier: Apache-2.0
*/
package java
import (
"archive/tar"
"bytes"
"compress/gzip"
"errors"
"fmt"
"io"
"net/url"
"regexp"
"strings"
"gitee.com/hyperledger-fabric-gm/fabric/common/flogging"
"gitee.com/hyperledger-fabric-gm/fabric/core/chaincode/platforms"
"gitee.com/hyperledger-fabric-gm/fabric/core/chaincode/platforms/ccmetadata"
"gitee.com/hyperledger-fabric-gm/fabric/core/chaincode/platforms/util"
cutil "gitee.com/hyperledger-fabric-gm/fabric/core/container/util"
pb "gitee.com/hyperledger-fabric-gm/fabric/protos/peer"
)
var logger = flogging.MustGetLogger("chaincode.platform.java")
// Platform for java chaincodes in java
type Platform struct {
}
// Name returns the name of this platform
func (javaPlatform *Platform) Name() string {
return pb.ChaincodeSpec_JAVA.String()
}
//ValidatePath validates the java chaincode paths
func (javaPlatform *Platform) ValidatePath(rawPath string) error {
path, err := url.Parse(rawPath)
if err != nil || path == nil {
logger.Errorf("invalid chaincode path %s %v", rawPath, err)
return fmt.Errorf("invalid path: %s", err)
}
return nil
}
func (javaPlatform *Platform) ValidateCodePackage(code []byte) error {
if len(code) == 0 {
// Nothing to validate if no CodePackage was included
return nil
}
// File to be valid should match first RegExp and not match second one.
filesToMatch := regexp.MustCompile(`^(/)?src/((src|META-INF)/.*|(build\.gradle|settings\.gradle|pom\.xml))`)
filesToIgnore := regexp.MustCompile(`.*\.class$`)
is := bytes.NewReader(code)
gr, err := gzip.NewReader(is)
if err != nil {
return fmt.Errorf("failure opening codepackage gzip stream: %s", err)
}
tr := tar.NewReader(gr)
for {
header, err := tr.Next()
if err != nil {
if err == io.EOF {
// We only get here if there are no more entries to scan
break
} else {
return err
}
}
// --------------------------------------------------------------------------------------
// Check name for conforming path
// --------------------------------------------------------------------------------------
if !filesToMatch.MatchString(header.Name) || filesToIgnore.MatchString(header.Name) {
return fmt.Errorf("illegal file detected in payload: \"%s\"", header.Name)
}
// --------------------------------------------------------------------------------------
// Check that file mode makes sense
// --------------------------------------------------------------------------------------
// Acceptable flags:
// ISREG == 0100000
// -rw-rw-rw- == 0666
//
// Anything else is suspect in this context and will be rejected
// --------------------------------------------------------------------------------------
if header.Mode&^0100666 != 0 {
return fmt.Errorf("illegal file mode detected for file %s: %o", header.Name, header.Mode)
}
}
return nil
}
// WritePackage writes the java chaincode package
func (javaPlatform *Platform) GetDeploymentPayload(path string) ([]byte, error) {
logger.Debugf("Packaging java project from path %s", path)
var err error
// --------------------------------------------------------------------------------------
// Write out our tar package
// --------------------------------------------------------------------------------------
payload := bytes.NewBuffer(nil)
gw := gzip.NewWriter(payload)
tw := tar.NewWriter(gw)
folder := path
if folder == "" {
logger.Error("ChaincodeSpec's path cannot be empty")
return nil, errors.New("ChaincodeSpec's path cannot be empty")
}
// trim trailing slash if it exists
if folder[len(folder)-1] == '/' {
folder = folder[:len(folder)-1]
}
if err = cutil.WriteJavaProjectToPackage(tw, folder); err != nil {
logger.Errorf("Error writing java project to tar package %s", err)
return nil, fmt.Errorf("Error writing Chaincode package contents: %s", err)
}
tw.Close()
gw.Close()
return payload.Bytes(), nil
}
func (javaPlatform *Platform) GenerateDockerfile() (string, error) {
var buf []string
buf = append(buf, "FROM "+cutil.GetDockerfileFromConfig("chaincode.java.runtime"))
buf = append(buf, "ADD binpackage.tar /root/chaincode-java/chaincode")
dockerFileContents := strings.Join(buf, "\n")
return dockerFileContents, nil
}
func (javaPlatform *Platform) GenerateDockerBuild(path string, code []byte, tw *tar.Writer) error {
codepackage := bytes.NewReader(code)
binpackage := bytes.NewBuffer(nil)
buildOptions := util.DockerBuildOptions{
Image: cutil.GetDockerfileFromConfig("chaincode.java.runtime"),
Cmd: "./build.sh",
InputStream: codepackage,
OutputStream: binpackage,
}
logger.Debugf("Executing docker build %v, %v", buildOptions.Image, buildOptions.Cmd)
err := util.DockerBuild(buildOptions)
if err != nil {
logger.Errorf("Can't build java chaincode %v", err)
return err
}
resultBytes := binpackage.Bytes()
return cutil.WriteBytesToPackage("binpackage.tar", resultBytes, tw)
}
//GetMetadataProvider fetches metadata provider given deployment spec
func (javaPlatform *Platform) GetMetadataProvider(code []byte) platforms.MetadataProvider {
return &ccmetadata.TargzMetadataProvider{Code: code}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。