Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
haskell-gargantext
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Grégoire Locqueville
haskell-gargantext
Commits
4b6991a3
Commit
4b6991a3
authored
Jun 24, 2024
by
Alfredo Di Napoli
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Hook CORS and middleware
parent
bb91161a
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
43 additions
and
26 deletions
+43
-26
gargantext-settings.toml
gargantext-settings.toml
+0
-1
API.hs
src/Gargantext/API.hs
+1
-1
MicroServices.hs
src/Gargantext/API/Admin/Settings/MicroServices.hs
+11
-1
TOML.hs
src/Gargantext/API/Admin/Settings/TOML.hs
+17
-2
Node.hs
src/Gargantext/Database/Action/Node.hs
+4
-4
ReverseProxy.hs
src/Gargantext/MicroServices/ReverseProxy.hs
+10
-17
No files found.
gargantext-settings.toml
View file @
4b6991a3
...
@@ -15,7 +15,6 @@ allowed-origins = [
...
@@ -15,7 +15,6 @@ allowed-origins = [
,
"https://msh.sub.gargantext.org"
,
"https://msh.sub.gargantext.org"
,
"https://dev.sub.gargantext.org"
,
"https://dev.sub.gargantext.org"
,
"http://localhost:8008"
,
"http://localhost:8008"
,
"http://localhost:8009"
]
]
use-origins-for-hosts
=
true
use-origins-for-hosts
=
true
...
...
src/Gargantext/API.hs
View file @
4b6991a3
...
@@ -79,7 +79,7 @@ startGargantext mode port file = withLoggerHoisted mode $ \logger -> do
...
@@ -79,7 +79,7 @@ startGargantext mode port file = withLoggerHoisted mode $ \logger -> do
periodicActions
<-
schedulePeriodicActions
env
periodicActions
<-
schedulePeriodicActions
env
let
runServer
=
run
port
(
mid
app
)
`
finally
`
stopGargantext
periodicActions
let
runServer
=
run
port
(
mid
app
)
`
finally
`
stopGargantext
periodicActions
let
runProxy
=
run
proxyPort
(
mi
croServicesProxyApp
env
)
let
runProxy
=
run
proxyPort
(
mi
d
(
microServicesProxyApp
env
)
)
Async
.
race_
runServer
runProxy
Async
.
race_
runServer
runProxy
...
...
src/Gargantext/API/Admin/Settings/MicroServices.hs
View file @
4b6991a3
...
@@ -4,8 +4,11 @@ module Gargantext.API.Admin.Settings.MicroServices where
...
@@ -4,8 +4,11 @@ module Gargantext.API.Admin.Settings.MicroServices where
import
Prelude
import
Prelude
import
Toml
import
Control.Lens.TH
import
Control.Lens.TH
import
Data.Text
qualified
as
T
import
Gargantext.Prelude.Config
import
Servant.Client.Core.BaseUrl
import
Toml
data
MicroServicesSettings
=
data
MicroServicesSettings
=
MicroServicesSettings
{
MicroServicesSettings
{
...
@@ -17,4 +20,11 @@ microServicesSettingsCodec :: TomlCodec MicroServicesSettings
...
@@ -17,4 +20,11 @@ microServicesSettingsCodec :: TomlCodec MicroServicesSettings
microServicesSettingsCodec
=
MicroServicesSettings
microServicesSettingsCodec
=
MicroServicesSettings
<$>
Toml
.
int
"proxy-port"
.=
_msProxyPort
<$>
Toml
.
int
"proxy-port"
.=
_msProxyPort
mkProxyUrl
::
GargConfig
->
MicroServicesSettings
->
BaseUrl
mkProxyUrl
GargConfig
{
..
}
MicroServicesSettings
{
..
}
=
case
parseBaseUrl
(
T
.
unpack
_gc_url
)
of
Nothing
->
BaseUrl
Http
"localhost"
80
""
Just
bh
->
bh
{
baseUrlPort
=
_msProxyPort
}
makeLenses
''
M
icroServicesSettings
makeLenses
''
M
icroServicesSettings
src/Gargantext/API/Admin/Settings/TOML.hs
View file @
4b6991a3
...
@@ -10,6 +10,7 @@ import Gargantext.System.Logging
...
@@ -10,6 +10,7 @@ import Gargantext.System.Logging
import
Paths_gargantext
import
Paths_gargantext
import
Prelude
import
Prelude
import
Toml
import
Toml
import
Servant.Client.Core.BaseUrl
-- | Compatibility bridge until we fix #304 (move to Toml)
-- | Compatibility bridge until we fix #304 (move to Toml)
data
GargTomlSettings
=
GargTomlSettings
data
GargTomlSettings
=
GargTomlSettings
...
@@ -24,6 +25,20 @@ settingsCodec = GargTomlSettings
...
@@ -24,6 +25,20 @@ settingsCodec = GargTomlSettings
<$>
(
Toml
.
table
corsSettingsCodec
"cors"
.=
_gargCorsSettings
)
<$>
(
Toml
.
table
corsSettingsCodec
"cors"
.=
_gargCorsSettings
)
<*>
(
Toml
.
table
microServicesSettingsCodec
"microservices"
.=
_gargMicroServicesSettings
)
<*>
(
Toml
.
table
microServicesSettingsCodec
"microservices"
.=
_gargMicroServicesSettings
)
-- | Extends the 'allowed-origins' in the CORSettings with the URLs embellished
-- with the proxy port.
addProxyToAllowedOrigins
::
GargTomlSettings
->
GargTomlSettings
addProxyToAllowedOrigins
stgs
=
stgs
&
over
gargCorsSettings
(
addProxies
$
stgs
^.
gargMicroServicesSettings
.
msProxyPort
)
where
addProxies
::
Int
->
CORSSettings
->
CORSSettings
addProxies
port
cors
=
let
origins
=
_corsAllowedOrigins
cors
mkUrl
(
CORSOrigin
u
)
=
case
parseBaseUrl
(
T
.
unpack
u
)
of
Nothing
->
CORSOrigin
u
Just
bh
->
CORSOrigin
$
T
.
pack
$
showBaseUrl
$
bh
{
baseUrlPort
=
port
}
in
cors
{
_corsAllowedOrigins
=
origins
<>
Prelude
.
map
mkUrl
origins
}
-- | Loads the 'CORSSettings' from the 'toml' file.
-- | Loads the 'CORSSettings' from the 'toml' file.
loadGargTomlSettings
::
IO
GargTomlSettings
loadGargTomlSettings
::
IO
GargTomlSettings
loadGargTomlSettings
=
do
loadGargTomlSettings
=
do
...
@@ -35,5 +50,5 @@ loadGargTomlSettings = do
...
@@ -35,5 +50,5 @@ loadGargTomlSettings = do
logMsg
ioLogger
ERROR
$
T
.
unpack
$
"Error, gargantext-settings.toml parsing failed: "
<>
Toml
.
prettyTomlDecodeErrors
errs
logMsg
ioLogger
ERROR
$
T
.
unpack
$
"Error, gargantext-settings.toml parsing failed: "
<>
Toml
.
prettyTomlDecodeErrors
errs
panicTrace
"Please fix the errors in your gargantext-settings.toml file."
panicTrace
"Please fix the errors in your gargantext-settings.toml file."
Right
settings0
->
case
settings0
^.
gargCorsSettings
.
corsUseOriginsForHosts
of
Right
settings0
->
case
settings0
^.
gargCorsSettings
.
corsUseOriginsForHosts
of
True
->
pure
$
settings0
&
over
(
gargCorsSettings
.
corsAllowedHosts
)
(
\
_
->
"http://localhost:3000"
:
(
settings0
^.
gargCorsSettings
.
corsAllowedOrigins
))
True
->
pure
$
addProxyToAllowedOrigins
$
settings0
&
over
(
gargCorsSettings
.
corsAllowedHosts
)
(
\
_
->
"http://localhost:3000"
:
(
settings0
^.
gargCorsSettings
.
corsAllowedOrigins
))
False
->
pure
$
settings0
&
over
(
gargCorsSettings
.
corsAllowedHosts
)
(
"http://localhost:3000"
:
)
False
->
pure
$
addProxyToAllowedOrigins
$
settings0
&
over
(
gargCorsSettings
.
corsAllowedHosts
)
(
"http://localhost:3000"
:
)
src/Gargantext/Database/Action/Node.hs
View file @
4b6991a3
...
@@ -36,6 +36,7 @@ import Gargantext.Database.Query.Table.Node.UpdateOpaleye (updateHyperdata)
...
@@ -36,6 +36,7 @@ import Gargantext.Database.Query.Table.Node.UpdateOpaleye (updateHyperdata)
import
Gargantext.Prelude
hiding
(
hash
)
import
Gargantext.Prelude
hiding
(
hash
)
import
Gargantext.Prelude.Config
(
GargConfig
(
..
))
import
Gargantext.Prelude.Config
(
GargConfig
(
..
))
import
Gargantext.Prelude.Crypto.Hash
(
hash
)
import
Gargantext.Prelude.Crypto.Hash
(
hash
)
import
Servant.Client.Core.BaseUrl
------------------------------------------------------------------------
------------------------------------------------------------------------
-- | TODO mk all others nodes
-- | TODO mk all others nodes
...
@@ -95,9 +96,8 @@ mkNodeWithParent_ConfigureHyperdata NodeFrameNotebook (Just i) uId name = (:[])
...
@@ -95,9 +96,8 @@ mkNodeWithParent_ConfigureHyperdata NodeFrameNotebook (Just i) uId name = (:[])
mkNodeWithParent_ConfigureHyperdata
_
_
_
_
=
nodeError
NotImplYet
mkNodeWithParent_ConfigureHyperdata
_
_
_
_
=
nodeError
NotImplYet
internalNotesProxy
::
MicroServicesSettings
->
T
.
Text
internalNotesProxy
::
BaseUrl
->
T
.
Text
internalNotesProxy
MicroServicesSettings
{
..
}
=
internalNotesProxy
proxyUrl
=
T
.
pack
$
showBaseUrl
proxyUrl
<>
"/notes"
"http://localhost:"
<>
T
.
pack
(
show
_msProxyPort
)
<>
"/notes"
-- | Function not exposed
-- | Function not exposed
mkNodeWithParent_ConfigureHyperdata'
::
(
HasNodeError
err
,
HasDBid
NodeType
,
HasSettings
env
)
mkNodeWithParent_ConfigureHyperdata'
::
(
HasNodeError
err
,
HasDBid
NodeType
,
HasSettings
env
)
...
@@ -116,7 +116,7 @@ mkNodeWithParent_ConfigureHyperdata' nt (Just i) uId name = do
...
@@ -116,7 +116,7 @@ mkNodeWithParent_ConfigureHyperdata' nt (Just i) uId name = do
cfg
<-
view
hasConfig
cfg
<-
view
hasConfig
stt
<-
view
settings
stt
<-
view
settings
u
<-
case
nt
of
u
<-
case
nt
of
Notes
->
pure
$
internalNotesProxy
(
_microservicesSettings
stt
)
Notes
->
pure
$
internalNotesProxy
(
mkProxyUrl
cfg
$
_microservicesSettings
stt
)
Calc
->
pure
$
_gc_frame_calc_url
cfg
Calc
->
pure
$
_gc_frame_calc_url
cfg
NodeFrameVisio
->
pure
$
_gc_frame_visio_url
cfg
NodeFrameVisio
->
pure
$
_gc_frame_visio_url
cfg
_
->
nodeError
NeedsConfiguration
_
->
nodeError
NeedsConfiguration
...
...
src/Gargantext/MicroServices/ReverseProxy.hs
View file @
4b6991a3
...
@@ -138,9 +138,9 @@ server env = ReverseProxyAPI {
...
@@ -138,9 +138,9 @@ server env = ReverseProxyAPI {
-- internally, the Javascript of CodiMD would otherwise take the first slice of the URL path
-- internally, the Javascript of CodiMD would otherwise take the first slice of the URL path
-- (something like `/notes/<frameId>`) and use /that/ as the <frameId>, which would be wrong
-- (something like `/notes/<frameId>`) and use /that/ as the <frameId>, which would be wrong
-- as it would try to establish a connection to `noteId=notes`.
-- as it would try to establish a connection to `noteId=notes`.
configJS
::
ServiceType
->
T
.
Text
configJS
::
BaseUrl
->
ServiceType
->
T
.
Text
configJS
st
=
T
.
pack
$
[
r
|
configJS
bu
st
=
T
.
pack
$
[
r
|
window.domain = ''
window.domain = '
|]
<>
(
baseUrlHost
bu
)
<>
[
r
|
'
window.urlpath = '
|]
<>
renderServiceType
st
<>
[
r
|
'
window.urlpath = '
|]
<>
renderServiceType
st
<>
[
r
|
'
window.debug = false
window.debug = false
window.version = '1.2.0'
window.version = '1.2.0'
...
@@ -154,7 +154,7 @@ notesProxyImplementation :: Env -> NotesProxy AsServer
...
@@ -154,7 +154,7 @@ notesProxyImplementation :: Env -> NotesProxy AsServer
notesProxyImplementation
env
=
NotesProxy
{
notesProxyImplementation
env
=
NotesProxy
{
slideEp
=
\
frameId
->
slideProxyServer
env
frameId
slideEp
=
\
frameId
->
slideProxyServer
env
frameId
,
publishEp
=
\
frameId
->
publishProxyServer
env
frameId
,
publishEp
=
\
frameId
->
publishProxyServer
env
frameId
,
configFile
=
pure
$
configJS
sty
,
configFile
=
pure
$
configJS
(
proxyUrl
env
)
sty
,
notesSocket
=
socketIOProxyImplementation
sty
env
,
notesSocket
=
socketIOProxyImplementation
sty
env
,
meEndpoint
=
proxyPassServer
sty
env
,
meEndpoint
=
proxyPassServer
sty
env
,
notesEp
=
\
_frameId
->
defaultForwardServer
sty
id
env
,
notesEp
=
\
_frameId
->
defaultForwardServer
sty
id
env
...
@@ -215,6 +215,10 @@ removeFromReferer pth originalRequest =
...
@@ -215,6 +215,10 @@ removeFromReferer pth originalRequest =
|
otherwise
|
otherwise
=
(
k
,
v
)
=
(
k
,
v
)
proxyUrl
::
Env
->
BaseUrl
proxyUrl
env
=
mkProxyUrl
(
env
^.
hasConfig
)
(
env
^.
env_settings
.
microservicesSettings
)
defaultForwardServer
::
ServiceType
defaultForwardServer
::
ServiceType
->
(
Request
->
Request
)
->
(
Request
->
Request
)
->
Env
->
Env
...
@@ -226,26 +230,15 @@ defaultForwardServer sty presendModifyRequest env =
...
@@ -226,26 +230,15 @@ defaultForwardServer sty presendModifyRequest env =
proxyDestination
::
ProxyDestination
proxyDestination
::
ProxyDestination
proxyDestination
=
mkProxyDestination
env
proxyDestination
=
mkProxyDestination
env
proxyUrl
::
BaseUrl
proxyUrl
=
fromMaybe
(
panicTrace
"Couldn't parse proxy settings"
)
$
do
url
<-
parseBaseUrl
(
"http://localhost:"
<>
Prelude
.
show
proxyListeningPort
)
-- FIXME(adn)
pure
url
proxyUrlStr
::
String
proxyUrlStr
::
String
proxyUrlStr
=
showBaseUrl
proxyUrl
proxyUrlStr
=
showBaseUrl
(
proxyUrl
env
)
microSrvSettings
::
MicroServicesSettings
microSrvSettings
=
env
^.
env_settings
.
microservicesSettings
proxyListeningPort
::
Int
proxyListeningPort
=
microSrvSettings
^.
msProxyPort
proxySettings
::
WaiProxySettings
proxySettings
::
WaiProxySettings
proxySettings
=
proxySettings
=
defaultWaiProxySettings
{
defaultWaiProxySettings
{
wpsProcessBody
=
\
_req
_res
->
Just
$
replaceRelativeLinks
(
C8
.
pack
$
proxyUrlStr
<>
serviceTypeToProxyPath
sty
)
wpsProcessBody
=
\
_req
_res
->
Just
$
replaceRelativeLinks
(
C8
.
pack
$
proxyUrlStr
<>
serviceTypeToProxyPath
sty
)
,
wpsModifyResponseHeaders
=
\
_req
_res
->
tweakResponseHeaders
,
wpsModifyResponseHeaders
=
\
_req
_res
->
tweakResponseHeaders
,
wpsRedirectCounts
=
2
,
wpsRedirectCounts
=
5
}
}
setHost
::
ProxyDestination
->
RequestHeaders
->
RequestHeaders
setHost
::
ProxyDestination
->
RequestHeaders
->
RequestHeaders
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment