1
0
mirror of https://github.com/haiwen/seafile-server.git synced 2025-05-04 06:07:08 +00:00
seafile-server/fileserver/searpc/searpc.go
Jiaqiang Xu 7420b8d738
Go fileserver (#437)
* Initial commit for fileserver written in golang.

[gofileserver] Fix some syntaxt errors.

Add fs backend and objstore test (#352)

* Add fs backend and objstore test

* modify test case and optimize fs backend

* Modify function name and first write temporary files

* Don't need to reopen the temp files

Add comment for objstore (#354)

* Add comment for objstore

* Modify comment

Add commitmgr and test case (#356)

* Add commitmgr and test case

* Redefine the interface

* Modify comment and interface

* Modify parameter and del unused method

* Add comment for FromData and ToData

Add blockmgr and test case (#357)

* Add blockmgr and test case

* Modify comment and interface

Add fsmgr and test case (#358)

* Add fsmgr and test case

* Add save interface and error details

* Modify errors and comments

Add searpc package and test case (#360)

* Add searpc package

* Add searpc test case

* Add return error and add Request struct

* Modify returned error

* Modify comments

add checkPerm (#369)

Add file and block download (#363)

* Add file and block download

* Modify init and use aes algorithm

* Get block by offset and add stat method

* Modify objID's type

* Fix reset pos after add start

* Add http error handing and record log when failed to read block or write block to response

* Modify http return code and value names

* Modify http return code and add log info

* Block read add comment and only repeat once

load ccnetdb and support sqlite (#371)

Add zip download (#372)

* Add zip download

* Modify pack dir and log info

* Modify http return code and use Deflate zip compression methods

add /repo/<repo-id>/permission-check (#375)

add /<repo-id>/commit/HEAD (#377)

add  /repo/<repo-id>/commit/<id> (#379)

add /repo/<repo-id>/block/<id> (#380)

add /repo/<repo-id>/fs-id-list (#383)

add /repo/head-commits-multi (#388)

Add file upload api (#378)

* Add file upload api

* Upload api implements post multi files and create relative path

* Modify handle error and save files directly

* Fix rebase conflict

* index block use channel and optimize mkdir with parents

* Handle jobs and results in a loop

* Mkdir with parents use postMultiFiles and use pointer of SeafDirent

* Del diff_simple size_sched virtual_repo

* Need to check the path with and without slash

* Modify merge trees and add merge test case

* Del postFile and don't close results channel

* Close the file and remove multipart temp file

* Modify merge test case and compare the first name of path

* Use pointer of Entries for SeafDir

* Add test cases for different situations

add /repo/<repo-id>/pack-fs (#389)

add POST /<repo-id>/check-fs and /<repo-id>/check-blocks (#396)

Merge compute repo (#397)

* Add update repo size and merge virtual repo

* Eliminate lint warnings

* Uncomment merge virtual repo and compute repo size

* Need init the dents

* Use interface{} param and modify removeElems

* Move update dir to file.go and modify logs

* Del sync pkg

add PUT /<repo-id>/commit/<commit-id> (#400)

add PUT /<repo-id>/block/<id> (#401)

add POST /<repo-id>/recv-fs (#398)

add PUT /<repo-id>/commit/HEAD (#402)

Add http return code (#403)

Add file update API (#399)

* Add file update API

* Add GetObjIDByPath and fix change size error

* Add traffic statistics for update api

add diffTrees unit test (#391)

add GET /accessible-repos (#406)

add GET /<repo-id>/block-map/<file-id> (#405)

Add test update repo size and merge virtual repo (#409)

* Update dir need update repo size

* Add test update repo size and merge virtual repo

* Add delay for test ajax

* Add delay before get repo size and modify comment

Use go fileserver for unit test (#410)

* Use go fileserver for unit test

* Blocking scheduling update repo size

* Add delay because of sqlite doesn't support concurrency

* Post use multipart form encode

* Del mysql database when test finished

* Fix merge virtual repo failed when use sqlite3

Add upload block API (#412)

fixed error

Add quota-check API (#426)

use diff package

* Use central conf for go fileserver (#428)

* Use central conf for go fileserver

* Fix log error

* use store id and remove share get repo owner (#430)

* Fix permission error (#432)

Co-authored-by: feiniks <36756310+feiniks@users.noreply.github.com>
Co-authored-by: Xiangyue Cai <caixiangyue007@gmail.com>
2021-01-04 11:41:53 +08:00

123 lines
3.0 KiB
Go

// Package searpc implements searpc client protocol with unix pipe transport.
package searpc
import (
"bufio"
"encoding/binary"
"encoding/json"
"fmt"
"io"
"net"
)
// Client represents a connections to the RPC server.
type Client struct {
// path of the named pipe
pipePath string
// RPC service name
Service string
}
type request struct {
Service string `json:"service"`
Request string `json:"request"`
}
// Init initializes rpc client.
func Init(pipePath string, service string) *Client {
client := new(Client)
client.pipePath = pipePath
client.Service = service
return client
}
// Call calls the RPC function funcname with variadic parameters.
// The return value of the RPC function is return as interface{} type
// The true returned type can be int32, int64, string, struct (object), list of struct (objects) or JSON
func (c *Client) Call(funcname string, params ...interface{}) (interface{}, error) {
// TODO: use reflection to compose requests and parse results.
var unixAddr *net.UnixAddr
unixAddr, err := net.ResolveUnixAddr("unix", c.pipePath)
if err != nil {
err := fmt.Errorf("failed to resolve unix addr when calling rpc : %v", err)
return nil, err
}
conn, err := net.DialUnix("unix", nil, unixAddr)
if err != nil {
err := fmt.Errorf("failed to dial unix when calling rpc : %v", err)
return nil, err
}
defer conn.Close()
var req []interface{}
req = append(req, funcname)
req = append(req, params...)
jsonstr, err := json.Marshal(req)
if err != nil {
err := fmt.Errorf("failed to encode rpc call to json : %v", err)
return nil, err
}
reqHeader := new(request)
reqHeader.Service = c.Service
reqHeader.Request = string(jsonstr)
jsonstr, err = json.Marshal(reqHeader)
if err != nil {
err := fmt.Errorf("failed to convert object to json : %v", err)
return nil, err
}
header := make([]byte, 4)
binary.LittleEndian.PutUint32(header, uint32(len(jsonstr)))
_, err = conn.Write([]byte(header))
if err != nil {
err := fmt.Errorf("Failed to write rpc request header : %v", err)
return nil, err
}
_, err = conn.Write([]byte(jsonstr))
if err != nil {
err := fmt.Errorf("Failed to write rpc request body : %v", err)
return nil, err
}
reader := bufio.NewReader(conn)
buflen := make([]byte, 4)
_, err = io.ReadFull(reader, buflen)
if err != nil {
err := fmt.Errorf("failed to read response header from rpc server : %v", err)
return nil, err
}
retlen := binary.LittleEndian.Uint32(buflen)
msg := make([]byte, retlen)
_, err = io.ReadFull(reader, msg)
if err != nil {
err := fmt.Errorf("failed to read response body from rpc server : %v", err)
return nil, err
}
retlist := make(map[string]interface{})
err = json.Unmarshal(msg, &retlist)
if err != nil {
err := fmt.Errorf("failed to decode rpc response : %v", err)
return nil, err
}
if _, ok := retlist["err_code"]; ok {
err := fmt.Errorf("searpc server returned error : %v", retlist["err_msg"])
return nil, err
}
if _, ok := retlist["ret"]; ok {
ret := retlist["ret"]
return ret, nil
}
err = fmt.Errorf("No value returned")
return nil, err
}