mirror of
https://github.com/documize/community.git
synced 2025-07-19 21:29:42 +02:00
72 lines
2.1 KiB
Go
72 lines
2.1 KiB
Go
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
|
|
//
|
|
// This software (Documize Community Edition) is licensed under
|
|
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
|
|
//
|
|
// You can operate outside the AGPL restrictions by purchasing
|
|
// Documize Enterprise Edition and obtaining a commercial license
|
|
// by contacting <sales@documize.com>.
|
|
//
|
|
// https://documize.com
|
|
|
|
package apidocumizecom
|
|
|
|
import (
|
|
"bytes"
|
|
"crypto/tls"
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
"path/filepath"
|
|
|
|
api "github.com/documize/community/core/convapi"
|
|
"golang.org/x/net/context"
|
|
)
|
|
|
|
// Msword type provides a peg to hang the Convert method on.
|
|
type Msword struct{}
|
|
|
|
// Convert converts a file into the Documize format.
|
|
func (file *Msword) Convert(r api.DocumentConversionRequest, reply *api.DocumentConversionResponse) error {
|
|
byts, err := json.Marshal(r)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
base := filepath.Base(r.Filename)
|
|
fmt.Println("Starting conversion of document: ", base)
|
|
|
|
var transport = &http.Transport{
|
|
TLSClientConfig: &tls.Config{
|
|
InsecureSkipVerify: true, // TODO should be glick.InsecureSkipVerifyTLS (from -insecure flag) but get error: x509: certificate signed by unknown authority
|
|
}}
|
|
|
|
client := &http.Client{Transport: transport}
|
|
|
|
resp, err := client.Post(r.ServiceEndpoint+"/api/word", "application/json", bytes.NewReader(byts))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer func() {
|
|
if e := resp.Body.Close(); e != nil {
|
|
fmt.Println("resp.Body.Close error: " + e.Error())
|
|
}
|
|
}()
|
|
|
|
fmt.Println("Finished converting document: ", base)
|
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
err = dec.Decode(reply)
|
|
|
|
return err
|
|
}
|
|
|
|
// MSwordConvert provides the standard interface for conversion of a MS-Word document.
|
|
// All the function does is return a pointer to api.DocumentConversionResponse with
|
|
// PagesHTML set to the given (*api.DocumentConversionRequest).Filedata converted by the Documize server.
|
|
func MSwordConvert(ctx context.Context, in interface{}) (interface{}, error) {
|
|
var msw Msword
|
|
dcr := in.(*api.DocumentConversionRequest)
|
|
rep := new(api.DocumentConversionResponse)
|
|
err := msw.Convert(*dcr, rep)
|
|
return rep, err
|
|
}
|