Compare commits
30 Commits
workgroup-
...
pkg/dev/ub
Author | SHA1 | Date | |
---|---|---|---|
81b2a38d27 | |||
213aa63033 | |||
eefaa6e6b9 | |||
655b4a6e11 | |||
286603e9aa | |||
d177e2dc3f | |||
c1d7e0daab | |||
42f7ba3473 | |||
0db3539627 | |||
057a5c1fd0 | |||
e32dd866a5 | |||
3a102bde60 | |||
1a0456ee84 | |||
b6b5512471 | |||
d02ae87a55 | |||
aed0048d95 | |||
98334bafa0 | |||
8681776283 | |||
c026b33954 | |||
ac7fec9e01 | |||
bbc8f65a47 | |||
9749ede28a | |||
bd133fa9d9 | |||
ab90365c9c | |||
ec6de8a217 | |||
17cd58d68f | |||
99fb4ac6d9 | |||
2ceba1f219 | |||
7122677351 | |||
1d526a37d0 |
@ -24,7 +24,7 @@ export function ProfilePage() {
|
|||||||
<div className="column is-6 is-offset-3">
|
<div className="column is-6 is-offset-3">
|
||||||
<div className="box">
|
<div className="box">
|
||||||
<h2 className="is-size-2 subtitle">Mon profil</h2>
|
<h2 className="is-size-2 subtitle">Mon profil</h2>
|
||||||
{ !isLoading ? <UserForm onChange={onUserChange} user={user} /> : null }
|
<UserForm onChange={onUserChange} user={user} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -14,7 +14,6 @@ export function InfoForm({ workgroup, onChange }: InfoFormProps) {
|
|||||||
workgroup: {
|
workgroup: {
|
||||||
id: workgroup && workgroup.id ? workgroup.id : '',
|
id: workgroup && workgroup.id ? workgroup.id : '',
|
||||||
name: workgroup && workgroup.name ? workgroup.name : '',
|
name: workgroup && workgroup.name ? workgroup.name : '',
|
||||||
description: workgroup && workgroup.description ? workgroup.description : '',
|
|
||||||
createdAt: workgroup && workgroup.createdAt ? workgroup.createdAt : null,
|
createdAt: workgroup && workgroup.createdAt ? workgroup.createdAt : null,
|
||||||
closedAt: workgroup && workgroup.closedAt ? workgroup.closedAt : null,
|
closedAt: workgroup && workgroup.closedAt ? workgroup.closedAt : null,
|
||||||
}
|
}
|
||||||
@ -35,7 +34,6 @@ export function InfoForm({ workgroup, onChange }: InfoFormProps) {
|
|||||||
workgroup: {
|
workgroup: {
|
||||||
id: workgroup && workgroup.id ? workgroup.id : '',
|
id: workgroup && workgroup.id ? workgroup.id : '',
|
||||||
name: workgroup && workgroup.name ? workgroup.name : '',
|
name: workgroup && workgroup.name ? workgroup.name : '',
|
||||||
description: workgroup && workgroup.description ? workgroup.description : '',
|
|
||||||
createdAt: workgroup && workgroup.createdAt ? workgroup.createdAt : null,
|
createdAt: workgroup && workgroup.createdAt ? workgroup.createdAt : null,
|
||||||
closedAt: workgroup && workgroup.closedAt ? workgroup.closedAt : null,
|
closedAt: workgroup && workgroup.closedAt ? workgroup.closedAt : null,
|
||||||
}
|
}
|
||||||
@ -78,14 +76,6 @@ export function InfoForm({ workgroup, onChange }: InfoFormProps) {
|
|||||||
onChange={onWorkgroupAttrChange.bind(null, "name")} />
|
onChange={onWorkgroupAttrChange.bind(null, "name")} />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="field">
|
|
||||||
<label className="label">Nom du groupe</label>
|
|
||||||
<div className="control">
|
|
||||||
<textarea className="input" value={state.workgroup.description}
|
|
||||||
disabled={!isAuthorized}
|
|
||||||
onChange={onWorkgroupAttrChange.bind(null, "description")}></textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{
|
{
|
||||||
state.workgroup.createdAt ?
|
state.workgroup.createdAt ?
|
||||||
<div className="field">
|
<div className="field">
|
||||||
|
@ -7,7 +7,6 @@ mutation updateWorkgroup($workgroupId: ID!, $changes: WorkgroupChanges!) {
|
|||||||
updateWorkgroup(workgroupId: $workgroupId, changes: $changes) {
|
updateWorkgroup(workgroupId: $workgroupId, changes: $changes) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
@ -27,7 +26,6 @@ mutation createWorkgroup($changes: WorkgroupChanges!) {
|
|||||||
createWorkgroup(changes: $changes) {
|
createWorkgroup(changes: $changes) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
@ -49,7 +47,6 @@ mutation joinWorkgroup($workgroupId: ID!) {
|
|||||||
joinWorkgroup(workgroupId: $workgroupId) {
|
joinWorkgroup(workgroupId: $workgroupId) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
@ -81,7 +78,6 @@ mutation leaveWorkgroup($workgroupId: ID!) {
|
|||||||
leaveWorkgroup(workgroupId: $workgroupId) {
|
leaveWorkgroup(workgroupId: $workgroupId) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
@ -121,7 +117,6 @@ mutation closeWorkgroup($workgroupId: ID!) {
|
|||||||
closeWorkgroup(workgroupId: $workgroupId) {
|
closeWorkgroup(workgroupId: $workgroupId) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
|
@ -7,7 +7,6 @@ export const QUERY_WORKGROUP = gql`
|
|||||||
workgroups(filter: $filter) {
|
workgroups(filter: $filter) {
|
||||||
id,
|
id,
|
||||||
name,
|
name,
|
||||||
description,
|
|
||||||
createdAt,
|
createdAt,
|
||||||
closedAt,
|
closedAt,
|
||||||
members {
|
members {
|
||||||
|
@ -2,7 +2,6 @@ import { User } from "./user";
|
|||||||
export interface Workgroup {
|
export interface Workgroup {
|
||||||
id: string
|
id: string
|
||||||
name: string
|
name: string
|
||||||
description: string
|
|
||||||
createdAt: Date
|
createdAt: Date
|
||||||
closedAt: Date
|
closedAt: Date
|
||||||
members: User[]
|
members: User[]
|
||||||
|
@ -79,9 +79,8 @@ func getServiceContainer(ctx context.Context, conf *config.Config) (*service.Con
|
|||||||
// Define default cookie options
|
// Define default cookie options
|
||||||
sessionStore.SessionOpts.Path = "/"
|
sessionStore.SessionOpts.Path = "/"
|
||||||
sessionStore.SessionOpts.HttpOnly = true
|
sessionStore.SessionOpts.HttpOnly = true
|
||||||
sessionStore.SessionOpts.Secure = conf.HTTP.CookieSecure
|
|
||||||
sessionStore.SessionOpts.MaxAge = conf.HTTP.CookieMaxAge
|
sessionStore.SessionOpts.MaxAge = conf.HTTP.CookieMaxAge
|
||||||
sessionStore.SessionOpts.SameSite = http.SameSiteLaxMode
|
sessionStore.SessionOpts.SameSite = http.SameSiteStrictMode
|
||||||
|
|
||||||
ctn.Provide(
|
ctn.Provide(
|
||||||
session.ServiceName,
|
session.ServiceName,
|
||||||
|
@ -27,8 +27,7 @@ func applyMigration(ctx context.Context, ctn *service.Container) error {
|
|||||||
|
|
||||||
// Register available migrations
|
// Register available migrations
|
||||||
migr.Register(
|
migr.Register(
|
||||||
m000InitialSchema(),
|
m000initialSchema(),
|
||||||
m001WorkgroupDescription(),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
currentVersion, err := migr.CurrentVersion(ctx)
|
currentVersion, err := migr.CurrentVersion(ctx)
|
||||||
@ -85,7 +84,7 @@ var initialModels = []interface{}{
|
|||||||
&model.Event{},
|
&model.Event{},
|
||||||
}
|
}
|
||||||
|
|
||||||
func m000InitialSchema() orm.Migration {
|
func m000initialSchema() orm.Migration {
|
||||||
return orm.NewDBMigration(
|
return orm.NewDBMigration(
|
||||||
"00_initial_schema",
|
"00_initial_schema",
|
||||||
func(ctx context.Context, tx *gorm.DB) error {
|
func(ctx context.Context, tx *gorm.DB) error {
|
||||||
@ -108,23 +107,3 @@ func m000InitialSchema() orm.Migration {
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
func m001WorkgroupDescription() orm.Migration {
|
|
||||||
return orm.NewDBMigration(
|
|
||||||
"01_workgroup_description",
|
|
||||||
func(ctx context.Context, tx *gorm.DB) error {
|
|
||||||
if err := tx.AutoMigrate(&model.Workgroup{}).Error; err != nil {
|
|
||||||
return errors.WithStack(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
func(ctx context.Context, tx *gorm.DB) error {
|
|
||||||
if err := tx.Model(&model.Workgroup{}).DropColumn("description").Error; err != nil {
|
|
||||||
return errors.WithStack(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
},
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
1
debian/compat
vendored
Normal file
1
debian/compat
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
9
|
14
debian/control
vendored
Normal file
14
debian/control
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
Source: daddy
|
||||||
|
Section: unknown
|
||||||
|
Priority: optional
|
||||||
|
Maintainer: Cadoles <contact@cadoles.com>
|
||||||
|
Build-Depends: debhelper (>= 8.0.0), wget, ca-certificates, tar
|
||||||
|
Standards-Version: 3.9.4
|
||||||
|
Homepage: http://forge.cadoles.com/Cadoles/daddy
|
||||||
|
Vcs-Git: http://forge.cadoles.com/Cadoles/daddy.git
|
||||||
|
Vcs-Browser: http://forge.cadoles.com/Cadoles/daddy
|
||||||
|
|
||||||
|
Package: daddy
|
||||||
|
Architecture: amd64
|
||||||
|
Depends: ${shlibs:Depends}, ${misc:Depends}
|
||||||
|
Description: Daddy app
|
1
debian/daddy.links
vendored
Normal file
1
debian/daddy.links
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
/etc/daddy/client-config.js /usr/share/daddy/public/config.js
|
11
debian/daddy.service
vendored
Normal file
11
debian/daddy.service
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=Daddy app
|
||||||
|
After=network-online.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
ExecStart=/usr/bin/daddy -workdir /usr/share/daddy -config /etc/daddy/config.yml
|
||||||
|
Restart=on-failure
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
56
debian/rules
vendored
Normal file
56
debian/rules
vendored
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
#!/usr/bin/make -f
|
||||||
|
# -*- makefile -*-
|
||||||
|
|
||||||
|
# Uncomment this to turn on verbose mode.
|
||||||
|
export DH_VERBOSE=1
|
||||||
|
|
||||||
|
GO_VERSION := 1.13.5
|
||||||
|
OS := linux
|
||||||
|
ARCH := amd64
|
||||||
|
GOPATH=$(HOME)/go
|
||||||
|
|
||||||
|
ifeq (, $(shell which go 2>/dev/null))
|
||||||
|
override_dh_auto_build: install-go
|
||||||
|
|
||||||
|
override_dh_auto_clean: install-go
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq (, $(shell which node 2>/dev/null))
|
||||||
|
override_dh_auto_build: install-nodejs
|
||||||
|
endif
|
||||||
|
|
||||||
|
%:
|
||||||
|
dh $@ --with systemd
|
||||||
|
|
||||||
|
override_dh_auto_build: $(GOPATH)
|
||||||
|
GOPATH=$(GOPATH) PATH="$(PATH):/usr/local/go/bin:$(GOPATH)/bin" make deps
|
||||||
|
GOPATH=$(GOPATH) PATH="$(PATH):/usr/local/go/bin:$(GOPATH)/bin" ARCH_TARGETS=$(ARCH) make release
|
||||||
|
|
||||||
|
$(GOPATH):
|
||||||
|
mkdir -p $(GOPATH)
|
||||||
|
|
||||||
|
install-go:
|
||||||
|
wget -nc https://dl.google.com/go/go$(GO_VERSION).$(OS)-$(ARCH).tar.gz
|
||||||
|
tar -C /usr/local -xzf go$(GO_VERSION).$(OS)-$(ARCH).tar.gz
|
||||||
|
|
||||||
|
install-nodejs:
|
||||||
|
wget -O- https://deb.nodesource.com/setup_12.x | bash -
|
||||||
|
apt-get install -y nodejs
|
||||||
|
|
||||||
|
override_dh_auto_install:
|
||||||
|
|
||||||
|
mkdir -p debian/daddy/usr/share/daddy
|
||||||
|
mkdir -p debian/daddy/etc/daddy
|
||||||
|
mkdir -p debian/daddy/usr/bin
|
||||||
|
|
||||||
|
cp -r release/server-$(OS)-$(ARCH)/* debian/daddy/usr/share/daddy/
|
||||||
|
|
||||||
|
mv debian/daddy/usr/share/daddy/bin/server debian/daddy/usr/bin/daddy
|
||||||
|
mv debian/daddy/usr/share/daddy/server.conf debian/daddy/etc/daddy/config.yml
|
||||||
|
mv debian/daddy/usr/share/daddy/public/config.js debian/daddy/etc/daddy/client-config.js
|
||||||
|
|
||||||
|
install -d debian/daddy
|
||||||
|
|
||||||
|
override_dh_strip:
|
||||||
|
|
||||||
|
override_dh_auto_test:
|
1
debian/source/format
vendored
Normal file
1
debian/source/format
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
3.0 (native)
|
2
go.mod
2
go.mod
@ -3,7 +3,7 @@ module forge.cadoles.com/Cadoles/daddy
|
|||||||
go 1.14
|
go 1.14
|
||||||
|
|
||||||
require (
|
require (
|
||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013125038-8d8d1519a52d
|
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013111944-d43b43b636ed
|
||||||
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc // indirect
|
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc // indirect
|
||||||
github.com/99designs/gqlgen v0.11.3
|
github.com/99designs/gqlgen v0.11.3
|
||||||
github.com/alecthomas/chroma v0.8.1 // indirect
|
github.com/alecthomas/chroma v0.8.1 // indirect
|
||||||
|
2
go.sum
2
go.sum
@ -41,8 +41,6 @@ forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013085949-5d5592098f13 h1:gZCo9p
|
|||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013085949-5d5592098f13/go.mod h1:phGAWHUGKNZj044478BvRg0jk049uK1IiX2Amh8krAk=
|
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013085949-5d5592098f13/go.mod h1:phGAWHUGKNZj044478BvRg0jk049uK1IiX2Amh8krAk=
|
||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013111944-d43b43b636ed h1:7dTCXOGxvAulu9vnOjpt2cTgsuxMHX4FH795/JJgo08=
|
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013111944-d43b43b636ed h1:7dTCXOGxvAulu9vnOjpt2cTgsuxMHX4FH795/JJgo08=
|
||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013111944-d43b43b636ed/go.mod h1:phGAWHUGKNZj044478BvRg0jk049uK1IiX2Amh8krAk=
|
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013111944-d43b43b636ed/go.mod h1:phGAWHUGKNZj044478BvRg0jk049uK1IiX2Amh8krAk=
|
||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013125038-8d8d1519a52d h1:o+Ppy/MyT5UgbtUYI2J1YqS3iuThxOuNFenYoPgKZKk=
|
|
||||||
forge.cadoles.com/wpetit/goweb-oidc v0.0.0-20201013125038-8d8d1519a52d/go.mod h1:phGAWHUGKNZj044478BvRg0jk049uK1IiX2Amh8krAk=
|
|
||||||
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc h1:9gc/1qizPtK6/iMVlizknWUFii75ntl2xSUV/FSC92Y=
|
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc h1:9gc/1qizPtK6/iMVlizknWUFii75ntl2xSUV/FSC92Y=
|
||||||
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc/go.mod h1:nANHORi270d5jDXjeJ7B3pMgK9R4J0/17p1IIc+rhOk=
|
forge.cadoles.com/wpetit/hydra-passwordless v0.0.0-20200908094025-38ac4422dddc/go.mod h1:nANHORi270d5jDXjeJ7B3pMgK9R4J0/17p1IIc+rhOk=
|
||||||
github.com/99designs/gqlgen v0.11.3 h1:oFSxl1DFS9X///uHV3y6CEfpcXWrDUxVblR4Xib2bs4=
|
github.com/99designs/gqlgen v0.11.3 h1:oFSxl1DFS9X///uHV3y6CEfpcXWrDUxVblR4Xib2bs4=
|
||||||
|
@ -47,7 +47,6 @@ type HTTPConfig struct {
|
|||||||
CookieAuthenticationKey string `yaml:"cookieAuthenticationKey" env:"HTTP_COOKIE_AUTHENTICATION_KEY"`
|
CookieAuthenticationKey string `yaml:"cookieAuthenticationKey" env:"HTTP_COOKIE_AUTHENTICATION_KEY"`
|
||||||
CookieEncryptionKey string `yaml:"cookieEncryptionKey" env:"HTTP_COOKIE_ENCRYPTION_KEY"`
|
CookieEncryptionKey string `yaml:"cookieEncryptionKey" env:"HTTP_COOKIE_ENCRYPTION_KEY"`
|
||||||
CookieMaxAge int `yaml:"cookieMaxAge" env:"HTTP_COOKIE_MAX_AGE"`
|
CookieMaxAge int `yaml:"cookieMaxAge" env:"HTTP_COOKIE_MAX_AGE"`
|
||||||
CookieSecure bool `yaml:"cookieSecure" env:"HTTP_COOKIE_SECURE"`
|
|
||||||
TemplateDir string `yaml:"templateDir" env:"HTTP_TEMPLATE_DIR"`
|
TemplateDir string `yaml:"templateDir" env:"HTTP_TEMPLATE_DIR"`
|
||||||
PublicDir string `yaml:"publicDir" env:"HTTP_PUBLIC_DIR"`
|
PublicDir string `yaml:"publicDir" env:"HTTP_PUBLIC_DIR"`
|
||||||
FrontendURL string `yaml:"frontendURL" env:"HTTP_FRONTEND_URL"`
|
FrontendURL string `yaml:"frontendURL" env:"HTTP_FRONTEND_URL"`
|
||||||
|
@ -11,7 +11,6 @@ const ObjectTypeWorkgroup = "workgroup"
|
|||||||
type Workgroup struct {
|
type Workgroup struct {
|
||||||
gorm.Model
|
gorm.Model
|
||||||
Name *string `json:"name"`
|
Name *string `json:"name"`
|
||||||
Workgroup *string `json:"workgroup"`
|
|
||||||
ClosedAt time.Time `json:"closedAt"`
|
ClosedAt time.Time `json:"closedAt"`
|
||||||
Members []*User `gorm:"many2many:users_workgroups;association_autoupdate:false"`
|
Members []*User `gorm:"many2many:users_workgroups;association_autoupdate:false"`
|
||||||
}
|
}
|
||||||
|
@ -68,8 +68,9 @@ func handleLoginCallback(w http.ResponseWriter, r *http.Request) {
|
|||||||
db := orm.Must(ctn).DB()
|
db := orm.Must(ctn).DB()
|
||||||
repo := model.NewUserRepository(db)
|
repo := model.NewUserRepository(db)
|
||||||
|
|
||||||
user := &model.User{
|
user, err := repo.CreateOrConnectUser(ctx, claims.Email)
|
||||||
Email: claims.Email,
|
if err != nil {
|
||||||
|
panic(errors.Wrap(err, "could not upsert user"))
|
||||||
}
|
}
|
||||||
|
|
||||||
authorized, err := auth.Authorize(user)
|
authorized, err := auth.Authorize(user)
|
||||||
@ -84,11 +85,6 @@ func handleLoginCallback(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
user, err = repo.CreateOrConnectUser(ctx, claims.Email)
|
|
||||||
if err != nil {
|
|
||||||
panic(errors.Wrap(err, "could not upsert user"))
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := session.SaveUserEmail(w, r, claims.Email); err != nil {
|
if err := session.SaveUserEmail(w, r, claims.Email); err != nil {
|
||||||
panic(errors.WithStack(err))
|
panic(errors.WithStack(err))
|
||||||
}
|
}
|
||||||
|
15
misc/debian/nginx/daddy.conf
Normal file
15
misc/debian/nginx/daddy.conf
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
server_name daddy.local;
|
||||||
|
|
||||||
|
root /usr/share/daddy/client/public;
|
||||||
|
index index.html;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
try_files $uri /index.html =404;
|
||||||
|
}
|
||||||
|
|
||||||
|
location /api/v1/graphql {
|
||||||
|
proxy_pass http://127.0.0.1:8080/api/v1/graphql;
|
||||||
|
}
|
||||||
|
}
|
1
misc/debian/systemd/daddy.env
Normal file
1
misc/debian/systemd/daddy.env
Normal file
@ -0,0 +1 @@
|
|||||||
|
GO_ENV=prod
|
Reference in New Issue
Block a user