✨ Generate service dynamically
This commit is contained in:
parent
0fe6f5070e
commit
931f75500f
3 changed files with 26 additions and 24 deletions
15
app.go
15
app.go
|
|
@ -3,6 +3,7 @@ package lenore
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
"codeberg.org/danjones000/lenore/config"
|
"codeberg.org/danjones000/lenore/config"
|
||||||
"codeberg.org/danjones000/lenore/store"
|
"codeberg.org/danjones000/lenore/store"
|
||||||
|
|
@ -11,6 +12,10 @@ import (
|
||||||
boxap "github.com/go-ap/fedbox/activitypub"
|
boxap "github.com/go-ap/fedbox/activitypub"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
client.UserAgent = config.UserAgent
|
||||||
|
}
|
||||||
|
|
||||||
type App struct {
|
type App struct {
|
||||||
conf config.Config
|
conf config.Config
|
||||||
self vocab.Service
|
self vocab.Service
|
||||||
|
|
@ -30,10 +35,12 @@ func NewApp(ver string, conf config.Config, db store.Store) (*App, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
selfIRI := boxap.DefaultServiceIRI(conf.BaseURL)
|
selfIRI := boxap.DefaultServiceIRI(conf.BaseURL)
|
||||||
self, err := boxap.LoadActor(db, selfIRI)
|
self := boxap.Self(selfIRI)
|
||||||
if err != nil {
|
self.Name = vocab.DefaultNaturalLanguageValue(app.Name())
|
||||||
return nil, err
|
self.AttributedTo = vocab.IRI(config.DevUrl)
|
||||||
}
|
self.Summary = vocab.DefaultNaturalLanguageValue("ActivityPub-powered reader")
|
||||||
|
self.Published = time.Now()
|
||||||
|
self.Updated = time.Now()
|
||||||
|
|
||||||
app.self = self
|
app.self = self
|
||||||
app.client = *client.New()
|
app.client = *client.New()
|
||||||
|
|
|
||||||
|
|
@ -4,44 +4,29 @@ package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
|
||||||
|
|
||||||
"codeberg.org/danjones000/lenore"
|
"codeberg.org/danjones000/lenore"
|
||||||
"codeberg.org/danjones000/lenore/config"
|
"codeberg.org/danjones000/lenore/config"
|
||||||
vocab "github.com/go-ap/activitypub"
|
|
||||||
boxap "github.com/go-ap/fedbox/activitypub"
|
|
||||||
"github.com/go-ap/storage-sqlite"
|
"github.com/go-ap/storage-sqlite"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
conf := config.Config{BaseURL: "http://localhost:4523/"}
|
conf := config.Config{BaseURL: "http://localhost:4523/"}
|
||||||
|
|
||||||
sqlConf := sqlite.Config{Path: "storage"}
|
sqlConf := sqlite.Config{Path: "storage"}
|
||||||
err := sqlite.Bootstrap(sqlConf)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
db, err := sqlite.New(sqlConf)
|
db, err := sqlite.New(sqlConf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
serv := vocab.ServiceNew(boxap.DefaultServiceIRI(conf.BaseURL))
|
app, err := lenore.NewApp(config.Version, conf, db)
|
||||||
serv.Name = vocab.DefaultNaturalLanguageValue("Lenore")
|
|
||||||
serv.Summary = vocab.DefaultNaturalLanguageValue("ActivityPub-powered reader")
|
|
||||||
serv.Published = time.Now()
|
|
||||||
serv.Updated = time.Now()
|
|
||||||
_, err = db.Save(serv)
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
app, err := lenore.NewApp("0.0.0", conf, db)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println(app)
|
fmt.Println(app)
|
||||||
fmt.Println(app.Service().ID)
|
serv := app.Service()
|
||||||
|
out, _ := serv.MarshalJSON()
|
||||||
|
fmt.Println(string(out))
|
||||||
|
fmt.Println(serv.ID)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
10
config/version.go
Normal file
10
config/version.go
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
package config
|
||||||
|
|
||||||
|
const (
|
||||||
|
AppName string = "lenore"
|
||||||
|
Version string = "0.0.1"
|
||||||
|
Url string = "https://codeberg.org/danjones000/lenore"
|
||||||
|
DevUrl string = "https://codeberg.org/danjones000"
|
||||||
|
Email string = "danjones@goodevilgenius.org"
|
||||||
|
UserAgent string = AppName + "/" + Version + " (" + Url + "; " + Email + ")"
|
||||||
|
)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue