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
84a3f5e3
Commit
84a3f5e3
authored
Jan 18, 2024
by
Alfredo Di Napoli
Committed by
Alfredo Di Napoli
Jan 22, 2024
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix compilation errors due to switch to GHC 9.4.7
parent
0d442496
Changes
35
Hide whitespace changes
Inline
Side-by-side
Showing
35 changed files
with
455 additions
and
368 deletions
+455
-368
cabal.project.freeze
cabal.project.freeze
+9
-9
gargantext.cabal
gargantext.cabal
+23
-13
Types.hs
src/Gargantext/API/Admin/Auth/Types.hs
+26
-10
Settings.hs
src/Gargantext/API/Admin/Settings.hs
+3
-2
Count.hs
src/Gargantext/API/Count.hs
+13
-8
Types.hs
src/Gargantext/API/Errors/Types.hs
+2
-2
GraphQL.hs
src/Gargantext/API/GraphQL.hs
+3
-3
Node.hs
src/Gargantext/API/GraphQL/Node.hs
+2
-2
Utils.hs
src/Gargantext/API/GraphQL/Utils.hs
+2
-0
Ngrams.hs
src/Gargantext/API/Ngrams.hs
+1
-1
Tools.hs
src/Gargantext/API/Ngrams/Tools.hs
+2
-1
Types.hs
src/Gargantext/API/Ngrams/Types.hs
+48
-52
Node.hs
src/Gargantext/API/Node.hs
+55
-57
Types.hs
src/Gargantext/API/Node/Document/Export/Types.hs
+2
-2
NodeStory.hs
src/Gargantext/Core/NodeStory.hs
+2
-2
Date.hs
src/Gargantext/Core/Text/Corpus/Parsers/Date.hs
+2
-2
Eleve.hs
src/Gargantext/Core/Text/Terms/Eleve.hs
+5
-4
En.hs
src/Gargantext/Core/Text/Terms/Mono/Token/En.hs
+2
-2
Phylo.hs
src/Gargantext/Core/Types/Phylo.hs
+61
-53
LegacyPhylo.hs
src/Gargantext/Core/Viz/LegacyPhylo.hs
+17
-17
Phylo.hs
src/Gargantext/Core/Viz/Phylo.hs
+4
-3
Tools.hs
src/Gargantext/Core/Viz/Phylo/API/Tools.hs
+1
-1
LegacyMain.hs
src/Gargantext/Core/Viz/Phylo/Legacy/LegacyMain.hs
+1
-1
Flow.hs
src/Gargantext/Database/Action/Flow.hs
+1
-1
Contact.hs
src/Gargantext/Database/Admin/Types/Hyperdata/Contact.hs
+14
-13
Document.hs
src/Gargantext/Database/Admin/Types/Hyperdata/Document.hs
+28
-24
User.hs
src/Gargantext/Database/Admin/Types/Hyperdata/User.hs
+1
-1
Metrics.hs
src/Gargantext/Database/Admin/Types/Metrics.hs
+1
-1
Prelude.hs
src/Gargantext/Database/Prelude.hs
+1
-1
Facet.hs
src/Gargantext/Database/Query/Facet.hs
+1
-0
User.hs
src/Gargantext/Database/Schema/User.hs
+3
-3
Jobs.hs
src/Gargantext/Utils/Jobs.hs
+1
-0
SpacyNLP.hs
src/Gargantext/Utils/SpacyNLP.hs
+18
-77
Types.hs
src/Gargantext/Utils/SpacyNLP/Types.hs
+95
-0
stack.yaml
stack.yaml
+5
-0
No files found.
cabal.project.freeze
View file @
84a3f5e3
...
@@ -1704,15 +1704,15 @@ constraints: any.AC-Angle ==1.0,
...
@@ -1704,15 +1704,15 @@ constraints: any.AC-Angle ==1.0,
any.monoid-transformer ==0.0.4,
any.monoid-transformer ==0.0.4,
any.monoidal-containers ==0.6.4.0,
any.monoidal-containers ==0.6.4.0,
any.more-containers ==0.2.2.2,
any.more-containers ==0.2.2.2,
any.morpheus-graphql ==0.2
7
.3,
any.morpheus-graphql ==0.2
4
.3,
any.morpheus-graphql-app ==0.2
7
.3,
any.morpheus-graphql-app ==0.2
4
.3,
any.morpheus-graphql-client ==0.2
7
.3,
any.morpheus-graphql-client ==0.2
4
.3,
any.morpheus-graphql-code-gen ==0.2
7
.3,
any.morpheus-graphql-code-gen ==0.2
4
.3,
any.morpheus-graphql-code-gen-utils ==0.2
7
.3,
any.morpheus-graphql-code-gen-utils ==0.2
4
.3,
any.morpheus-graphql-core ==0.2
7
.3,
any.morpheus-graphql-core ==0.2
4
.3,
any.morpheus-graphql-server ==0.2
7
.3,
any.morpheus-graphql-server ==0.2
4
.3,
any.morpheus-graphql-subscriptions ==0.2
7
.3,
any.morpheus-graphql-subscriptions ==0.2
4
.3,
any.morpheus-graphql-tests ==0.2
7
.3,
any.morpheus-graphql-tests ==0.2
4
.3,
any.moss ==0.2.0.1,
any.moss ==0.2.0.1,
any.mountpoints ==1.0.2,
any.mountpoints ==1.0.2,
any.mpi-hs ==0.7.2.0,
any.mpi-hs ==0.7.2.0,
...
...
gargantext.cabal
View file @
84a3f5e3
...
@@ -45,6 +45,10 @@ flag test-crypto
...
@@ -45,6 +45,10 @@ flag test-crypto
default: False
default: False
manual: True
manual: True
flag disable-db-obfuscation-executable
default: False
manual: True
library
library
exposed-modules:
exposed-modules:
Gargantext
Gargantext
...
@@ -165,6 +169,7 @@ library
...
@@ -165,6 +169,7 @@ library
Gargantext.Utils.Jobs.Settings
Gargantext.Utils.Jobs.Settings
Gargantext.Utils.Jobs.State
Gargantext.Utils.Jobs.State
Gargantext.Utils.SpacyNLP
Gargantext.Utils.SpacyNLP
Gargantext.Utils.SpacyNLP.Types
Gargantext.Utils.Tuple
Gargantext.Utils.Tuple
Gargantext.Utils.Zip
Gargantext.Utils.Zip
other-modules:
other-modules:
...
@@ -491,10 +496,11 @@ library
...
@@ -491,10 +496,11 @@ library
, matrix ^>= 0.3.6.1
, matrix ^>= 0.3.6.1
, monad-control ^>= 1.0.3.1
, monad-control ^>= 1.0.3.1
, monad-logger ^>= 0.3.36
, monad-logger ^>= 0.3.36
, morpheus-graphql ^>= 0.17.0
, morpheus-graphql >= 0.17.0 && < 0.25
, morpheus-graphql-app ^>= 0.17.0
, morpheus-graphql-app >= 0.17.0 && < 0.25
, morpheus-graphql-core ^>= 0.17.0
, morpheus-graphql-core >= 0.17.0 && < 0.25
, morpheus-graphql-subscriptions ^>= 0.17.0
, morpheus-graphql-server >= 0.17.0 && < 0.25
, morpheus-graphql-subscriptions >= 0.17.0 && < 0.25
, mtl ^>= 2.2.2
, mtl ^>= 2.2.2
, natural-transformation ^>= 0.4
, natural-transformation ^>= 0.4
, network-uri ^>= 2.6.4.1
, network-uri ^>= 2.6.4.1
...
@@ -547,6 +553,7 @@ library
...
@@ -547,6 +553,7 @@ library
, servant-xml-conduit >= 0.1.0.4
, servant-xml-conduit >= 0.1.0.4
, simple-reflect ^>= 0.3.3
, simple-reflect ^>= 0.3.3
, singletons ^>= 2.7
, singletons ^>= 2.7
, singletons-th >= 3.1
, split ^>= 0.2.3.4
, split ^>= 0.2.3.4
, stemmer ^>= 0.5.2
, stemmer ^>= 0.5.2
, stm ^>= 2.5.0.1
, stm ^>= 2.5.0.1
...
@@ -714,15 +721,18 @@ executable gargantext-db-obfuscation
...
@@ -714,15 +721,18 @@ executable gargantext-db-obfuscation
RecordWildCards
RecordWildCards
StrictData
StrictData
ghc-options: -Wall -threaded -rtsopts -with-rtsopts=-N -O2 -Wmissing-signatures
ghc-options: -Wall -threaded -rtsopts -with-rtsopts=-N -O2 -Wmissing-signatures
build-depends:
if flag(disable-db-obfuscation-executable)
base
buildable: False
, extra
else
, gargantext
build-depends:
, gargantext-prelude
base
, optparse-simple
, extra
, postgresql-simple ^>= 0.6.4
, gargantext
, text
, gargantext-prelude
default-language: Haskell2010
, optparse-simple
, postgresql-simple ^>= 0.6.4
, text
default-language: Haskell2010
executable gargantext-import
executable gargantext-import
main-is: Main.hs
main-is: Main.hs
...
...
src/Gargantext/API/Admin/Auth/Types.hs
View file @
84a3f5e3
...
@@ -52,16 +52,11 @@ data AuthenticatedUser = AuthenticatedUser
...
@@ -52,16 +52,11 @@ data AuthenticatedUser = AuthenticatedUser
,
_auth_user_id
::
UserId
,
_auth_user_id
::
UserId
}
deriving
(
Generic
)
}
deriving
(
Generic
)
$
(
deriveJSON
(
JSON
.
defaultOptions
{
JSON
.
fieldLabelModifier
=
tail
.
dropWhile
((
/=
)
'_'
)
.
tail
})
''
A
uthenticatedUser
)
makeLenses
''
A
uthenticatedUser
makeLenses
''
A
uthenticatedUser
instance
ToSchema
AuthenticatedUser
where
instance
ToSchema
AuthenticatedUser
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authUser_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authUser_"
)
instance
ToJWT
AuthenticatedUser
instance
FromJWT
AuthenticatedUser
data
AuthenticationError
data
AuthenticationError
=
LoginFailed
NodeId
UserId
Jose
.
Error
=
LoginFailed
NodeId
UserId
Jose
.
Error
|
InvalidUsernameOrPassword
|
InvalidUsernameOrPassword
...
@@ -71,7 +66,6 @@ data AuthenticationError
...
@@ -71,7 +66,6 @@ data AuthenticationError
type
AuthContext
=
'[
J
WTSettings
,
CookieSettings
]
-- , BasicAuthCfg
type
AuthContext
=
'[
J
WTSettings
,
CookieSettings
]
-- , BasicAuthCfg
-- | Instances
-- | Instances
$
(
deriveJSON
(
unPrefix
"_authReq_"
)
''
A
uthRequest
)
instance
ToSchema
AuthRequest
where
instance
ToSchema
AuthRequest
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authReq_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authReq_"
)
...
@@ -81,7 +75,6 @@ instance Arbitrary AuthRequest where
...
@@ -81,7 +75,6 @@ instance Arbitrary AuthRequest where
,
p
<-
arbitraryPassword
,
p
<-
arbitraryPassword
]
]
$
(
deriveJSON
(
unPrefix
"_authRes_"
)
''
A
uthResponse
)
instance
ToSchema
AuthResponse
where
instance
ToSchema
AuthResponse
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authRes_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_authRes_"
)
instance
Arbitrary
AuthResponse
where
instance
Arbitrary
AuthResponse
where
...
@@ -101,20 +94,43 @@ type Password = Text
...
@@ -101,20 +94,43 @@ type Password = Text
data
ForgotPasswordRequest
=
ForgotPasswordRequest
{
_fpReq_email
::
Email
}
data
ForgotPasswordRequest
=
ForgotPasswordRequest
{
_fpReq_email
::
Email
}
deriving
(
Generic
)
deriving
(
Generic
)
$
(
deriveJSON
(
unPrefix
"_fpReq_"
)
''
F
orgotPasswordRequest
)
instance
ToSchema
ForgotPasswordRequest
where
instance
ToSchema
ForgotPasswordRequest
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpReq_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpReq_"
)
data
ForgotPasswordResponse
=
ForgotPasswordResponse
{
_fpRes_status
::
Text
}
data
ForgotPasswordResponse
=
ForgotPasswordResponse
{
_fpRes_status
::
Text
}
deriving
(
Generic
)
deriving
(
Generic
)
$
(
deriveJSON
(
unPrefix
"_fpRes_"
)
''
F
orgotPasswordResponse
)
instance
ToSchema
ForgotPasswordResponse
where
instance
ToSchema
ForgotPasswordResponse
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpRes_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpRes_"
)
data
ForgotPasswordGet
=
ForgotPasswordGet
{
_fpGet_password
::
Password
}
data
ForgotPasswordGet
=
ForgotPasswordGet
{
_fpGet_password
::
Password
}
deriving
(
Generic
)
deriving
(
Generic
)
$
(
deriveJSON
(
unPrefix
"_fpGet_"
)
''
F
orgotPasswordGet
)
instance
ToSchema
ForgotPasswordGet
where
instance
ToSchema
ForgotPasswordGet
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpGet_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_fpGet_"
)
--
-- Lenses
--
makeLenses
''
A
uthValid
>>>>>>>
b7657056
(
Fix
compilation
errors
due
to
switch
to
GHC
9.4
.
7
)
makeLenses
''
A
uthResponse
makeLenses
''
A
uthResponse
--
-- JSON instances
--
$
(
deriveJSON
(
JSON
.
defaultOptions
{
JSON
.
fieldLabelModifier
=
tail
.
dropWhile
((
/=
)
'_'
)
.
tail
})
''
A
uthenticatedUser
)
$
(
deriveJSON
(
unPrefix
"_authReq_"
)
''
A
uthRequest
)
$
(
deriveJSON
(
unPrefix
"_authInv_"
)
''
A
uthInvalid
)
$
(
deriveJSON
(
unPrefix
"_authVal_"
)
''
A
uthValid
)
$
(
deriveJSON
(
unPrefix
"_authRes_"
)
''
A
uthResponse
)
$
(
deriveJSON
(
unPrefix
"_fpReq_"
)
''
F
orgotPasswordRequest
)
$
(
deriveJSON
(
unPrefix
"_fpRes_"
)
''
F
orgotPasswordResponse
)
$
(
deriveJSON
(
unPrefix
"_fpGet_"
)
''
F
orgotPasswordGet
)
--
-- JWT instances
--
instance
ToJWT
AuthenticatedUser
instance
FromJWT
AuthenticatedUser
src/Gargantext/API/Admin/Settings.hs
View file @
84a3f5e3
...
@@ -24,7 +24,8 @@ import Control.Lens
...
@@ -24,7 +24,8 @@ import Control.Lens
import
Control.Monad.Logger
(
LogLevel
(
..
))
import
Control.Monad.Logger
(
LogLevel
(
..
))
import
Control.Monad.Reader
import
Control.Monad.Reader
import
Data.ByteString.Lazy
qualified
as
L
import
Data.ByteString.Lazy
qualified
as
L
import
Data.Pool
(
Pool
,
createPool
)
import
Data.Pool
(
Pool
)
import
qualified
Data.Pool
as
Pool
import
Database.PostgreSQL.Simple
(
Connection
,
connect
,
close
,
ConnectInfo
)
import
Database.PostgreSQL.Simple
(
Connection
,
connect
,
close
,
ConnectInfo
)
import
Gargantext.API.Admin.EnvTypes
import
Gargantext.API.Admin.EnvTypes
import
Gargantext.API.Admin.Types
import
Gargantext.API.Admin.Types
...
@@ -217,7 +218,7 @@ newEnv logger port file = do
...
@@ -217,7 +218,7 @@ newEnv logger port file = do
}
}
newPool
::
ConnectInfo
->
IO
(
Pool
Connection
)
newPool
::
ConnectInfo
->
IO
(
Pool
Connection
)
newPool
param
=
createPool
(
connect
param
)
close
1
(
60
*
60
)
8
newPool
param
=
Pool
.
newPool
$
Pool
.
setNumStripes
(
Just
1
)
$
Pool
.
defaultPoolConfig
(
connect
param
)
close
(
60
*
60
)
8
{-
{-
cleanEnv :: (HasConfig env, HasRepo env) => env -> IO ()
cleanEnv :: (HasConfig env, HasRepo env) => env -> IO ()
...
...
src/Gargantext/API/Count.hs
View file @
84a3f5e3
...
@@ -104,18 +104,12 @@ messages = toMessage $ [ (400, ["Ill formed query "])
...
@@ -104,18 +104,12 @@ messages = toMessage $ [ (400, ["Ill formed query "])
instance
Arbitrary
Message
where
instance
Arbitrary
Message
where
arbitrary
=
elements
messages
arbitrary
=
elements
messages
instance
FromJSON
Message
instance
ToJSON
Message
instance
ToSchema
Message
instance
ToSchema
Message
-----------------------------------------------------------------------
-----------------------------------------------------------------------
data
Counts
=
Counts
{
results
::
[
Either
Message
Count
]
data
Counts
=
Counts
{
results
::
[
Either
Message
Count
]
}
deriving
(
Eq
,
Show
,
Generic
)
}
deriving
(
Eq
,
Show
,
Generic
)
instance
FromJSON
Counts
instance
ToJSON
Counts
instance
Arbitrary
Counts
where
instance
Arbitrary
Counts
where
arbitrary
=
elements
[
Counts
[
Right
(
Count
Pubmed
(
Just
20
))
arbitrary
=
elements
[
Counts
[
Right
(
Count
Pubmed
(
Just
20
))
,
Right
(
Count
IsTex
(
Just
150
))
,
Right
(
Count
IsTex
(
Just
150
))
...
@@ -131,8 +125,6 @@ data Count = Count { count_name :: Scraper
...
@@ -131,8 +125,6 @@ data Count = Count { count_name :: Scraper
}
}
deriving
(
Eq
,
Show
,
Generic
)
deriving
(
Eq
,
Show
,
Generic
)
$
(
deriveJSON
(
unPrefix
"count_"
)
''
C
ount
)
instance
ToSchema
Count
where
instance
ToSchema
Count
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"count_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"count_"
)
--instance Arbitrary Count where
--instance Arbitrary Count where
...
@@ -141,3 +133,16 @@ instance ToSchema Count where
...
@@ -141,3 +133,16 @@ instance ToSchema Count where
-----------------------------------------------------------------------
-----------------------------------------------------------------------
count
::
Monad
m
=>
Query
->
m
Counts
count
::
Monad
m
=>
Query
->
m
Counts
count
_
=
undefined
count
_
=
undefined
--
-- JSON instances
--
instance
FromJSON
Message
instance
ToJSON
Message
$
(
deriveJSON
(
unPrefix
"count_"
)
''
C
ount
)
instance
FromJSON
Counts
instance
ToJSON
Counts
src/Gargantext/API/Errors/Types.hs
View file @
84a3f5e3
...
@@ -671,8 +671,8 @@ genFrontendErr be = do
...
@@ -671,8 +671,8 @@ genFrontendErr be = do
EC_404__tree_empty_root
EC_404__tree_empty_root
->
pure
$
mkFrontendErr'
txt
$
FE_tree_empty_root
->
pure
$
mkFrontendErr'
txt
$
FE_tree_empty_root
EC_500__tree_too_many_roots
EC_500__tree_too_many_roots
->
do
nodes
<-
arbitrary
->
do
nodes
<-
getNonEmpty
<$>
arbitrary
pure
$
mkFrontendErr'
txt
$
FE_tree_too_many_roots
nodes
pure
$
mkFrontendErr'
txt
$
FE_tree_too_many_roots
(
NE
.
fromList
nodes
)
-- job errors
-- job errors
EC_500__job_invalid_id_type
EC_500__job_invalid_id_type
...
...
src/Gargantext/API/GraphQL.hs
View file @
84a3f5e3
...
@@ -22,7 +22,7 @@ import Data.ByteString.Lazy.Char8 ( ByteString )
...
@@ -22,7 +22,7 @@ import Data.ByteString.Lazy.Char8 ( ByteString )
import
Data.Morpheus
(
App
,
deriveApp
)
import
Data.Morpheus
(
App
,
deriveApp
)
import
Data.Morpheus.Server
(
httpPlayground
)
import
Data.Morpheus.Server
(
httpPlayground
)
import
Data.Morpheus.Subscriptions
(
Event
(
..
),
httpPubApp
)
import
Data.Morpheus.Subscriptions
(
Event
(
..
),
httpPubApp
)
import
Data.Morpheus.Types
(
GQLRequest
,
GQLResponse
,
GQLType
,
RootResolver
(
..
),
Undefined
(
..
)
)
import
Data.Morpheus.Types
(
GQLRequest
,
GQLResponse
,
GQLType
,
RootResolver
(
..
),
Undefined
,
defaultRootResolver
)
import
Data.Proxy
import
Data.Proxy
import
Gargantext.API.Admin.Auth.Types
(
AuthenticatedUser
)
import
Gargantext.API.Admin.Auth.Types
(
AuthenticatedUser
)
import
Gargantext.API.Admin.Orchestrator.Types
(
JobLog
)
import
Gargantext.API.Admin.Orchestrator.Types
(
JobLog
)
...
@@ -111,7 +111,7 @@ rootResolver
...
@@ -111,7 +111,7 @@ rootResolver
->
AccessPolicyManager
->
AccessPolicyManager
->
RootResolver
(
GargM
env
BackendInternalError
)
e
Query
Mutation
Undefined
->
RootResolver
(
GargM
env
BackendInternalError
)
e
Query
Mutation
Undefined
rootResolver
authenticatedUser
policyManager
=
rootResolver
authenticatedUser
policyManager
=
RootResolver
default
RootResolver
{
queryResolver
=
Query
{
annuaire_contacts
=
GQLA
.
resolveAnnuaireContacts
{
queryResolver
=
Query
{
annuaire_contacts
=
GQLA
.
resolveAnnuaireContacts
,
context_ngrams
=
GQLCTX
.
resolveContextNgrams
,
context_ngrams
=
GQLCTX
.
resolveContextNgrams
,
contexts
=
GQLCTX
.
resolveNodeContext
,
contexts
=
GQLCTX
.
resolveNodeContext
...
@@ -133,7 +133,7 @@ rootResolver authenticatedUser policyManager =
...
@@ -133,7 +133,7 @@ rootResolver authenticatedUser policyManager =
,
update_user_epo_api_token
=
GQLUser
.
updateUserEPOAPIToken
,
update_user_epo_api_token
=
GQLUser
.
updateUserEPOAPIToken
,
delete_team_membership
=
GQLTeam
.
deleteTeamMembership
,
delete_team_membership
=
GQLTeam
.
deleteTeamMembership
,
update_node_context_category
=
GQLCTX
.
updateNodeContextCategory
}
,
update_node_context_category
=
GQLCTX
.
updateNodeContextCategory
}
,
subscriptionResolver
=
Undefined
}
}
-- | Main GraphQL "app".
-- | Main GraphQL "app".
app
app
...
...
src/Gargantext/API/GraphQL/Node.hs
View file @
84a3f5e3
...
@@ -15,7 +15,7 @@ Portability : POSIX
...
@@ -15,7 +15,7 @@ Portability : POSIX
module
Gargantext.API.GraphQL.Node
where
module
Gargantext.API.GraphQL.Node
where
import
Data.Aeson
import
Data.Aeson
import
Data.
HashMap.Strict
qualified
as
HashMap
import
Data.
Aeson.KeyMap
qualified
as
KM
import
Data.Morpheus.Types
(
GQLType
)
import
Data.Morpheus.Types
(
GQLType
)
import
Data.Text
qualified
as
T
import
Data.Text
qualified
as
T
import
Gargantext.API.Admin.Auth.Types
import
Gargantext.API.Admin.Auth.Types
...
@@ -126,7 +126,7 @@ toCorpus N.Node { .. } = Corpus { id = NN.unNodeId _node_id
...
@@ -126,7 +126,7 @@ toCorpus N.Node { .. } = Corpus { id = NN.unNodeId _node_id
pubmedAPIKeyFromValue
::
Value
->
Maybe
PUBMED
.
APIKey
pubmedAPIKeyFromValue
::
Value
->
Maybe
PUBMED
.
APIKey
pubmedAPIKeyFromValue
(
Object
kv
)
=
pubmedAPIKeyFromValue
(
Object
kv
)
=
case
HashMap
.
lookup
"pubmed_api_key"
kv
of
case
KM
.
lookup
"pubmed_api_key"
kv
of
Nothing
->
Nothing
Nothing
->
Nothing
Just
v
->
case
fromJSON
v
of
Just
v
->
case
fromJSON
v
of
Error
_
->
Nothing
Error
_
->
Nothing
...
...
src/Gargantext/API/GraphQL/Utils.hs
View file @
84a3f5e3
...
@@ -8,6 +8,8 @@ Stability : experimental
...
@@ -8,6 +8,8 @@ Stability : experimental
Portability : POSIX
Portability : POSIX
-}
-}
{-# OPTIONS_GHC -Wno-deprecations #-}
-- FIXME(adn) GraphQL will need updating.
module
Gargantext.API.GraphQL.Utils
where
module
Gargantext.API.GraphQL.Utils
where
import
Control.Lens.Getter
(
view
)
import
Control.Lens.Getter
(
view
)
...
...
src/Gargantext/API/Ngrams.hs
View file @
84a3f5e3
...
@@ -120,7 +120,7 @@ import Gargantext.Database.Query.Table.Node (getNode)
...
@@ -120,7 +120,7 @@ import Gargantext.Database.Query.Table.Node (getNode)
import
Gargantext.Database.Query.Table.Node.Error
(
HasNodeError
)
import
Gargantext.Database.Query.Table.Node.Error
(
HasNodeError
)
import
Gargantext.Database.Query.Table.Node.Select
import
Gargantext.Database.Query.Table.Node.Select
import
Gargantext.Database.Schema.Node
(
node_id
,
node_parent_id
,
node_user_id
)
import
Gargantext.Database.Schema.Node
(
node_id
,
node_parent_id
,
node_user_id
)
import
Gargantext.Prelude
hiding
(
log
,
to
,
toLower
,
(
%
))
import
Gargantext.Prelude
hiding
(
log
,
to
,
toLower
,
(
%
)
,
isInfixOf
)
import
Gargantext.Prelude.Clock
(
hasTime
,
getTime
)
import
Gargantext.Prelude.Clock
(
hasTime
,
getTime
)
import
Gargantext.Utils.Jobs
(
serveJobsAPI
,
MonadJobStatus
(
..
))
import
Gargantext.Utils.Jobs
(
serveJobsAPI
,
MonadJobStatus
(
..
))
import
GHC.Conc
(
readTVar
,
writeTVar
)
import
GHC.Conc
(
readTVar
,
writeTVar
)
...
...
src/Gargantext/API/Ngrams/Tools.hs
View file @
84a3f5e3
...
@@ -9,7 +9,8 @@ Portability : POSIX
...
@@ -9,7 +9,8 @@ Portability : POSIX
-}
-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
module
Gargantext.API.Ngrams.Tools
module
Gargantext.API.Ngrams.Tools
where
where
...
...
src/Gargantext/API/Ngrams/Types.hs
View file @
84a3f5e3
...
@@ -84,8 +84,6 @@ instance ToParamSchema TabType
...
@@ -84,8 +84,6 @@ instance ToParamSchema TabType
instance
ToJSON
TabType
instance
ToJSON
TabType
instance
FromJSON
TabType
instance
FromJSON
TabType
instance
ToSchema
TabType
instance
ToSchema
TabType
instance
Arbitrary
TabType
where
arbitrary
=
elements
[
minBound
..
maxBound
]
instance
FromJSONKey
TabType
where
instance
FromJSONKey
TabType
where
fromJSONKey
=
genericFromJSONKey
defaultJSONKeyOptions
fromJSONKey
=
genericFromJSONKey
defaultJSONKeyOptions
instance
ToJSONKey
TabType
where
instance
ToJSONKey
TabType
where
...
@@ -161,14 +159,11 @@ deriveJSON (unPrefix "_nre_") ''NgramsRepoElement
...
@@ -161,14 +159,11 @@ deriveJSON (unPrefix "_nre_") ''NgramsRepoElement
makeLenses
''
N
gramsRepoElement
makeLenses
''
N
gramsRepoElement
instance
ToSchema
NgramsRepoElement
where
instance
ToSchema
NgramsRepoElement
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_nre_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_nre_"
)
instance
Serialise
NgramsRepoElement
instance
FromField
NgramsRepoElement
where
instance
FromField
NgramsRepoElement
where
fromField
=
fromJSONField
fromField
=
fromJSONField
instance
ToField
NgramsRepoElement
where
instance
ToField
NgramsRepoElement
where
toField
=
toJSONField
toField
=
toJSONField
instance
Serialise
(
MSet
NgramsTerm
)
data
NgramsElement
=
data
NgramsElement
=
NgramsElement
{
_ne_ngrams
::
NgramsTerm
NgramsElement
{
_ne_ngrams
::
NgramsTerm
,
_ne_size
::
Int
,
_ne_size
::
Int
...
@@ -197,9 +192,6 @@ newNgramsElement mayList ngrams =
...
@@ -197,9 +192,6 @@ newNgramsElement mayList ngrams =
instance
ToSchema
NgramsElement
where
instance
ToSchema
NgramsElement
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_ne_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_ne_"
)
instance
Arbitrary
NgramsElement
where
arbitrary
=
elements
[
newNgramsElement
Nothing
"sport"
]
------------------------------------------------------------------------
------------------------------------------------------------------------
newtype
NgramsTable
=
NgramsTable
[
NgramsElement
]
newtype
NgramsTable
=
NgramsTable
[
NgramsElement
]
...
@@ -257,9 +249,6 @@ mockTable = NgramsTable
...
@@ -257,9 +249,6 @@ mockTable = NgramsTable
where
where
rp
n
=
Just
$
RootParent
n
n
rp
n
=
Just
$
RootParent
n
n
instance
Arbitrary
NgramsTable
where
arbitrary
=
pure
mockTable
instance
ToSchema
NgramsTable
instance
ToSchema
NgramsTable
------------------------------------------------------------------------
------------------------------------------------------------------------
...
@@ -283,10 +272,6 @@ instance ToParamSchema OrderBy
...
@@ -283,10 +272,6 @@ instance ToParamSchema OrderBy
instance
FromJSON
OrderBy
instance
FromJSON
OrderBy
instance
ToJSON
OrderBy
instance
ToJSON
OrderBy
instance
ToSchema
OrderBy
instance
ToSchema
OrderBy
instance
Arbitrary
OrderBy
where
arbitrary
=
elements
[
minBound
..
maxBound
]
-- | A query on a 'NgramsTable'.
-- | A query on a 'NgramsTable'.
data
NgramsSearchQuery
=
NgramsSearchQuery
data
NgramsSearchQuery
=
NgramsSearchQuery
...
@@ -367,8 +352,6 @@ instance ToSchema a => ToSchema (PatchSet a)
...
@@ -367,8 +352,6 @@ instance ToSchema a => ToSchema (PatchSet a)
type
AddRem
=
Replace
(
Maybe
()
)
type
AddRem
=
Replace
(
Maybe
()
)
instance
Serialise
AddRem
remPatch
,
addPatch
::
AddRem
remPatch
,
addPatch
::
AddRem
remPatch
=
replace
(
Just
()
)
Nothing
remPatch
=
replace
(
Just
()
)
Nothing
addPatch
=
replace
Nothing
(
Just
()
)
addPatch
=
replace
Nothing
(
Just
()
)
...
@@ -388,9 +371,6 @@ unPatchMSet (PatchMSet a) = a
...
@@ -388,9 +371,6 @@ unPatchMSet (PatchMSet a) = a
type
ConflictResolutionPatchMSet
a
=
a
->
ConflictResolutionReplace
(
Maybe
()
)
type
ConflictResolutionPatchMSet
a
=
a
->
ConflictResolutionReplace
(
Maybe
()
)
type
instance
ConflictResolution
(
PatchMSet
a
)
=
ConflictResolutionPatchMSet
a
type
instance
ConflictResolution
(
PatchMSet
a
)
=
ConflictResolutionPatchMSet
a
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMap
a
AddRem
)
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMSet
a
)
-- TODO this breaks module abstraction
-- TODO this breaks module abstraction
makePrisms
''
P
M
.
PatchMap
makePrisms
''
P
M
.
PatchMap
...
@@ -419,19 +399,12 @@ instance (Ord a, ToJSON a) => ToJSON (PatchMSet a) where
...
@@ -419,19 +399,12 @@ instance (Ord a, ToJSON a) => ToJSON (PatchMSet a) where
instance
(
Ord
a
,
FromJSON
a
)
=>
FromJSON
(
PatchMSet
a
)
where
instance
(
Ord
a
,
FromJSON
a
)
=>
FromJSON
(
PatchMSet
a
)
where
parseJSON
=
fmap
(
_PatchMSetIso
#
)
.
parseJSON
parseJSON
=
fmap
(
_PatchMSetIso
#
)
.
parseJSON
instance
(
Ord
a
,
Arbitrary
a
)
=>
Arbitrary
(
PatchMSet
a
)
where
arbitrary
=
(
PatchMSet
.
PM
.
fromMap
)
<$>
arbitrary
instance
ToSchema
a
=>
ToSchema
(
PatchMSet
a
)
where
instance
ToSchema
a
=>
ToSchema
(
PatchMSet
a
)
where
-- TODO
-- TODO
declareNamedSchema
_
=
wellNamedSchema
""
(
Proxy
::
Proxy
TODO
)
declareNamedSchema
_
=
wellNamedSchema
""
(
Proxy
::
Proxy
TODO
)
type
instance
Patched
(
PatchMSet
a
)
=
MSet
a
type
instance
Patched
(
PatchMSet
a
)
=
MSet
a
instance
(
Eq
a
,
Arbitrary
a
)
=>
Arbitrary
(
Replace
a
)
where
arbitrary
=
uncurry
replace
<$>
arbitrary
-- If they happen to be equal then the patch is Keep.
instance
ToSchema
a
=>
ToSchema
(
Replace
a
)
where
instance
ToSchema
a
=>
ToSchema
(
Replace
a
)
where
declareNamedSchema
(
_
::
Proxy
(
Replace
a
))
=
do
declareNamedSchema
(
_
::
Proxy
(
Replace
a
))
=
do
-- TODO Keep constructor is not supported here.
-- TODO Keep constructor is not supported here.
...
@@ -475,19 +448,11 @@ instance ToSchema NgramsPatch where
...
@@ -475,19 +448,11 @@ instance ToSchema NgramsPatch where
,
(
"old"
,
nreSch
)
,
(
"old"
,
nreSch
)
,
(
"new"
,
nreSch
)
,
(
"new"
,
nreSch
)
]
]
instance
Arbitrary
NgramsPatch
where
arbitrary
=
frequency
[
(
9
,
NgramsPatch
<$>
arbitrary
<*>
(
replace
<$>
arbitrary
<*>
arbitrary
))
,
(
1
,
NgramsReplace
<$>
arbitrary
<*>
arbitrary
)
]
instance
Serialise
NgramsPatch
instance
FromField
NgramsPatch
where
instance
FromField
NgramsPatch
where
fromField
=
fromJSONField
fromField
=
fromJSONField
instance
ToField
NgramsPatch
where
instance
ToField
NgramsPatch
where
toField
=
toJSONField
toField
=
toJSONField
instance
Serialise
(
Replace
ListType
)
instance
Serialise
ListType
type
NgramsPatchIso
=
type
NgramsPatchIso
=
MaybePatch
NgramsRepoElement
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
))
MaybePatch
NgramsRepoElement
(
PairPatch
(
PatchMSet
NgramsTerm
)
(
Replace
ListType
))
...
@@ -555,9 +520,6 @@ newtype NgramsTablePatch = NgramsTablePatch (PatchMap NgramsTerm NgramsPatch)
...
@@ -555,9 +520,6 @@ newtype NgramsTablePatch = NgramsTablePatch (PatchMap NgramsTerm NgramsPatch)
mkNgramsTablePatch
::
Map
NgramsTerm
NgramsPatch
->
NgramsTablePatch
mkNgramsTablePatch
::
Map
NgramsTerm
NgramsPatch
->
NgramsTablePatch
mkNgramsTablePatch
=
NgramsTablePatch
.
PM
.
fromMap
mkNgramsTablePatch
=
NgramsTablePatch
.
PM
.
fromMap
instance
Serialise
NgramsTablePatch
instance
Serialise
(
PatchMap
NgramsTerm
NgramsPatch
)
instance
FromField
NgramsTablePatch
instance
FromField
NgramsTablePatch
where
where
fromField
=
fromJSONField
fromField
=
fromJSONField
...
@@ -690,9 +652,6 @@ instance Action NgramsTablePatch (Maybe NgramsTableMap) where
...
@@ -690,9 +652,6 @@ instance Action NgramsTablePatch (Maybe NgramsTableMap) where
fmap
(
execState
(
reParentNgramsTablePatch
p
))
.
fmap
(
execState
(
reParentNgramsTablePatch
p
))
.
act
(
p
^.
_NgramsTablePatch
)
act
(
p
^.
_NgramsTablePatch
)
instance
Arbitrary
NgramsTablePatch
where
arbitrary
=
NgramsTablePatch
<$>
PM
.
fromMap
<$>
arbitrary
-- Should it be less than an Lens' to preserve PatchMap's abstraction.
-- Should it be less than an Lens' to preserve PatchMap's abstraction.
-- ntp_ngrams_patches :: Lens' NgramsTablePatch (Map NgramsTerm NgramsPatch)
-- ntp_ngrams_patches :: Lens' NgramsTablePatch (Map NgramsTerm NgramsPatch)
-- ntp_ngrams_patches = _NgramsTablePatch . undefined
-- ntp_ngrams_patches = _NgramsTablePatch . undefined
...
@@ -709,8 +668,6 @@ deriveJSON (unPrefix "_v_") ''Versioned
...
@@ -709,8 +668,6 @@ deriveJSON (unPrefix "_v_") ''Versioned
makeLenses
''
V
ersioned
makeLenses
''
V
ersioned
instance
(
Typeable
a
,
ToSchema
a
)
=>
ToSchema
(
Versioned
a
)
where
instance
(
Typeable
a
,
ToSchema
a
)
=>
ToSchema
(
Versioned
a
)
where
declareNamedSchema
=
wellNamedSchema
"_v_"
declareNamedSchema
=
wellNamedSchema
"_v_"
instance
Arbitrary
a
=>
Arbitrary
(
Versioned
a
)
where
arbitrary
=
Versioned
1
<$>
arbitrary
-- TODO 1 is constant so far
------------------------------------------------------------------------
------------------------------------------------------------------------
type
Count
=
Int
type
Count
=
Int
...
@@ -724,8 +681,6 @@ deriveJSON (unPrefix "_vc_") ''VersionedWithCount
...
@@ -724,8 +681,6 @@ deriveJSON (unPrefix "_vc_") ''VersionedWithCount
makeLenses
''
V
ersionedWithCount
makeLenses
''
V
ersionedWithCount
instance
(
Typeable
a
,
ToSchema
a
)
=>
ToSchema
(
VersionedWithCount
a
)
where
instance
(
Typeable
a
,
ToSchema
a
)
=>
ToSchema
(
VersionedWithCount
a
)
where
declareNamedSchema
=
wellNamedSchema
"_vc_"
declareNamedSchema
=
wellNamedSchema
"_vc_"
instance
Arbitrary
a
=>
Arbitrary
(
VersionedWithCount
a
)
where
arbitrary
=
VersionedWithCount
1
1
<$>
arbitrary
-- TODO 1 is constant so far
toVersionedWithCount
::
Count
->
Versioned
a
->
VersionedWithCount
a
toVersionedWithCount
::
Count
->
Versioned
a
->
VersionedWithCount
a
toVersionedWithCount
count
(
Versioned
version
data_
)
=
VersionedWithCount
version
count
data_
toVersionedWithCount
count
(
Versioned
version
data_
)
=
VersionedWithCount
version
count
data_
...
@@ -749,8 +704,6 @@ instance (ToJSON s, ToJSON p) => ToJSON (Repo s p) where
...
@@ -749,8 +704,6 @@ instance (ToJSON s, ToJSON p) => ToJSON (Repo s p) where
toJSON
=
genericToJSON
$
unPrefix
"_r_"
toJSON
=
genericToJSON
$
unPrefix
"_r_"
toEncoding
=
genericToEncoding
$
unPrefix
"_r_"
toEncoding
=
genericToEncoding
$
unPrefix
"_r_"
instance
(
Serialise
s
,
Serialise
p
)
=>
Serialise
(
Repo
s
p
)
makeLenses
''
R
epo
makeLenses
''
R
epo
initRepo
::
Monoid
s
=>
Repo
s
p
initRepo
::
Monoid
s
=>
Repo
s
p
...
@@ -771,11 +724,6 @@ type RepoCmdM env err m =
...
@@ -771,11 +724,6 @@ type RepoCmdM env err m =
-- Instances
-- Instances
instance
Arbitrary
NgramsRepoElement
where
arbitrary
=
elements
$
map
ngramsElementToRepo
ns
where
NgramsTable
ns
=
mockTable
instance
FromHttpApiData
(
Map
TableNgrams
.
NgramsType
(
Versioned
NgramsTableMap
))
instance
FromHttpApiData
(
Map
TableNgrams
.
NgramsType
(
Versioned
NgramsTableMap
))
where
where
parseUrlPiece
x
=
maybeToEither
x
(
decode
$
cs
x
)
parseUrlPiece
x
=
maybeToEither
x
(
decode
$
cs
x
)
...
@@ -814,3 +762,51 @@ instance ToSchema UpdateTableNgramsCharts where
...
@@ -814,3 +762,51 @@ instance ToSchema UpdateTableNgramsCharts where
------------------------------------------------------------------------
------------------------------------------------------------------------
type
NgramsList
=
(
Map
TableNgrams
.
NgramsType
(
Versioned
NgramsTableMap
))
type
NgramsList
=
(
Map
TableNgrams
.
NgramsType
(
Versioned
NgramsTableMap
))
--
-- Serialise instances
--
instance
Serialise
ListType
instance
Serialise
NgramsRepoElement
instance
Serialise
NgramsTablePatch
instance
Serialise
(
PatchMap
NgramsTerm
NgramsPatch
)
instance
Serialise
(
MSet
NgramsTerm
)
instance
Serialise
AddRem
instance
Serialise
NgramsPatch
instance
Serialise
(
Replace
ListType
)
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMap
a
AddRem
)
instance
(
Serialise
a
,
Ord
a
)
=>
Serialise
(
PatchMSet
a
)
instance
(
Serialise
s
,
Serialise
p
)
=>
Serialise
(
Repo
s
p
)
--
-- Arbitrary instances
--
instance
Arbitrary
TabType
where
arbitrary
=
elements
[
minBound
..
maxBound
]
instance
Arbitrary
NgramsElement
where
arbitrary
=
elements
[
newNgramsElement
Nothing
"sport"
]
instance
Arbitrary
NgramsTable
where
arbitrary
=
pure
mockTable
instance
Arbitrary
OrderBy
where
arbitrary
=
elements
[
minBound
..
maxBound
]
instance
(
Ord
a
,
Arbitrary
a
)
=>
Arbitrary
(
PatchMSet
a
)
where
arbitrary
=
(
PatchMSet
.
PM
.
fromMap
)
<$>
arbitrary
instance
(
Eq
a
,
Arbitrary
a
)
=>
Arbitrary
(
Replace
a
)
where
arbitrary
=
uncurry
replace
<$>
arbitrary
-- If they happen to be equal then the patch is Keep.
instance
Arbitrary
NgramsPatch
where
arbitrary
=
frequency
[
(
9
,
NgramsPatch
<$>
arbitrary
<*>
(
replace
<$>
arbitrary
<*>
arbitrary
))
,
(
1
,
NgramsReplace
<$>
arbitrary
<*>
arbitrary
)
]
instance
Arbitrary
NgramsTablePatch
where
arbitrary
=
NgramsTablePatch
<$>
PM
.
fromMap
<$>
arbitrary
instance
Arbitrary
a
=>
Arbitrary
(
Versioned
a
)
where
arbitrary
=
Versioned
1
<$>
arbitrary
-- TODO 1 is constant so far
instance
Arbitrary
a
=>
Arbitrary
(
VersionedWithCount
a
)
where
arbitrary
=
VersionedWithCount
1
1
<$>
arbitrary
-- TODO 1 is constant so far
instance
Arbitrary
NgramsRepoElement
where
arbitrary
=
elements
$
map
ngramsElementToRepo
ns
where
NgramsTable
ns
=
mockTable
src/Gargantext/API/Node.hs
View file @
84a3f5e3
...
@@ -189,62 +189,6 @@ nodeNodeAPI p uId cId nId = withAccess (Proxy :: Proxy (NodeNodeAPI a)) Proxy uI
...
@@ -189,62 +189,6 @@ nodeNodeAPI p uId cId nId = withAccess (Proxy :: Proxy (NodeNodeAPI a)) Proxy uI
nodeNodeAPI'
::
GargServer
(
NodeNodeAPI
a
)
nodeNodeAPI'
::
GargServer
(
NodeNodeAPI
a
)
nodeNodeAPI'
=
getNodeWith
nId
p
nodeNodeAPI'
=
getNodeWith
nId
p
------------------------------------------------------------------------
-- TODO: make the NodeId type indexed by `a`, then we no longer need the proxy.
nodeAPI
::
forall
proxy
a
.
(
HyperdataC
a
,
Show
a
)
=>
proxy
a
->
AuthenticatedUser
->
NodeId
->
ServerT
(
NodeAPI
a
)
(
GargM
Env
BackendInternalError
)
nodeAPI
p
authenticatedUser
targetNode
=
withAccess
(
Proxy
::
Proxy
(
NodeAPI
a
))
Proxy
authenticatedUser
(
PathNode
targetNode
)
nodeAPI'
where
userRootId
=
RootId
$
authenticatedUser
^.
auth_node_id
nodeAPI'
::
ServerT
(
NodeAPI
a
)
(
GargM
Env
BackendInternalError
)
nodeAPI'
=
withPolicy
authenticatedUser
(
nodeChecks
targetNode
)
(
getNodeWith
targetNode
p
)
:<|>
rename
targetNode
:<|>
postNode
authenticatedUser
targetNode
:<|>
postNodeAsyncAPI
authenticatedUser
targetNode
:<|>
FrameCalcUpload
.
api
authenticatedUser
targetNode
:<|>
putNode
targetNode
:<|>
Update
.
api
targetNode
:<|>
Action
.
deleteNode
userRootId
targetNode
:<|>
getChildren
targetNode
p
-- TODO gather it
:<|>
tableApi
targetNode
:<|>
apiNgramsTableCorpus
targetNode
:<|>
catApi
targetNode
:<|>
scoreApi
targetNode
:<|>
Search
.
api
targetNode
:<|>
Share
.
api
userRootId
targetNode
-- Pairing Tools
:<|>
pairWith
targetNode
:<|>
pairs
targetNode
:<|>
getPair
targetNode
-- VIZ
:<|>
scatterApi
targetNode
:<|>
chartApi
targetNode
:<|>
pieApi
targetNode
:<|>
treeApi
targetNode
:<|>
phyloAPI
targetNode
:<|>
moveNode
userRootId
targetNode
-- :<|> nodeAddAPI id'
-- :<|> postUpload id'
:<|>
Share
.
unPublish
targetNode
:<|>
fileApi
targetNode
:<|>
fileAsyncApi
authenticatedUser
targetNode
:<|>
DFWN
.
api
authenticatedUser
targetNode
:<|>
DocumentUpload
.
api
targetNode
------------------------------------------------------------------------
------------------------------------------------------------------------
data
RenameNode
=
RenameNode
{
r_name
::
Text
}
data
RenameNode
=
RenameNode
{
r_name
::
Text
}
deriving
(
Generic
)
deriving
(
Generic
)
...
@@ -374,5 +318,59 @@ instance ToSchema RenameNode
...
@@ -374,5 +318,59 @@ instance ToSchema RenameNode
instance
Arbitrary
RenameNode
where
instance
Arbitrary
RenameNode
where
arbitrary
=
elements
[
RenameNode
"test"
]
arbitrary
=
elements
[
RenameNode
"test"
]
------------------------------------------------------------------------
-- TODO: make the NodeId type indexed by `a`, then we no longer need the proxy.
nodeAPI
::
forall
proxy
a
.
(
HyperdataC
a
,
Show
a
,
MimeUnrender
JSON
a
)
=>
proxy
a
->
AuthenticatedUser
->
NodeId
->
ServerT
(
NodeAPI
a
)
(
GargM
Env
BackendInternalError
)
nodeAPI
p
authenticatedUser
targetNode
=
withAccess
(
Proxy
::
Proxy
(
NodeAPI
a
))
Proxy
authenticatedUser
(
PathNode
targetNode
)
nodeAPI'
where
userRootId
=
RootId
$
authenticatedUser
^.
auth_node_id
nodeAPI'
::
ServerT
(
NodeAPI
a
)
(
GargM
Env
BackendInternalError
)
nodeAPI'
=
withPolicy
authenticatedUser
(
nodeChecks
targetNode
)
(
getNodeWith
targetNode
p
)
:<|>
rename
targetNode
:<|>
postNode
authenticatedUser
targetNode
:<|>
postNodeAsyncAPI
authenticatedUser
targetNode
:<|>
FrameCalcUpload
.
api
authenticatedUser
targetNode
:<|>
putNode
targetNode
:<|>
Update
.
api
targetNode
:<|>
Action
.
deleteNode
userRootId
targetNode
:<|>
getChildren
targetNode
p
-- TODO gather it
:<|>
tableApi
targetNode
:<|>
apiNgramsTableCorpus
targetNode
:<|>
catApi
targetNode
:<|>
scoreApi
targetNode
:<|>
Search
.
api
targetNode
:<|>
Share
.
api
userRootId
targetNode
-- Pairing Tools
:<|>
pairWith
targetNode
:<|>
pairs
targetNode
:<|>
getPair
targetNode
-- VIZ
:<|>
scatterApi
targetNode
:<|>
chartApi
targetNode
:<|>
pieApi
targetNode
:<|>
treeApi
targetNode
:<|>
phyloAPI
targetNode
:<|>
moveNode
userRootId
targetNode
-- :<|> nodeAddAPI id'
-- :<|> postUpload id'
:<|>
Share
.
unPublish
targetNode
:<|>
fileApi
targetNode
:<|>
fileAsyncApi
authenticatedUser
targetNode
:<|>
DFWN
.
api
authenticatedUser
targetNode
:<|>
DocumentUpload
.
api
targetNode
-------------------------------------------------------------
src/Gargantext/API/Node/Document/Export/Types.hs
View file @
84a3f5e3
...
@@ -94,6 +94,6 @@ type API = Summary "Document Export"
...
@@ -94,6 +94,6 @@ type API = Summary "Document Export"
:<|>
"csv"
:<|>
"csv"
:>
Get
'[
P
lainText
]
(
Headers
'[
S
ervant
.
Header
"Content-Disposition"
Text
]
Text
))
-- [Document])
:>
Get
'[
P
lainText
]
(
Headers
'[
S
ervant
.
Header
"Content-Disposition"
Text
]
Text
))
-- [Document])
$
(
deriveJSON
(
unPrefix
"_de_"
)
''
D
ocumentExport
)
$
(
deriveJSON
(
unPrefix
"_d_"
)
''
D
ocument
)
$
(
deriveJSON
(
unPrefix
"_ng_"
)
''
N
grams
)
$
(
deriveJSON
(
unPrefix
"_ng_"
)
''
N
grams
)
$
(
deriveJSON
(
unPrefix
"_d_"
)
''
D
ocument
)
$
(
deriveJSON
(
unPrefix
"_de_"
)
''
D
ocumentExport
)
src/Gargantext/Core/NodeStory.hs
View file @
84a3f5e3
...
@@ -701,7 +701,7 @@ clearHistory (NodeStory ns) = NodeStory $ ns & (traverse . a_history) .~ emptyHi
...
@@ -701,7 +701,7 @@ clearHistory (NodeStory ns) = NodeStory $ ns & (traverse . a_history) .~ emptyHi
currentVersion
::
(
HasNodeStory
env
err
m
)
=>
ListId
->
m
Version
currentVersion
::
(
HasNodeStory
env
err
m
)
=>
ListId
->
m
Version
currentVersion
listId
=
do
currentVersion
listId
=
do
pool
<-
view
connPool
pool
<-
view
connPool
nls
<-
withResource
pool
$
\
c
->
liftBase
$
getNodeStory
c
listId
nls
<-
liftBase
$
withResource
pool
$
\
c
->
liftBase
$
getNodeStory
c
listId
pure
$
nls
^.
unNodeStory
.
at
listId
.
_Just
.
a_version
pure
$
nls
^.
unNodeStory
.
at
listId
.
_Just
.
a_version
...
@@ -711,7 +711,7 @@ currentVersion listId = do
...
@@ -711,7 +711,7 @@ currentVersion listId = do
fixNodeStoryVersions
::
(
HasNodeStory
env
err
m
)
=>
m
()
fixNodeStoryVersions
::
(
HasNodeStory
env
err
m
)
=>
m
()
fixNodeStoryVersions
=
do
fixNodeStoryVersions
=
do
pool
<-
view
connPool
pool
<-
view
connPool
_
<-
withResource
pool
$
\
c
->
liftBase
$
PGS
.
withTransaction
c
$
do
_
<-
liftBase
$
withResource
pool
$
\
c
->
liftBase
$
PGS
.
withTransaction
c
$
do
nIds
<-
runPGSQuery
c
[
sql
|
SELECT id FROM nodes WHERE ?
|]
(
PGS
.
Only
True
)
::
IO
[
PGS
.
Only
Int64
]
nIds
<-
runPGSQuery
c
[
sql
|
SELECT id FROM nodes WHERE ?
|]
(
PGS
.
Only
True
)
::
IO
[
PGS
.
Only
Int64
]
-- printDebug "[fixNodeStoryVersions] nIds" nIds
-- printDebug "[fixNodeStoryVersions] nIds" nIds
mapM_
(
\
(
PGS
.
Only
nId
)
->
do
mapM_
(
\
(
PGS
.
Only
nId
)
->
do
...
...
src/Gargantext/Core/Text/Corpus/Parsers/Date.hs
View file @
84a3f5e3
...
@@ -24,7 +24,7 @@ module Gargantext.Core.Text.Corpus.Parsers.Date
...
@@ -24,7 +24,7 @@ module Gargantext.Core.Text.Corpus.Parsers.Date
import
Data.Aeson
(
toJSON
,
Value
)
import
Data.Aeson
(
toJSON
,
Value
)
import
Data.Aeson
qualified
as
Json
import
Data.Aeson
qualified
as
Json
import
Data.
HashMap.Strict
as
H
M
hiding
(
map
)
import
Data.
Aeson.KeyMap
as
K
M
hiding
(
map
)
import
Data.HashSet
qualified
as
HashSet
import
Data.HashSet
qualified
as
HashSet
import
Data.List
qualified
as
List
import
Data.List
qualified
as
List
import
Data.Text
(
unpack
,
splitOn
,
replace
)
import
Data.Text
(
unpack
,
splitOn
,
replace
)
...
@@ -184,7 +184,7 @@ getTimeValue rt = case head rt of
...
@@ -184,7 +184,7 @@ getTimeValue rt = case head rt of
extractValue
::
Maybe
Value
->
Maybe
Text
extractValue
::
Maybe
Value
->
Maybe
Text
extractValue
(
Just
(
Json
.
Object
object
))
=
extractValue
(
Just
(
Json
.
Object
object
))
=
case
H
M
.
lookup
"value"
object
of
case
K
M
.
lookup
"value"
object
of
Just
(
Json
.
String
date
)
->
Just
date
Just
(
Json
.
String
date
)
->
Just
date
_
->
Nothing
_
->
Nothing
extractValue
_
=
Nothing
extractValue
_
=
Nothing
...
...
src/Gargantext/Core/Text/Terms/Eleve.hs
View file @
84a3f5e3
...
@@ -34,10 +34,11 @@ Notes for current implementation:
...
@@ -34,10 +34,11 @@ Notes for current implementation:
{-# OPTIONS_GHC -fno-warn-deprecations #-}
{-# OPTIONS_GHC -fno-warn-deprecations #-}
{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE ConstraintKinds #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
module
Gargantext.Core.Text.Terms.Eleve
where
module
Gargantext.Core.Text.Terms.Eleve
where
...
...
src/Gargantext/Core/Text/Terms/Mono/Token/En.hs
View file @
84a3f5e3
...
@@ -143,11 +143,11 @@ whitespace :: Tokenizer
...
@@ -143,11 +143,11 @@ whitespace :: Tokenizer
whitespace
xs
=
E
[
Right
w
|
w
<-
T
.
words
xs
]
whitespace
xs
=
E
[
Right
w
|
w
<-
T
.
words
xs
]
instance
Monad
(
EitherList
a
)
where
instance
Monad
(
EitherList
a
)
where
return
x
=
E
[
Right
x
]
return
=
pure
E
xs
>>=
f
=
E
$
concatMap
(
either
(
return
.
Left
)
(
unE
.
f
))
xs
E
xs
>>=
f
=
E
$
concatMap
(
either
(
return
.
Left
)
(
unE
.
f
))
xs
instance
Applicative
(
EitherList
a
)
where
instance
Applicative
(
EitherList
a
)
where
pure
=
pure
pure
x
=
E
[
Right
x
]
f
<*>
x
=
f
`
ap
`
x
f
<*>
x
=
f
`
ap
`
x
instance
Functor
(
EitherList
a
)
where
instance
Functor
(
EitherList
a
)
where
...
...
src/Gargantext/Core/Types/Phylo.hs
View file @
84a3f5e3
...
@@ -216,43 +216,6 @@ data ObjectData =
...
@@ -216,43 +216,6 @@ data ObjectData =
|
Layer
!
GvId
!
GraphDataData
!
LayerData
|
Layer
!
GvId
!
GraphDataData
!
LayerData
deriving
(
Show
,
Eq
,
Generic
)
deriving
(
Show
,
Eq
,
Generic
)
instance
ToJSON
ObjectData
where
toJSON
=
\
case
GroupToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
BranchToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
PeriodToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
Layer
gvid
graphData
nodeTypeData
->
mkObject
gvid
(
Right
graphData
)
nodeTypeData
instance
FromJSON
ObjectData
where
parseJSON
=
withObject
"ObjectData"
$
\
o
->
do
_gvid
<-
o
.:
"_gvid"
-- try to parse the graph data first. If we succeed, then we are dealing with
-- the 'Layer', otherwise we the rest, but for the rest we can avoid re-parsing
-- the 'NodeCommonData' every time.
case
parseMaybe
@
_
@
GraphDataData
parseJSON
(
Object
o
)
of
Nothing
->
do
commonData
<-
parseJSON
(
Object
o
)
((
GroupToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
))
<|>
(
BranchToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
))
<|>
(
PeriodToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
)))
Just
gd
->
Layer
<$>
pure
_gvid
<*>
pure
gd
<*>
parseJSON
(
Object
o
)
mkObject
::
ToJSON
a
=>
GvId
->
Either
NodeCommonData
GraphDataData
->
a
->
Value
mkObject
gvid
commonData
objectTypeData
=
let
commonDataJSON
=
either
toJSON
toJSON
commonData
objectTypeDataJSON
=
toJSON
objectTypeData
header
=
object
$
[
"_gvid"
.=
toJSON
gvid
]
in
case
(
commonDataJSON
,
objectTypeDataJSON
,
header
)
of
(
Object
hdr
,
Object
cdJSON
,
Object
etDataJSON
)
->
Object
$
hdr
<>
cdJSON
<>
etDataJSON
_
->
panicTrace
"[Gargantext.Core.Types.Phylo.mkObject] impossible: commonData, header or objectTypeDataJSON didn't convert back to JSON Object."
data
GroupToNodeData
data
GroupToNodeData
=
GroupToNodeData
=
GroupToNodeData
{
_gtn_bId
::
Text
{
_gtn_bId
::
Text
...
@@ -474,17 +437,23 @@ data BranchToGroupData
...
@@ -474,17 +437,23 @@ data BranchToGroupData
,
_btg_style
::
Maybe
Text
,
_btg_style
::
Maybe
Text
}
deriving
(
Show
,
Eq
,
Generic
)
}
deriving
(
Show
,
Eq
,
Generic
)
-- | Lenses
makeLenses
''
P
hylo
makeLenses
''
P
hyloPeriod
makeLenses
''
P
hyloLevel
makeLenses
''
P
hyloGroup
-- | JSON instances
-- | JSON instances
$
(
deriveJSON
(
unPrefix
"_phylo_"
)
''
P
hylo
)
instance
ToJSON
GvId
where
$
(
deriveJSON
(
unPrefix
"_phylo_Period"
)
''
P
hyloPeriod
)
toJSON
GvId
{
..
}
=
toJSON
_GvId
$
(
deriveJSON
(
unPrefix
"_phylo_Level"
)
''
P
hyloLevel
)
instance
FromJSON
GvId
where
$
(
deriveJSON
(
unPrefix
"_phylo_Group"
)
''
P
hyloGroup
)
parseJSON
v
=
GvId
<$>
parseJSON
v
-- /NOTE/ We need to define /after/ the JSON istance for 'GvId' due to GHC stage limitation.
mkObject
::
ToJSON
a
=>
GvId
->
Either
NodeCommonData
GraphDataData
->
a
->
Value
mkObject
gvid
commonData
objectTypeData
=
let
commonDataJSON
=
either
toJSON
toJSON
commonData
objectTypeDataJSON
=
toJSON
objectTypeData
header
=
object
$
[
"_gvid"
.=
toJSON
gvid
]
in
case
(
commonDataJSON
,
objectTypeDataJSON
,
header
)
of
(
Object
hdr
,
Object
cdJSON
,
Object
etDataJSON
)
->
Object
$
hdr
<>
cdJSON
<>
etDataJSON
_
->
panicTrace
"[Gargantext.Core.Types.Phylo.mkObject] impossible: commonData, header or objectTypeDataJSON didn't convert back to JSON Object."
instance
ToJSON
GraphData
where
instance
ToJSON
GraphData
where
toJSON
=
mkGraphData
toJSON
=
mkGraphData
...
@@ -512,11 +481,6 @@ instance FromJSON GraphData where
...
@@ -512,11 +481,6 @@ instance FromJSON GraphData where
_gd_data
<-
parseJSON
(
Object
o
)
_gd_data
<-
parseJSON
(
Object
o
)
pure
GraphData
{
..
}
pure
GraphData
{
..
}
instance
ToJSON
GvId
where
toJSON
GvId
{
..
}
=
toJSON
_GvId
instance
FromJSON
GvId
where
parseJSON
v
=
GvId
<$>
parseJSON
v
instance
ToJSON
EdgeData
where
instance
ToJSON
EdgeData
where
toJSON
=
\
case
toJSON
=
\
case
GroupToAncestor
gvid
commonData
edgeTypeData
GroupToAncestor
gvid
commonData
edgeTypeData
...
@@ -608,6 +572,38 @@ instance FromJSON BranchToGroupData where
...
@@ -608,6 +572,38 @@ instance FromJSON BranchToGroupData where
_btg_style
<-
o
.:?
"style"
_btg_style
<-
o
.:?
"style"
pure
BranchToGroupData
{
..
}
pure
BranchToGroupData
{
..
}
instance
ToJSON
ObjectData
where
toJSON
=
\
case
GroupToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
BranchToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
PeriodToNode
gvid
commonData
nodeTypeData
->
mkObject
gvid
(
Left
commonData
)
nodeTypeData
Layer
gvid
graphData
nodeTypeData
->
mkObject
gvid
(
Right
graphData
)
nodeTypeData
instance
FromJSON
ObjectData
where
parseJSON
=
withObject
"ObjectData"
$
\
o
->
do
_gvid
<-
o
.:
"_gvid"
-- try to parse the graph data first. If we succeed, then we are dealing with
-- the 'Layer', otherwise we the rest, but for the rest we can avoid re-parsing
-- the 'NodeCommonData' every time.
case
parseMaybe
@
_
@
GraphDataData
parseJSON
(
Object
o
)
of
Nothing
->
do
commonData
<-
parseJSON
(
Object
o
)
((
GroupToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
))
<|>
(
BranchToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
))
<|>
(
PeriodToNode
<$>
pure
_gvid
<*>
pure
commonData
<*>
parseJSON
(
Object
o
)))
Just
gd
->
Layer
<$>
pure
_gvid
<*>
pure
gd
<*>
parseJSON
(
Object
o
)
$
(
deriveJSON
(
unPrefix
"_phylo_Group"
)
''
P
hyloGroup
)
$
(
deriveJSON
(
unPrefix
"_phylo_Level"
)
''
P
hyloLevel
)
$
(
deriveJSON
(
unPrefix
"_phylo_Period"
)
''
P
hyloPeriod
)
$
(
deriveJSON
(
unPrefix
"_phylo_"
)
''
P
hylo
)
-- | ToSchema instances
-- | ToSchema instances
instance
ToSchema
Phylo
where
instance
ToSchema
Phylo
where
...
@@ -637,7 +633,9 @@ instance ToSchema GraphDataData where
...
@@ -637,7 +633,9 @@ instance ToSchema GraphDataData where
instance
ToSchema
GraphData
where
instance
ToSchema
GraphData
where
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_gd_"
)
declareNamedSchema
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_gd_"
)
-- | Arbitrary instances
--
-- Arbitrary instances
--
instance
Arbitrary
LayerData
where
instance
Arbitrary
LayerData
where
arbitrary
=
LayerData
<$>
arbitrary
arbitrary
=
LayerData
<$>
arbitrary
instance
Arbitrary
NodeCommonData
where
instance
Arbitrary
NodeCommonData
where
...
@@ -723,3 +721,13 @@ instance Arbitrary GraphDataData where
...
@@ -723,3 +721,13 @@ instance Arbitrary GraphDataData where
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
--
-- Lenses
--
makeLenses
''
P
hylo
makeLenses
''
P
hyloPeriod
makeLenses
''
P
hyloLevel
makeLenses
''
P
hyloGroup
src/Gargantext/Core/Viz/LegacyPhylo.hs
View file @
84a3f5e3
...
@@ -475,38 +475,38 @@ makeLenses ''PhyloEdge
...
@@ -475,38 +475,38 @@ makeLenses ''PhyloEdge
------------------------
------------------------
$
(
deriveJSON
(
unPrefix
"_phylo_"
)
''
P
hylo
)
$
(
deriveJSON
(
unPrefix
"_phylo_group"
)
''
P
hyloGroup
)
$
(
deriveJSON
(
unPrefix
"_phylo_level"
)
''
P
hyloLevel
)
$
(
deriveJSON
(
unPrefix
"_phylo_foundations"
)
''
P
hyloFoundations
)
$
(
deriveJSON
(
unPrefix
"_phylo_foundations"
)
''
P
hyloFoundations
)
$
(
deriveJSON
(
unPrefix
"_phylo_period"
)
''
P
hyloPeriod
)
$
(
deriveJSON
(
unPrefix
"_phylo_period"
)
''
P
hyloPeriod
)
$
(
deriveJSON
(
unPrefix
"_phylo_level"
)
''
P
hyloLevel
)
$
(
deriveJSON
(
unPrefix
"_phylo_group"
)
''
P
hyloGroup
)
$
(
deriveJSON
(
unPrefix
"_phyloFis_"
)
''
P
hyloFis
)
$
(
deriveJSON
(
unPrefix
"_phyloFis_"
)
''
P
hyloFis
)
--
--
$
(
deriveJSON
(
unPrefix
"_software_"
)
''
S
oftware
)
$
(
deriveJSON
(
unPrefix
"_lb_"
)
''
L
BParams
)
$
(
deriveJSON
(
unPrefix
"_phyloParam_"
)
''
P
hyloParam
)
$
(
deriveJSON
(
unPrefix
"_sb_"
)
''
S
BParams
)
--
$
(
deriveJSON
(
unPrefix
"_fis_"
)
''
F
isParams
)
$
(
deriveJSON
(
unPrefix
"_hamming_"
)
''
H
ammingParams
)
$
(
deriveJSON
(
unPrefix
"_wlj_"
)
''
W
LJParams
)
--
--
$
(
deriveJSON
defaultOptions
''
F
ilter
)
$
(
deriveJSON
defaultOptions
''
F
ilter
)
$
(
deriveJSON
defaultOptions
''
M
etric
)
$
(
deriveJSON
defaultOptions
''
M
etric
)
$
(
deriveJSON
defaultOptions
''
C
luster
)
$
(
deriveJSON
defaultOptions
''
P
roximity
)
$
(
deriveJSON
defaultOptions
''
P
roximity
)
--
$
(
deriveJSON
(
unPrefix
"_fis_"
)
''
F
isParams
)
$
(
deriveJSON
(
unPrefix
"_hamming_"
)
''
H
ammingParams
)
$
(
deriveJSON
(
unPrefix
"_louvain_"
)
''
L
ouvainParams
)
$
(
deriveJSON
(
unPrefix
"_louvain_"
)
''
L
ouvainParams
)
$
(
deriveJSON
(
unPrefix
"_rc_"
)
''
R
CParams
)
$
(
deriveJSON
(
unPrefix
"_rc_"
)
''
R
CParams
)
$
(
deriveJSON
(
unPrefix
"_wlj_"
)
''
W
LJParams
)
$
(
deriveJSON
defaultOptions
''
C
luster
)
$
(
deriveJSON
(
unPrefix
"_q_"
)
''
P
hyloQueryBuild
)
--
--
$
(
deriveJSON
(
unPrefix
"_lb_"
)
''
L
BParams
)
$
(
deriveJSON
(
unPrefix
"_software_"
)
''
S
oftware
)
$
(
deriveJSON
(
unPrefix
"_sb_"
)
''
S
BParams
)
$
(
deriveJSON
(
unPrefix
"_phyloParam_"
)
''
P
hyloParam
)
$
(
deriveJSON
(
unPrefix
"_phylo_"
)
''
P
hylo
)
--
--
$
(
deriveJSON
(
unPrefix
"_q_"
)
''
P
hyloQueryBuild
)
$
(
deriveJSON
(
unPrefix
"_pv_"
)
''
P
hyloView
)
$
(
deriveJSON
(
unPrefix
"_pb_"
)
''
P
hyloBranch
)
$
(
deriveJSON
(
unPrefix
"_pb_"
)
''
P
hyloBranch
)
$
(
deriveJSON
(
unPrefix
"_pe_"
)
''
P
hyloEdge
)
$
(
deriveJSON
(
unPrefix
"_pn_"
)
''
P
hyloNode
)
$
(
deriveJSON
defaultOptions
''
F
iliation
)
$
(
deriveJSON
defaultOptions
''
F
iliation
)
$
(
deriveJSON
(
unPrefix
"_pn_"
)
''
P
hyloNode
)
$
(
deriveJSON
defaultOptions
''
E
dgeType
)
$
(
deriveJSON
defaultOptions
''
E
dgeType
)
$
(
deriveJSON
(
unPrefix
"_pe_"
)
''
P
hyloEdge
)
$
(
deriveJSON
(
unPrefix
"_pv_"
)
''
P
hyloView
)
---------------------------
---------------------------
-- | Swagger instances | --
-- | Swagger instances | --
...
...
src/Gargantext/Core/Viz/Phylo.hs
View file @
84a3f5e3
...
@@ -625,9 +625,6 @@ makeLenses ''PhyloBranch
...
@@ -625,9 +625,6 @@ makeLenses ''PhyloBranch
-- | JSON instances | --
-- | JSON instances | --
------------------------
------------------------
instance
FromJSON
Phylo
instance
ToJSON
Phylo
instance
FromJSON
PhyloSources
instance
FromJSON
PhyloSources
instance
ToJSON
PhyloSources
instance
ToJSON
PhyloSources
...
@@ -651,6 +648,9 @@ instance ToJSON PhyloGroup
...
@@ -651,6 +648,9 @@ instance ToJSON PhyloGroup
$
(
deriveJSON
(
unPrefix
"_foundations_"
)
''
P
hyloFoundations
)
$
(
deriveJSON
(
unPrefix
"_foundations_"
)
''
P
hyloFoundations
)
instance
FromJSON
Phylo
instance
ToJSON
Phylo
-- NFData instances
-- NFData instances
instance
NFData
CorpusParser
instance
NFData
CorpusParser
...
@@ -677,3 +677,4 @@ instance NFData Order
...
@@ -677,3 +677,4 @@ instance NFData Order
instance
NFData
Sort
instance
NFData
Sort
instance
NFData
Tagger
instance
NFData
Tagger
instance
NFData
PhyloLabel
instance
NFData
PhyloLabel
src/Gargantext/Core/Viz/Phylo/API/Tools.hs
View file @
84a3f5e3
...
@@ -114,7 +114,7 @@ corpusIdtoDocuments timeUnit corpusId = do
...
@@ -114,7 +114,7 @@ corpusIdtoDocuments timeUnit corpusId = do
docs
<-
selectDocNodes
corpusId
docs
<-
selectDocNodes
corpusId
lId
<-
defaultList
corpusId
lId
<-
defaultList
corpusId
termList
<-
getTermList
lId
MapTerm
NgramsTerms
termList
<-
getTermList
lId
MapTerm
NgramsTerms
corpus_node
<-
getNodeWith
corpusId
(
Proxy
@
HyperdataCorpus
)
corpus_node
<-
getNodeWith
corpusId
(
Proxy
@
HyperdataCorpus
)
let
corpusLang
=
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
let
corpusLang
=
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
let
patterns
=
case
termList
of
let
patterns
=
case
termList
of
...
...
src/Gargantext/Core/Viz/Phylo/Legacy/LegacyMain.hs
View file @
84a3f5e3
...
@@ -46,7 +46,7 @@ flowPhylo :: (HasNodeStory env err m, HasDBid NodeType)
...
@@ -46,7 +46,7 @@ flowPhylo :: (HasNodeStory env err m, HasDBid NodeType)
->
m
Phylo
->
m
Phylo
flowPhylo
cId
=
do
flowPhylo
cId
=
do
corpus_node
<-
getNodeWith
cId
(
Proxy
@
HyperdataCorpus
)
corpus_node
<-
getNodeWith
cId
(
Proxy
@
HyperdataCorpus
)
let
lang
=
withDefaultLanguage
$
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
let
lang
=
withDefaultLanguage
$
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
list'
<-
defaultList
cId
list'
<-
defaultList
cId
termList
<-
HashMap
.
toList
<$>
getTermsWith
(
Text
.
words
.
unNgramsTerm
)
[
list'
]
NgramsTerms
(
Set
.
singleton
MapTerm
)
termList
<-
HashMap
.
toList
<$>
getTermsWith
(
Text
.
words
.
unNgramsTerm
)
[
list'
]
NgramsTerms
(
Set
.
singleton
MapTerm
)
...
...
src/Gargantext/Database/Action/Flow.hs
View file @
84a3f5e3
...
@@ -659,7 +659,7 @@ reIndexWith :: ( HasNodeStory env err m )
...
@@ -659,7 +659,7 @@ reIndexWith :: ( HasNodeStory env err m )
->
m
()
->
m
()
reIndexWith
cId
lId
nt
lts
=
do
reIndexWith
cId
lId
nt
lts
=
do
-- printDebug "(cId,lId,nt,lts)" (cId, lId, nt, lts)
-- printDebug "(cId,lId,nt,lts)" (cId, lId, nt, lts)
corpus_node
<-
getNodeWith
cId
(
Proxy
@
HyperdataCorpus
)
corpus_node
<-
getNodeWith
cId
(
Proxy
@
HyperdataCorpus
)
let
corpusLang
=
withDefaultLanguage
$
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
let
corpusLang
=
withDefaultLanguage
$
view
(
node_hyperdata
.
to
_hc_lang
)
corpus_node
-- Getting [NgramsTerm]
-- Getting [NgramsTerm]
...
...
src/Gargantext/Database/Admin/Types/Hyperdata/Contact.hs
View file @
84a3f5e3
...
@@ -193,6 +193,20 @@ instance Arbitrary HyperdataContact where
...
@@ -193,6 +193,20 @@ instance Arbitrary HyperdataContact where
-- | Specific Gargantext instance
-- | Specific Gargantext instance
instance
Hyperdata
HyperdataContact
instance
Hyperdata
HyperdataContact
-- | All lenses
makeLenses
''
C
ontactWho
makeLenses
''
C
ontactWhere
makeLenses
''
C
ontactTouch
makeLenses
''
C
ontactMetaData
makeLenses
''
H
yperdataContact
-- | All Json instances
$
(
deriveJSON
(
unPrefix
"_ct_"
)
''
C
ontactTouch
)
$
(
deriveJSON
(
unPrefix
"_cw_"
)
''
C
ontactWho
)
$
(
deriveJSON
(
unPrefix
"_cw_"
)
''
C
ontactWhere
)
$
(
deriveJSON
(
unPrefix
"_cm_"
)
''
C
ontactMetaData
)
$
(
deriveJSON
(
unPrefix
"_hc_"
)
''
H
yperdataContact
)
-- | Database (Posgresql-simple instance)
-- | Database (Posgresql-simple instance)
instance
FromField
HyperdataContact
where
instance
FromField
HyperdataContact
where
fromField
=
fromField'
fromField
=
fromField'
...
@@ -207,16 +221,3 @@ instance DefaultFromField (Nullable SqlJsonb) HyperdataContact where
...
@@ -207,16 +221,3 @@ instance DefaultFromField (Nullable SqlJsonb) HyperdataContact where
-- | All lenses
makeLenses
''
C
ontactWho
makeLenses
''
C
ontactWhere
makeLenses
''
C
ontactTouch
makeLenses
''
C
ontactMetaData
makeLenses
''
H
yperdataContact
-- | All Json instances
$
(
deriveJSON
(
unPrefix
"_cw_"
)
''
C
ontactWho
)
$
(
deriveJSON
(
unPrefix
"_cw_"
)
''
C
ontactWhere
)
$
(
deriveJSON
(
unPrefix
"_ct_"
)
''
C
ontactTouch
)
$
(
deriveJSON
(
unPrefix
"_cm_"
)
''
C
ontactMetaData
)
$
(
deriveJSON
(
unPrefix
"_hc_"
)
''
H
yperdataContact
)
src/Gargantext/Database/Admin/Types/Hyperdata/Document.hs
View file @
84a3f5e3
...
@@ -73,8 +73,6 @@ defaultHyperdataDocument = case decode docExample of
...
@@ -73,8 +73,6 @@ defaultHyperdataDocument = case decode docExample of
data
StatusV3
=
StatusV3
{
statusV3_error
::
!
(
Maybe
Text
)
data
StatusV3
=
StatusV3
{
statusV3_error
::
!
(
Maybe
Text
)
,
statusV3_action
::
!
(
Maybe
Text
)
,
statusV3_action
::
!
(
Maybe
Text
)
}
deriving
(
Show
,
Generic
)
}
deriving
(
Show
,
Generic
)
$
(
deriveJSON
(
unPrefix
"statusV3_"
)
''
S
tatusV3
)
------------------------------------------------------------------------
------------------------------------------------------------------------
data
HyperdataDocumentV3
=
HyperdataDocumentV3
{
_hdv3_publication_day
::
!
(
Maybe
Int
)
data
HyperdataDocumentV3
=
HyperdataDocumentV3
{
_hdv3_publication_day
::
!
(
Maybe
Int
)
...
@@ -140,12 +138,25 @@ arbitraryHyperdataDocuments =
...
@@ -140,12 +138,25 @@ arbitraryHyperdataDocuments =
instance
Hyperdata
HyperdataDocument
instance
Hyperdata
HyperdataDocument
instance
Hyperdata
HyperdataDocumentV3
instance
Hyperdata
HyperdataDocumentV3
------------------------------------------------------------------------
------------------------------------------------------------------------
$
(
makeLenses
''
H
yperdataDocument
)
-- $(deriveJSON (unPrefix "_hd_") ''HyperdataDocument)
makePrisms
''
H
yperdataDocument
instance
ToSchema
HyperdataDocument
where
declareNamedSchema
proxy
=
genericDeclareNamedSchema
(
unPrefixSwagger
"_hd_"
)
proxy
&
mapped
.
schema
.
description
?~
"Document Hyperdata"
&
mapped
.
schema
.
example
?~
toJSON
defaultHyperdataDocument
$
(
makeLenses
''
H
yperdataDocumentV3
)
{-
-- | For now HyperdataDocumentV3 is not exposed with the API
instance ToSchema HyperdataDocumentV3 where
declareNamedSchema proxy =
genericDeclareNamedSchema (unPrefixSwagger "hyperdataDocumentV3_") proxy
& mapped.schema.description ?~ "Document Hyperdata for Garg V3"
& mapped.schema.example ?~ toJSON defaultHyperdataDocumentV3
-}
-- $(deriveJSON (unPrefix "_hd_") ''HyperdataDocument)
--
-- JSON instances
--
instance
FromJSON
HyperdataDocument
instance
FromJSON
HyperdataDocument
where
where
...
@@ -167,24 +178,13 @@ instance ToJSON HyperdataDocument
...
@@ -167,24 +178,13 @@ instance ToJSON HyperdataDocument
$
(
deriveJSON
(
unPrefix
"statusV3_"
)
''
S
tatusV3
)
$
(
deriveJSON
(
unPrefix
"_hdv3_"
)
''
H
yperdataDocumentV3
)
$
(
deriveJSON
(
unPrefix
"_hdv3_"
)
''
H
yperdataDocumentV3
)
instance
ToSchema
HyperdataDocument
where
--
declareNamedSchema
proxy
=
-- FromField/ToField instances
genericDeclareNamedSchema
(
unPrefixSwagger
"_hd_"
)
proxy
--
&
mapped
.
schema
.
description
?~
"Document Hyperdata"
&
mapped
.
schema
.
example
?~
toJSON
defaultHyperdataDocument
{-
-- | For now HyperdataDocumentV3 is not exposed with the API
instance ToSchema HyperdataDocumentV3 where
declareNamedSchema proxy =
genericDeclareNamedSchema (unPrefixSwagger "hyperdataDocumentV3_") proxy
& mapped.schema.description ?~ "Document Hyperdata for Garg V3"
& mapped.schema.example ?~ toJSON defaultHyperdataDocumentV3
-}
------------------------------------------------------------------------
instance
FromField
HyperdataDocument
instance
FromField
HyperdataDocument
where
where
fromField
=
fromField'
fromField
=
fromField'
...
@@ -193,14 +193,12 @@ instance FromField HyperdataDocumentV3
...
@@ -193,14 +193,12 @@ instance FromField HyperdataDocumentV3
where
where
fromField
=
fromField'
fromField
=
fromField'
-------
instance
ToField
HyperdataDocument
where
instance
ToField
HyperdataDocument
where
toField
=
toJSONField
toField
=
toJSONField
instance
ToField
HyperdataDocumentV3
where
instance
ToField
HyperdataDocumentV3
where
toField
=
toJSONField
toField
=
toJSONField
------------------------------------------------------------------------
instance
DefaultFromField
SqlJsonb
HyperdataDocument
instance
DefaultFromField
SqlJsonb
HyperdataDocument
where
where
defaultFromField
=
fromPGSFromField
defaultFromField
=
fromPGSFromField
...
@@ -208,4 +206,10 @@ instance DefaultFromField SqlJsonb HyperdataDocument
...
@@ -208,4 +206,10 @@ instance DefaultFromField SqlJsonb HyperdataDocument
instance
DefaultFromField
SqlJsonb
HyperdataDocumentV3
instance
DefaultFromField
SqlJsonb
HyperdataDocumentV3
where
where
defaultFromField
=
fromPGSFromField
defaultFromField
=
fromPGSFromField
------------------------------------------------------------------------
--
-- Lenses
--
$
(
makeLenses
''
H
yperdataDocument
)
makePrisms
''
H
yperdataDocument
$
(
makeLenses
''
H
yperdataDocumentV3
)
src/Gargantext/Database/Admin/Types/Hyperdata/User.hs
View file @
84a3f5e3
...
@@ -98,9 +98,9 @@ makeLenses ''HyperdataPrivate
...
@@ -98,9 +98,9 @@ makeLenses ''HyperdataPrivate
makeLenses
''
H
yperdataPublic
makeLenses
''
H
yperdataPublic
-- | All Json instances
-- | All Json instances
$
(
deriveJSON
(
unPrefix
"_hu_"
)
''
H
yperdataUser
)
$
(
deriveJSON
(
unPrefix
"_hpr_"
)
''
H
yperdataPrivate
)
$
(
deriveJSON
(
unPrefix
"_hpr_"
)
''
H
yperdataPrivate
)
$
(
deriveJSON
(
unPrefix
"_hpu_"
)
''
H
yperdataPublic
)
$
(
deriveJSON
(
unPrefix
"_hpu_"
)
''
H
yperdataPublic
)
$
(
deriveJSON
(
unPrefix
"_hu_"
)
''
H
yperdataUser
)
-- | Arbitrary instances
-- | Arbitrary instances
instance
Arbitrary
HyperdataUser
where
instance
Arbitrary
HyperdataUser
where
...
...
src/Gargantext/Database/Admin/Types/Metrics.hs
View file @
84a3f5e3
...
@@ -41,8 +41,8 @@ instance Arbitrary Metric
...
@@ -41,8 +41,8 @@ instance Arbitrary Metric
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
<*>
arbitrary
deriveJSON
(
unPrefix
"metrics_"
)
''
M
etrics
deriveJSON
(
unPrefix
"m_"
)
''
M
etric
deriveJSON
(
unPrefix
"m_"
)
''
M
etric
deriveJSON
(
unPrefix
"metrics_"
)
''
M
etrics
newtype
ChartMetrics
a
=
ChartMetrics
{
chartMetrics_data
::
a
}
newtype
ChartMetrics
a
=
ChartMetrics
{
chartMetrics_data
::
a
}
...
...
src/Gargantext/Database/Prelude.hs
View file @
84a3f5e3
...
@@ -119,7 +119,7 @@ fromInt64ToInt = fromIntegral
...
@@ -119,7 +119,7 @@ fromInt64ToInt = fromIntegral
mkCmd
::
(
Connection
->
IO
a
)
->
DBCmd
err
a
mkCmd
::
(
Connection
->
IO
a
)
->
DBCmd
err
a
mkCmd
k
=
do
mkCmd
k
=
do
pool
<-
view
connPool
pool
<-
view
connPool
withResource
pool
(
liftBase
.
k
)
liftBase
$
withResource
pool
(
liftBase
.
k
)
runCmd
::
(
HasConnectionPool
env
)
runCmd
::
(
HasConnectionPool
env
)
=>
env
=>
env
...
...
src/Gargantext/Database/Query/Facet.hs
View file @
84a3f5e3
...
@@ -15,6 +15,7 @@ Portability : POSIX
...
@@ -15,6 +15,7 @@ Portability : POSIX
{-# LANGUAGE NoMonomorphismRestriction #-}
{-# LANGUAGE NoMonomorphismRestriction #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
------------------------------------------------------------------------
------------------------------------------------------------------------
module
Gargantext.Database.Query.Facet
module
Gargantext.Database.Query.Facet
(
runViewAuthorsDoc
(
runViewAuthorsDoc
...
...
src/Gargantext/Database/Schema/User.hs
View file @
84a3f5e3
...
@@ -121,11 +121,11 @@ userTable = Table "auth_user"
...
@@ -121,11 +121,11 @@ userTable = Table "auth_user"
}
}
)
)
$
(
deriveJSON
(
unPrefix
"userLight_"
)
''
U
serLight
)
$
(
deriveJSON
(
unPrefix
"user_"
)
''
U
serPoly
)
instance
FromField
UserLight
where
instance
FromField
UserLight
where
fromField
=
fromField'
fromField
=
fromField'
instance
FromField
UserDB
where
instance
FromField
UserDB
where
fromField
=
fromField'
fromField
=
fromField'
$
(
deriveJSON
(
unPrefix
"userLight_"
)
''
U
serLight
)
$
(
deriveJSON
(
unPrefix
"user_"
)
''
U
serPoly
)
src/Gargantext/Utils/Jobs.hs
View file @
84a3f5e3
...
@@ -10,6 +10,7 @@ Portability : POSIX
...
@@ -10,6 +10,7 @@ Portability : POSIX
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeOperators #-}
module
Gargantext.Utils.Jobs
(
module
Gargantext.Utils.Jobs
(
-- * Serving the JOBS API
-- * Serving the JOBS API
serveJobsAPI
serveJobsAPI
...
...
src/Gargantext/Utils/SpacyNLP.hs
View file @
84a3f5e3
...
@@ -15,71 +15,24 @@ Server to be used: https://gitlab.iscpif.fr/gargantext/spacy-server
...
@@ -15,71 +15,24 @@ Server to be used: https://gitlab.iscpif.fr/gargantext/spacy-server
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TemplateHaskell #-}
module
Gargantext.Utils.SpacyNLP
where
module
Gargantext.Utils.SpacyNLP
(
module
Gargantext
.
Utils
.
SpacyNLP
.
Types
,
spacyRequest
,
spacyTagsToToken
,
spacyDataToPosSentences
,
nlp
)
where
import
Control.Lens
import
Data.Aeson
(
encode
)
import
Data.Aeson
(
encode
)
import
Data.Aeson.TH
(
deriveJSON
)
import
Data.Text
hiding
(
map
,
group
,
filter
,
concat
,
zip
)
import
Data.Text
hiding
(
map
,
group
,
filter
,
concat
,
zip
)
import
Gargantext.Core
(
Lang
(
..
))
import
Gargantext.Core
(
Lang
(
..
))
import
Gargantext.Core.Text.Terms.Multi.PosTagging.Types
import
Gargantext.Core.Text.Terms.Multi.PosTagging.Types
import
Gargantext.Core.Types
(
POS
(
..
),
NER
(
..
))
import
Gargantext.Core.Utils.Prefix
(
unPrefix
)
import
Gargantext.Prelude
import
Gargantext.Prelude
import
Network.HTTP.Simple
(
parseRequest
,
httpJSON
,
setRequestBodyLBS
,
getResponseBody
,
Response
)
import
Network.HTTP.Simple
(
parseRequest
,
httpJSON
,
setRequestBodyLBS
,
getResponseBody
,
Response
)
import
Network.URI
(
URI
(
..
))
import
Network.URI
(
URI
(
..
))
import
Gargantext.Utils.SpacyNLP.Types
data
SpacyData
=
SpacyData
{
_spacy_data
::
!
[
SpacyText
]}
deriving
(
Show
)
data
SpacyText
=
SpacyText
{
_spacy_text
::
!
Text
,
_spacy_tags
::
!
[
SpacyTags
]
}
deriving
(
Show
)
data
SpacyTags
=
SpacyTags
{
_spacyTags_text
::
!
Text
,
_spacyTags_text_with_ws
::
!
Text
,
_spacyTags_whitespace
::
!
Text
,
_spacyTags_head
::
!
Text
,
_spacyTags_head_index
::
!
Int
,
_spacyTags_left_edge
::
!
Text
,
_spacyTags_right_edge
::
!
Text
,
_spacyTags_index
::
Int
,
_spacyTags_ent_type
::
!
NER
,
_spacyTags_ent_iob
::
!
Text
,
_spacyTags_lemma
::
!
Text
,
_spacyTags_normalized
::
!
Text
,
_spacyTags_shape
::
!
Text
,
_spacyTags_prefix
::
!
Text
,
_spacyTags_suffix
::
!
Text
,
_spacyTags_is_alpha
::
Bool
,
_spacyTags_is_ascii
::
Bool
,
_spacyTags_is_digit
::
Bool
,
_spacyTags_is_title
::
Bool
,
_spacyTags_is_punct
::
Bool
,
_spacyTags_is_left_punct
::
Bool
,
_spacyTags_is_right_punct
::
Bool
,
_spacyTags_is_space
::
Bool
,
_spacyTags_is_bracket
::
Bool
,
_spacyTags_is_quote
::
Bool
,
_spacyTags_is_currency
::
Bool
,
_spacyTags_like_url
::
Bool
,
_spacyTags_like_num
::
Bool
,
_spacyTags_like_email
::
Bool
,
_spacyTags_is_oov
::
Bool
,
_spacyTags_is_stop
::
Bool
,
_spacyTags_pos
::
POS
,
_spacyTags_tag
::
POS
,
_spacyTags_dep
::
!
Text
,
_spacyTags_lang
::
!
Text
,
_spacyTags_prob
::
!
Int
,
_spacyTags_char_offset
::
!
Int
}
deriving
(
Show
)
data
SpacyRequest
=
SpacyRequest
{
_spacyRequest_text
::
!
Text
}
deriving
(
Show
)
spacyRequest
::
URI
->
Text
->
IO
SpacyData
spacyRequest
::
URI
->
Text
->
IO
SpacyData
spacyRequest
uri
txt
=
do
spacyRequest
uri
txt
=
do
req
<-
parseRequest
$
"POST "
<>
show
(
uri
{
uriPath
=
"/pos"
})
req
<-
parseRequest
$
"POST "
<>
show
(
uri
{
uriPath
=
"/pos"
})
...
@@ -87,30 +40,18 @@ spacyRequest uri txt = do
...
@@ -87,30 +40,18 @@ spacyRequest uri txt = do
result
<-
httpJSON
request
::
IO
(
Response
SpacyData
)
result
<-
httpJSON
request
::
IO
(
Response
SpacyData
)
pure
$
getResponseBody
result
pure
$
getResponseBody
result
-- Instances
deriveJSON
(
unPrefix
"_spacy_"
)
''
S
pacyData
deriveJSON
(
unPrefix
"_spacy_"
)
''
S
pacyText
deriveJSON
(
unPrefix
"_spacyTags_"
)
''
S
pacyTags
deriveJSON
(
unPrefix
"_spacyRequest_"
)
''
S
pacyRequest
makeLenses
''
S
pacyData
makeLenses
''
S
pacyText
makeLenses
''
S
pacyTags
makeLenses
''
S
pacyRequest
----------------------------------------------------------------
----------------------------------------------------------------
spacyTagsToToken
::
SpacyTags
->
Token
spacyTagsToToken
::
SpacyTags
->
Token
spacyTagsToToken
st
=
Token
(
st
^.
spacyTags_index
)
spacyTagsToToken
st
=
Token
(
_spacyTags_index
st
)
(
st
^.
spacyTags_normalized
)
(
_spacyTags_normalized
st
)
(
st
^.
spacyTags_tex
t
)
(
_spacyTags_text
s
t
)
(
st
^.
spacyTags_lemma
)
(
_spacyTags_lemma
st
)
(
st
^.
spacyTags_head_index
)
(
_spacyTags_head_index
st
)
(
st
^.
spacyTags_char_offse
t
)
(
_spacyTags_char_offset
s
t
)
(
Just
$
st
^.
spacyTags_pos
)
(
Just
$
_spacyTags_pos
st
)
(
Just
$
st
^.
spacyTags_ent_type
)
(
Just
$
_spacyTags_ent_type
st
)
(
Just
$
st
^.
spacyTags_prefix
)
(
Just
$
_spacyTags_prefix
st
)
(
Just
$
st
^.
spacyTags_suffix
)
(
Just
$
_spacyTags_suffix
st
)
spacyDataToPosSentences
::
SpacyData
->
PosSentences
spacyDataToPosSentences
::
SpacyData
->
PosSentences
spacyDataToPosSentences
(
SpacyData
ds
)
=
PosSentences
spacyDataToPosSentences
(
SpacyData
ds
)
=
PosSentences
...
...
src/Gargantext/Utils/SpacyNLP/Types.hs
0 → 100644
View file @
84a3f5e3
{-|
Module : Gargantext.Utils.SpacyNLP.Types
Description : John Snow NLP API connexion
Copyright : (c) CNRS, 2017
License : AGPL + CECILL v3
Maintainer : team@gargantext.org
Stability : experimental
Portability : POSIX
Spacy ecosystem: https://github.com/explosion/spaCy
Server to be used: https://gitlab.iscpif.fr/gargantext/spacy-server
-}
{-# LANGUAGE TemplateHaskell #-}
module
Gargantext.Utils.SpacyNLP.Types
where
import
Control.Lens
import
Data.Aeson.TH
(
deriveJSON
)
import
Data.Text
hiding
(
map
,
group
,
filter
,
concat
,
zip
)
import
Gargantext.Core.Types
(
POS
(
..
),
NER
(
..
))
import
Gargantext.Core.Utils.Prefix
(
unPrefix
)
import
Gargantext.Prelude
data
SpacyData
=
SpacyData
{
_spacy_data
::
!
[
SpacyText
]}
deriving
(
Show
)
data
SpacyText
=
SpacyText
{
_spacy_text
::
!
Text
,
_spacy_tags
::
!
[
SpacyTags
]
}
deriving
(
Show
)
data
SpacyTags
=
SpacyTags
{
_spacyTags_text
::
!
Text
,
_spacyTags_text_with_ws
::
!
Text
,
_spacyTags_whitespace
::
!
Text
,
_spacyTags_head
::
!
Text
,
_spacyTags_head_index
::
!
Int
,
_spacyTags_left_edge
::
!
Text
,
_spacyTags_right_edge
::
!
Text
,
_spacyTags_index
::
Int
,
_spacyTags_ent_type
::
!
NER
,
_spacyTags_ent_iob
::
!
Text
,
_spacyTags_lemma
::
!
Text
,
_spacyTags_normalized
::
!
Text
,
_spacyTags_shape
::
!
Text
,
_spacyTags_prefix
::
!
Text
,
_spacyTags_suffix
::
!
Text
,
_spacyTags_is_alpha
::
Bool
,
_spacyTags_is_ascii
::
Bool
,
_spacyTags_is_digit
::
Bool
,
_spacyTags_is_title
::
Bool
,
_spacyTags_is_punct
::
Bool
,
_spacyTags_is_left_punct
::
Bool
,
_spacyTags_is_right_punct
::
Bool
,
_spacyTags_is_space
::
Bool
,
_spacyTags_is_bracket
::
Bool
,
_spacyTags_is_quote
::
Bool
,
_spacyTags_is_currency
::
Bool
,
_spacyTags_like_url
::
Bool
,
_spacyTags_like_num
::
Bool
,
_spacyTags_like_email
::
Bool
,
_spacyTags_is_oov
::
Bool
,
_spacyTags_is_stop
::
Bool
,
_spacyTags_pos
::
POS
,
_spacyTags_tag
::
POS
,
_spacyTags_dep
::
!
Text
,
_spacyTags_lang
::
!
Text
,
_spacyTags_prob
::
!
Int
,
_spacyTags_char_offset
::
!
Int
}
deriving
(
Show
)
data
SpacyRequest
=
SpacyRequest
{
_spacyRequest_text
::
!
Text
}
deriving
(
Show
)
--
-- JSON instances
--
deriveJSON
(
unPrefix
"_spacyTags_"
)
''
S
pacyTags
deriveJSON
(
unPrefix
"_spacy_"
)
''
S
pacyText
deriveJSON
(
unPrefix
"_spacy_"
)
''
S
pacyData
deriveJSON
(
unPrefix
"_spacyRequest_"
)
''
S
pacyRequest
--
-- Lenses
--
makeLenses
''
S
pacyData
makeLenses
''
S
pacyText
makeLenses
''
S
pacyTags
makeLenses
''
S
pacyRequest
stack.yaml
View file @
84a3f5e3
...
@@ -148,6 +148,11 @@ extra-deps:
...
@@ -148,6 +148,11 @@ extra-deps:
-
tmp-postgres-1.34.1.0
-
tmp-postgres-1.34.1.0
-
vector-0.12.3.0@sha256:0ae2c1ba86f0077910be242ec6802cc3d7725fe7b2bea6987201aa3737b239b5,7953
-
vector-0.12.3.0@sha256:0ae2c1ba86f0077910be242ec6802cc3d7725fe7b2bea6987201aa3737b239b5,7953
-
wai-3.2.4
-
wai-3.2.4
-
morpheus-graphql-0.24.3
-
morpheus-graphql-app-0.24.3
-
morpheus-graphql-core-0.24.3
-
morpheus-graphql-server-0.24.3
-
morpheus-graphql-subscriptions-0.24.3
# For the graph clustering
# For the graph clustering
ghc-options
:
ghc-options
:
...
...
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