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

125 lines
2.5 KiB

package main
import (
"encoding/json"
"fmt"
"net/http"
"github.com/fatih/color"
"github.com/gorilla/mux"
)
//TODO use rsa library instead own rsa functions
func Index(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "clientApp")
}
func GetServer(w http.ResponseWriter, r *http.Request) {
color.Green(config.Server)
fmt.Fprintln(w, config.Server)
}
func GetIDs(w http.ResponseWriter, r *http.Request) {
keys := IDs()
jResp, err := json.Marshal(keys)
check(err)
fmt.Fprintln(w, string(jResp))
}
func GetID(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
keyID := vars["keyid"]
key := getKeyByKeyID(keyID)
jResp, err := json.Marshal(key)
check(err)
fmt.Fprintln(w, string(jResp))
}
func GetNewID(w http.ResponseWriter, r *http.Request) {
key := NewID()
fmt.Println(key)
jResp, err := json.Marshal(key)
check(err)
fmt.Fprintln(w, string(jResp))
}
func GetBlindAndSendToSign(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
idKey := vars["keyid"]
color.Green(idKey)
keys := BlindAndSendToSign(idKey)
jResp, err := json.Marshal(keys)
check(err)
fmt.Fprintln(w, string(jResp))
}
func GetVerify(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
packPubK := vars["pubK"]
color.Green(packPubK)
//keys := Verify(packPubK)
keys := "a"
jResp, err := json.Marshal(keys)
check(err)
fmt.Fprintln(w, string(jResp))
}
func GetDelete(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
keyID := vars["keyid"]
keys := Delete(keyID)
jResp, err := json.Marshal(keys)
check(err)
fmt.Fprintln(w, string(jResp))
}
type EncryptData struct {
M string `json:"m"`
C []byte `json:"c"`
}
func PostEncrypt(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
keyID := vars["keyid"]
//get ciphertext from POST json
decoder := json.NewDecoder(r.Body)
var encryptData EncryptData
err := decoder.Decode(&encryptData)
if err != nil {
panic(err)
}
defer r.Body.Close()
encryptData = Encrypt(keyID, encryptData)
jResp, err := json.Marshal(encryptData)
check(err)
fmt.Fprintln(w, string(jResp))
}
func PostDecrypt(w http.ResponseWriter, r *http.Request) {
vars := mux.Vars(r)
keyID := vars["keyid"]
//get ciphertext from POST json
decoder := json.NewDecoder(r.Body)
var encryptData EncryptData
err := decoder.Decode(&encryptData)
if err != nil {
panic(err)
}
defer r.Body.Close()
encryptData = Decrypt(keyID, encryptData)
jResp, err := json.Marshal(encryptData)
check(err)
fmt.Fprintln(w, string(jResp))
}