Initial commit
This commit is contained in:
commit
651c6c1404
|
@ -0,0 +1,8 @@
|
|||
#!/bin/bash
|
||||
|
||||
result="$(gofmt -s -l . | grep -v '^vendor/' )"
|
||||
if [ -n "$result" ]; then
|
||||
echo "Go code is not formatted, run 'gofmt -s -w .'" >&2
|
||||
echo "$result"
|
||||
exit 1
|
||||
fi
|
|
@ -0,0 +1,25 @@
|
|||
#!/usr/bin/env python
|
||||
# checks if every desired package has test files
|
||||
|
||||
import os
|
||||
import re
|
||||
import sys
|
||||
|
||||
source_re = re.compile(".*\.go")
|
||||
test_re = re.compile(".*_test\.go")
|
||||
missing = False
|
||||
|
||||
for root, dirs, files in os.walk("."):
|
||||
# ignore some paths
|
||||
if root == "." or root.startswith("./vendor") or root.startswith("./."):
|
||||
continue
|
||||
|
||||
# source files but not test files?
|
||||
if len(filter(source_re.match, files)) > 0 and len(filter(test_re.match, files)) == 0:
|
||||
print("no test files for {}".format(root))
|
||||
missing = True
|
||||
|
||||
if missing:
|
||||
sys.exit(1)
|
||||
else:
|
||||
print("every package has test files")
|
|
@ -0,0 +1,2 @@
|
|||
thrempp.db
|
||||
config.toml
|
|
@ -0,0 +1,33 @@
|
|||
image: golang:latest
|
||||
stages:
|
||||
- build
|
||||
- test
|
||||
|
||||
before_script:
|
||||
- mkdir -p /go/src/dev.sum7.eu/$CI_PROJECT_NAMESPACE/
|
||||
- cp -R $CI_PROJECT_DIR /go/src/dev.sum7.eu/$CI_PROJECT_NAMESPACE
|
||||
- cd /go/src/dev.sum7.eu/$CI_PROJECT_PATH
|
||||
- go get -v dev.sum7.eu/$CI_PROJECT_PATH
|
||||
|
||||
build-my-project:
|
||||
stage: build
|
||||
script:
|
||||
- mkdir $CI_PROJECT_DIR/bin/
|
||||
- cp /go/bin/$CI_PROJECT_NAME $CI_PROJECT_DIR/bin/$CI_PROJECT_NAME
|
||||
artifacts:
|
||||
paths:
|
||||
- bin/thrempp
|
||||
- config_example.toml
|
||||
|
||||
test-my-project:
|
||||
stage: test
|
||||
script:
|
||||
- ./.ci/check-gofmt
|
||||
- ./.ci/check-testfiles
|
||||
- go test $(go list ./... | grep -v /vendor/) -v -coverprofile .testCoverage.txt
|
||||
- go tool cover -func=.testCoverage.txt
|
||||
|
||||
test-race-my-project:
|
||||
stage: test
|
||||
script:
|
||||
- go test -race ./...
|
|
@ -0,0 +1,50 @@
|
|||
# Thrempp [![pipeline status](https://dev.sum7.eu/genofire/thrempp/badges/master/pipeline.svg)](https://dev.sum7.eu/genofire/thrempp/pipelines) [![coverage report](https://dev.sum7.eu/genofire/thrempp/badges/master/coverage.svg)](https://dev.sum7.eu/genofire/thrempp/pipelines)
|
||||
XMPP - Transport
|
||||
|
||||
ATM planned support for Threema only
|
||||
|
||||
## Get thrempp
|
||||
|
||||
#### Download
|
||||
|
||||
Latest Build binary from ci here:
|
||||
|
||||
[Download All](https://dev.sum7.eu/genofire/thrempp/-/jobs/artifacts/master/download/?job=build-my-project) (with config example)
|
||||
|
||||
[Download Binary](https://dev.sum7.eu/genofire/thrempp/-/jobs/artifacts/master/raw/bin/thrempp?inline=false&job=build-my-project)
|
||||
|
||||
#### Build
|
||||
|
||||
```bash
|
||||
go get -u dev.sum7.eu/genofire/thrempp
|
||||
```
|
||||
|
||||
## Configure
|
||||
|
||||
see `config_example.conf`
|
||||
|
||||
## Start / Boot
|
||||
|
||||
_/lib/systemd/system/thrempp.service_ :
|
||||
```
|
||||
[Unit]
|
||||
Description=thrempp
|
||||
After=network.target
|
||||
# After=ejabberd.service
|
||||
# After=prosody.service
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
# User=notRoot
|
||||
ExecStart=/opt/go/bin/thrempp serve --config /etc/thrempp.conf
|
||||
Restart=always
|
||||
RestartSec=5sec
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
```
|
||||
|
||||
Start: `systemctl start thrempp`
|
||||
Autostart: `systemctl enable thrempp`
|
||||
|
||||
|
|
@ -0,0 +1,26 @@
|
|||
package cmd
|
||||
|
||||
import (
|
||||
"os"
|
||||
|
||||
"github.com/bdlm/log"
|
||||
"github.com/spf13/cobra"
|
||||
)
|
||||
|
||||
var (
|
||||
timestamps bool
|
||||
)
|
||||
|
||||
// RootCmd represents the base command when called without any subcommands
|
||||
var RootCmd = &cobra.Command{
|
||||
Use: "thrempp",
|
||||
}
|
||||
|
||||
// Execute adds all child commands to the root command and sets flags appropriately.
|
||||
// This is called by main.main(). It only needs to happen once to the rootCmd.
|
||||
func Execute() {
|
||||
if err := RootCmd.Execute(); err != nil {
|
||||
log.Fatal(err)
|
||||
os.Exit(1)
|
||||
}
|
||||
}
|
|
@ -0,0 +1 @@
|
|||
package cmd
|
|
@ -0,0 +1,107 @@
|
|||
package cmd
|
||||
|
||||
import (
|
||||
"os"
|
||||
"os/signal"
|
||||
"syscall"
|
||||
|
||||
"github.com/bdlm/log"
|
||||
"github.com/bdlm/std/logger"
|
||||
"github.com/spf13/cobra"
|
||||
|
||||
"dev.sum7.eu/genofire/golang-lib/database"
|
||||
"dev.sum7.eu/genofire/golang-lib/file"
|
||||
|
||||
"dev.sum7.eu/genofire/thrempp/component"
|
||||
// need for database init
|
||||
_ "dev.sum7.eu/genofire/thrempp/component/all"
|
||||
_ "dev.sum7.eu/genofire/thrempp/models"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
LogLevel logger.Level `toml:"log_level"`
|
||||
Database database.Config `toml:"database"`
|
||||
Components []component.Config `toml:"component"`
|
||||
}
|
||||
|
||||
var configPath string
|
||||
|
||||
// serveCmd represents the serve command
|
||||
var serveCmd = &cobra.Command{
|
||||
Use: "serve",
|
||||
Short: "Run xmpp transport",
|
||||
Example: "yanic serve --config /etc/thrempp.toml",
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
config := &Config{}
|
||||
if err := file.ReadTOML(configPath, config); err != nil {
|
||||
log.Panicf("open config file: %s", err)
|
||||
}
|
||||
|
||||
log.SetLevel(config.LogLevel)
|
||||
|
||||
if err := database.Open(config.Database); err != nil {
|
||||
log.Panicf("no database connection: %s", err)
|
||||
}
|
||||
defer database.Close()
|
||||
component.Load(config.Components)
|
||||
|
||||
// Wait for INT/TERM
|
||||
sigs := make(chan os.Signal, 1)
|
||||
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
|
||||
sig := <-sigs
|
||||
log.Infof("received %s", sig)
|
||||
|
||||
/*
|
||||
server := o3.ThreemaRest{}
|
||||
|
||||
var thrAccount models.AccountThreema
|
||||
if err := database.Read.First(&thrAccount).Error; err != nil {
|
||||
id, _ := server.CreateIdentity()
|
||||
thrAccount.TID = make([]byte, len(id.ID))
|
||||
thrAccount.LSK = make([]byte, len(id.LSK))
|
||||
copy(thrAccount.TID, id.ID[:])
|
||||
copy(thrAccount.LSK, id.LSK[:])
|
||||
database.Write.Create(&thrAccount)
|
||||
}
|
||||
|
||||
log.Warnf("%s", thrAccount.TID)
|
||||
var lsk [32]byte
|
||||
copy(lsk[:], thrAccount.LSK[:])
|
||||
tid, err := o3.NewThreemaID(string(thrAccount.TID), lsk, o3.AddressBook{})
|
||||
tid.Nick = o3.NewPubNick("xmpp:geno@fireorbit.de")
|
||||
|
||||
ctx := o3.NewSessionContext(tid)
|
||||
|
||||
// let the session begin
|
||||
log.Info("Starting session")
|
||||
sendMsgChan, receiveMsgChan, err := ctx.Run()
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
// handle incoming messages
|
||||
for receivedMessage := range receiveMsgChan {
|
||||
if receivedMessage.Err != nil {
|
||||
log.Errorf("Error Receiving Message: %s\n", receivedMessage.Err)
|
||||
continue
|
||||
}
|
||||
switch msg := receivedMessage.Msg.(type) {
|
||||
case o3.TextMessage:
|
||||
if tid.String() == msg.Sender().String() {
|
||||
continue
|
||||
}
|
||||
qoute := fmt.Sprintf("> %s: %s\n%s", msg.Sender(), msg.Text(), "Exactly!")
|
||||
err = ctx.SendTextMessage(msg.Sender().String(), qoute, sendMsgChan)
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
*/
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
RootCmd.AddCommand(serveCmd)
|
||||
serveCmd.Flags().StringVarP(&configPath, "config", "c", "config.toml", "Path to configuration file")
|
||||
}
|
|
@ -0,0 +1,6 @@
|
|||
package all
|
||||
|
||||
import (
|
||||
// import all implementations
|
||||
_ "dev.sum7.eu/genofire/thrempp/component/threema"
|
||||
)
|
|
@ -0,0 +1 @@
|
|||
package all
|
|
@ -0,0 +1,36 @@
|
|||
package component
|
||||
|
||||
import (
|
||||
"github.com/bdlm/log"
|
||||
"gosrc.io/xmpp"
|
||||
)
|
||||
|
||||
type Component interface {
|
||||
Connect() (chan xmpp.Packet, error)
|
||||
Send(xmpp.Packet)
|
||||
}
|
||||
|
||||
// Connect function with config to get DB connection interface
|
||||
type Connect func(config map[string]interface{}) (Component, error)
|
||||
|
||||
var components = map[string]Connect{}
|
||||
|
||||
func AddComponent(name string, c Connect) {
|
||||
components[name] = c
|
||||
}
|
||||
|
||||
func Load(configs []Config) {
|
||||
for _, config := range configs {
|
||||
f, ok := components[config.Type]
|
||||
if !ok {
|
||||
log.Warnf("it was not possible to find a component with type '%s'", config.Type)
|
||||
continue
|
||||
}
|
||||
comp, err := f(config.Special)
|
||||
if err != nil {
|
||||
log.WithField("type", config.Type).Panic(err)
|
||||
}
|
||||
config.comp = comp
|
||||
log.WithField("type", config.Type).Infof("component for %s started", config.Host)
|
||||
}
|
||||
}
|
|
@ -0,0 +1 @@
|
|||
package component
|
|
@ -0,0 +1,15 @@
|
|||
package threema
|
||||
|
||||
import "dev.sum7.eu/genofire/thrempp/component"
|
||||
|
||||
type Threema struct {
|
||||
component.Component
|
||||
}
|
||||
|
||||
func NewThreema(config map[string]interface{}) (component.Component, error) {
|
||||
return &Threema{}, nil
|
||||
}
|
||||
|
||||
func init() {
|
||||
component.AddComponent("threema", NewThreema)
|
||||
}
|
|
@ -0,0 +1 @@
|
|||
package threema
|
|
@ -0,0 +1,38 @@
|
|||
package component
|
||||
|
||||
import (
|
||||
"gosrc.io/xmpp"
|
||||
)
|
||||
|
||||
type Config struct {
|
||||
Type string
|
||||
Host string
|
||||
Connection string
|
||||
Secret string
|
||||
Special map[string]interface{}
|
||||
|
||||
xmpp *xmpp.Component
|
||||
comp Component
|
||||
}
|
||||
|
||||
func (c *Config) Start() error {
|
||||
c.xmpp = &xmpp.Component{Host: c.Host, Secret: c.Secret}
|
||||
err := c.xmpp.Connect(c.Connection)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
out, err := c.comp.Connect()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
go c.recieve(out)
|
||||
go c.sender()
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *Config) recieve(chan xmpp.Packet) {
|
||||
}
|
||||
func (c *Config) sender() {
|
||||
}
|
|
@ -0,0 +1,15 @@
|
|||
log_level = 50
|
||||
|
||||
[[component]]
|
||||
type = "threema"
|
||||
host = "threema.chat.sum7.eu"
|
||||
connection = "localhost:5347"
|
||||
secret = "change_me"
|
||||
|
||||
[database]
|
||||
type = "sqlite3"
|
||||
logging = false
|
||||
connection = "./thrempp.db"
|
||||
# For Master-Slave cluster
|
||||
# read_connection = ""
|
||||
|
|
@ -0,0 +1,7 @@
|
|||
package main
|
||||
|
||||
import "dev.sum7.eu/genofire/thrempp/cmd"
|
||||
|
||||
func main() {
|
||||
cmd.Execute()
|
||||
}
|
|
@ -0,0 +1,19 @@
|
|||
package models
|
||||
|
||||
import (
|
||||
"github.com/jinzhu/gorm"
|
||||
|
||||
"dev.sum7.eu/genofire/golang-lib/database"
|
||||
)
|
||||
|
||||
type AccountThreema struct {
|
||||
gorm.Model
|
||||
XMPPID uint
|
||||
XMPP JID
|
||||
TID []byte
|
||||
LSK []byte
|
||||
}
|
||||
|
||||
func init() {
|
||||
database.AddModel(&AccountThreema{})
|
||||
}
|
|
@ -0,0 +1,21 @@
|
|||
package models
|
||||
|
||||
import (
|
||||
"github.com/jinzhu/gorm"
|
||||
|
||||
"dev.sum7.eu/genofire/golang-lib/database"
|
||||
)
|
||||
|
||||
type JID struct {
|
||||
gorm.Model
|
||||
Local string
|
||||
Domain string
|
||||
}
|
||||
|
||||
func (j *JID) TableName() string {
|
||||
return "jid"
|
||||
}
|
||||
|
||||
func init() {
|
||||
database.AddModel(&JID{})
|
||||
}
|
|
@ -0,0 +1 @@
|
|||
package models
|
Reference in New Issue