aboutsummaryrefslogtreecommitdiff
path: root/weed/operation/assign_file_id.go
blob: 169fd664d301058f91634a5debf3243a1708574b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
package operation

import (
	"encoding/json"
	"fmt"
	"net/url"
	"strconv"

	"github.com/chrislusf/seaweedfs/weed/glog"
	"github.com/chrislusf/seaweedfs/weed/util"
)

type VolumeAssignRequest struct {
	Count       uint64
	Replication string
	Collection  string
	Ttl         string
	DataCenter  string
	Rack        string
	DataNode    string
}

type AssignResult struct {
	Fid       string `json:"fid,omitempty"`
	Url       string `json:"url,omitempty"`
	PublicUrl string `json:"publicUrl,omitempty"`
	Count     uint64 `json:"count,omitempty"`
	Error     string `json:"error,omitempty"`
}

func Assign(server string, primaryRequest *VolumeAssignRequest, alternativeRequests ...*VolumeAssignRequest) (*AssignResult, error) {
	var requests []*VolumeAssignRequest
	requests = append(requests, primaryRequest)
	requests = append(requests, alternativeRequests...)

	var lastError error
	for i, request := range requests {
		if request == nil {
			continue
		}
		values := make(url.Values)
		values.Add("count", strconv.FormatUint(request.Count, 10))
		if request.Replication != "" {
			values.Add("replication", request.Replication)
		}
		if request.Collection != "" {
			values.Add("collection", request.Collection)
		}
		if request.Ttl != "" {
			values.Add("ttl", request.Ttl)
		}
		if request.DataCenter != "" {
			values.Add("dataCenter", request.DataCenter)
		}
		if request.Rack != "" {
			values.Add("rack", request.Rack)
		}
		if request.DataNode != "" {
			values.Add("dataNode", request.DataNode)
		}

		postUrl := fmt.Sprintf("http://%s/dir/assign", server)
		jsonBlob, err := util.Post(postUrl, values)
		glog.V(2).Infof("assign %d result from %s %+v : %s", i, postUrl, values, string(jsonBlob))
		if err != nil {
			return nil, err
		}
		var ret AssignResult
		err = json.Unmarshal(jsonBlob, &ret)
		if err != nil {
			return nil, fmt.Errorf("/dir/assign result JSON unmarshal error:%v, json:%s", err, string(jsonBlob))
		}
		if ret.Count <= 0 {
			lastError = fmt.Errorf("assign failure %d: %v", i+1, ret.Error)
			continue
		}
		return &ret, nil
	}
	return nil, lastError
}