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
Christian Merten
haskell-gargantext
Commits
e4222dfc
Commit
e4222dfc
authored
Jul 22, 2024
by
Alfredo Di Napoli
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support port in share URL if localhost
parent
d5153d39
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
4 deletions
+25
-4
ShareURL.hs
src/Gargantext/API/Node/ShareURL.hs
+11
-1
Share.hs
test/Test/API/Private/Share.hs
+14
-3
No files found.
src/Gargantext/API/Node/ShareURL.hs
View file @
e4222dfc
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE BangPatterns #-}
module
Gargantext.API.Node.ShareURL
where
module
Gargantext.API.Node.ShareURL
where
...
@@ -14,6 +15,7 @@ import Gargantext.Database.Prelude (HasConfig (hasConfig), CmdCommon)
...
@@ -14,6 +15,7 @@ import Gargantext.Database.Prelude (HasConfig (hasConfig), CmdCommon)
import
Gargantext.Prelude
import
Gargantext.Prelude
import
Network.URI
(
parseURI
)
import
Network.URI
(
parseURI
)
import
Servant.Server.Generic
(
AsServerT
)
import
Servant.Server.Generic
(
AsServerT
)
import
Gargantext.API.Admin.Types
(
appPort
,
settings
)
shareURL
::
IsGargServer
env
err
m
=>
Named
.
ShareURL
(
AsServerT
m
)
shareURL
::
IsGargServer
env
err
m
=>
Named
.
ShareURL
(
AsServerT
m
)
shareURL
=
Named
.
ShareURL
getUrl
shareURL
=
Named
.
ShareURL
getUrl
...
@@ -25,10 +27,18 @@ getUrl :: (IsGargServer env err m, CmdCommon env)
...
@@ -25,10 +27,18 @@ getUrl :: (IsGargServer env err m, CmdCommon env)
getUrl
nt
id
=
do
getUrl
nt
id
=
do
-- TODO add check that the node is able to be shared (in a shared folder)
-- TODO add check that the node is able to be shared (in a shared folder)
urlHost
<-
T
.
unpack
<$>
view
(
hasConfig
.
gc_url
)
urlHost
<-
T
.
unpack
<$>
view
(
hasConfig
.
gc_url
)
urlPort
<-
view
(
settings
.
appPort
)
let
res
=
do
let
res
=
do
t
<-
maybe
(
Left
"Invalid node Type"
)
Right
nt
t
<-
maybe
(
Left
"Invalid node Type"
)
Right
nt
i
<-
maybe
(
Left
"Invalid node ID"
)
Right
id
i
<-
maybe
(
Left
"Invalid node ID"
)
Right
id
let
rawURL
=
urlHost
<>
"/#/share/"
<>
show
t
<>
"/"
<>
show
(
unNodeId
i
)
-- Include the port the server is running on if this is
-- localhost, so that share URLs would work out of the box.
let
!
rawURL
|
"localhost"
`
isInfixOf
`
urlHost
=
urlHost
<>
":"
<>
show
urlPort
<>
"/#/share/"
<>
show
t
<>
"/"
<>
show
(
unNodeId
i
)
|
otherwise
=
urlHost
<>
"/#/share/"
<>
show
t
<>
"/"
<>
show
(
unNodeId
i
)
maybe
(
Left
$
"Couldn't construct a valid share URL from '"
<>
rawURL
<>
"'"
)
maybe
(
Left
$
"Couldn't construct a valid share URL from '"
<>
rawURL
<>
"'"
)
(
Right
.
Named
.
ShareLink
)
(
Right
.
Named
.
ShareLink
)
(
parseURI
rawURL
)
(
parseURI
rawURL
)
...
...
test/Test/API/Private/Share.hs
View file @
e4222dfc
...
@@ -8,7 +8,7 @@ module Test.API.Private.Share (
...
@@ -8,7 +8,7 @@ module Test.API.Private.Share (
import
Control.Lens
import
Control.Lens
import
Data.ByteString.Lazy.Char8
qualified
as
CL8
import
Data.ByteString.Lazy.Char8
qualified
as
CL8
import
Data.
Lis
t
qualified
as
T
import
Data.
Tex
t
qualified
as
T
import
Gargantext.API.Errors
import
Gargantext.API.Errors
import
Gargantext.API.Routes.Named
import
Gargantext.API.Routes.Named
import
Gargantext.API.Routes.Named.Private
import
Gargantext.API.Routes.Named.Private
...
@@ -59,7 +59,7 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
...
@@ -59,7 +59,7 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
url
<-
liftIO
$
runClientM
(
shareURL
(
toServantToken
token
)
Nothing
Nothing
)
(
clientEnv
serverPort
)
url
<-
liftIO
$
runClientM
(
shareURL
(
toServantToken
token
)
Nothing
Nothing
)
(
clientEnv
serverPort
)
case
url
of
case
url
of
Left
(
FailureResponse
_req
res
)
Left
(
FailureResponse
_req
res
)
->
liftIO
$
(
CL8
.
unpack
$
responseBody
res
)
`
shouldSatisfy
`
(
T
.
isInfixOf
"Invalid node Type"
)
->
liftIO
$
(
CL8
.
unpack
$
responseBody
res
)
`
shouldSatisfy
`
(
T
.
isInfixOf
"Invalid node Type"
.
T
.
pack
)
_
->
fail
"Test did not fail as expected!"
_
->
fail
"Test did not fail as expected!"
it
"should fail if no node ID is specified"
$
\
((
_testEnv
,
serverPort
),
app
)
->
do
it
"should fail if no node ID is specified"
$
\
((
_testEnv
,
serverPort
),
app
)
->
do
...
@@ -68,7 +68,7 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
...
@@ -68,7 +68,7 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
url
<-
liftIO
$
runClientM
(
shareURL
(
toServantToken
token
)
(
Just
NodeCorpus
)
Nothing
)
(
clientEnv
serverPort
)
url
<-
liftIO
$
runClientM
(
shareURL
(
toServantToken
token
)
(
Just
NodeCorpus
)
Nothing
)
(
clientEnv
serverPort
)
case
url
of
case
url
of
Left
(
FailureResponse
_req
res
)
Left
(
FailureResponse
_req
res
)
->
liftIO
$
(
CL8
.
unpack
$
responseBody
res
)
`
shouldSatisfy
`
(
T
.
isInfixOf
"Invalid node ID"
)
->
liftIO
$
(
CL8
.
unpack
$
responseBody
res
)
`
shouldSatisfy
`
(
T
.
isInfixOf
"Invalid node ID"
.
T
.
pack
)
_
->
fail
"Test did not fail as expected!"
_
->
fail
"Test did not fail as expected!"
it
"should return a valid URL"
$
\
((
testEnv
,
serverPort
),
app
)
->
do
it
"should return a valid URL"
$
\
((
testEnv
,
serverPort
),
app
)
->
do
...
@@ -81,3 +81,14 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
...
@@ -81,3 +81,14 @@ tests = sequential $ aroundAll withTestDBAndPort $ do
->
fail
(
show
err
)
->
fail
(
show
err
)
Right
(
ShareLink
_
)
Right
(
ShareLink
_
)
->
pure
()
->
pure
()
it
"should include the port if needed (like localhost)"
$
\
((
testEnv
,
serverPort
),
app
)
->
do
withApplication
app
$
do
withValidLogin
serverPort
"alice"
(
GargPassword
"alice"
)
$
\
token
->
do
cId
<-
liftIO
$
newCorpusForUser
testEnv
"alice"
url
<-
liftIO
$
runClientM
(
shareURL
(
toServantToken
token
)
(
Just
NodeCorpus
)
(
Just
cId
))
(
clientEnv
serverPort
)
case
url
of
Left
err
->
fail
(
show
err
)
Right
(
ShareLink
uri
)
->
liftIO
$
"localhost:80"
`
T
.
isInfixOf
`
T
.
pack
(
show
uri
)
`
shouldBe
`
True
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