You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.go 1.7 kB

2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. package main
  2. import (
  3. //"context"
  4. //"io"
  5. "fmt"
  6. "os"
  7. //"path/filepath"
  8. //"sync"
  9. "strconv"
  10. //agentcaller "proto"
  11. //"github.com/pborman/uuid"
  12. //"github.com/streadway/amqp"
  13. //"google.golang.org/grpc"
  14. _ "google.golang.org/grpc/balancer/grpclb"
  15. )
  16. func main() {
  17. //TODO xh:加载配置文件,获取packetSizeInBytes、grpc port、ipfs port、最大副本数、本机公网Ip等信息,参照src/utils/config.go
  18. args := os.Args
  19. arg_num := len(os.Args)
  20. for i := 0; i < arg_num; i++ {
  21. fmt.Println(args[i])
  22. }
  23. //TODO: 改为交互式client,输入用户名及秘钥后进入交互界面
  24. switch args[1] {
  25. case "ecWrite":
  26. EcWrite(args[2], args[3], args[4], args[5])
  27. //TODO: 写入对象时,Coor判断对象是否已存在,如果存在,则直接返回
  28. case "write":
  29. numRep, _ := strconv.Atoi(args[5])
  30. if numRep <= 0 || numRep > 10 { //TODO xh:10改为从配置文件中读出的最大副本数
  31. print("write::InputError!") //TODO xh:优化提示语
  32. } else {
  33. RepWrite(args[2], args[3], args[4], numRep)
  34. }
  35. case "read":
  36. Read(args[2], args[3], args[4])
  37. case "move":
  38. Move(args[2], args[3], args[4]) //bucket object destination
  39. }
  40. /*
  41. TO DO:
  42. 1. ls命令,显示用户指定桶下的所有对象,及相关的元数据
  43. 2. rm命令,用户指定bucket和object名,执行删除操作
  44. 3. update命令,用户发起对象更新命令,查询元数据,判断对象的冗余方式,删除旧对象(unpin所有的副本或编码块),写入新对象
  45. 4. ipfsStat命令,查看本地有无ipfsdaemon,ipfs目录的使用率
  46. 5. ipfsFlush命令,unpin本地ipfs目录中的所有cid(block)
  47. */
  48. }

本项目旨在将云际存储公共基础设施化,使个人及企业可低门槛使用高效的云际存储服务(安装开箱即用云际存储客户端即可,无需关注其他组件的部署),同时支持用户灵活便捷定制云际存储的功能细节。

Contributors (1)