Skip to content

Commit

Permalink
no errors in Response
Browse files Browse the repository at this point in the history
  • Loading branch information
monacoremo committed Apr 26, 2021
1 parent 912bb16 commit 11c37bd
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 26 deletions.
13 changes: 11 additions & 2 deletions src/PostgREST/App.hs
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,9 @@ import PostgREST.Request (Request (..))
import PostgREST.Request.ApiRequest (ApiRequest (..))
import PostgREST.Version (prettyVersion)
import PostgREST.Workers (connectionWorker, listener)
import PostgREST.DbStructure.Identifiers (QualifiedIdentifier(..))
import PostgREST.DbStructure (tablePKCols)
import PostgREST.DbStructure.Table (Table(..))

import qualified PostgREST.Query as Query
import qualified PostgREST.Request as Request
Expand Down Expand Up @@ -172,8 +175,13 @@ handleRequest conf dbStructure req =
Response.deleteResponse apiRequest
<$> Query.delete conf dbStructure identifier apiRequest readReq mutReq

InfoRequest _ identifier ->
liftEither $ Response.infoResponse identifier dbStructure
InfoRequest _ QualifiedIdentifier{..} ->
maybe (throwError Error.NotFound)
(return . Response.infoResponse hasPK)
(find tableMatches $ dbTables dbStructure)
where
tableMatches Table{..} = tableName == qiName && tableSchema == qiSchema
hasPK = not $ null $ tablePKCols dbStructure qiSchema qiName

InvokeRequest apiRequest invMethod proc readReq bField -> do
(results, gucHeaders, gucStatus) <- Query.invoke proc readReq bField conf dbStructure apiRequest
Expand All @@ -182,3 +190,4 @@ handleRequest conf dbStructure req =
OpenApiRequest apiRequest headersOnly tSchema -> do
(accessibleTables, schemaDescription, accessibleProcs) <- Query.openApi tSchema conf
return $ Response.openApiResponse headersOnly conf dbStructure apiRequest accessibleTables schemaDescription accessibleProcs

36 changes: 12 additions & 24 deletions src/PostgREST/Response.hs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@ import qualified Network.HTTP.Types.Status as HTTP
import qualified Network.HTTP.Types.URI as HTTP
import qualified Network.Wai as Wai

import qualified PostgREST.Error as Error
import qualified PostgREST.OpenAPI as OpenAPI
import qualified PostgREST.Query.Statements as Statements
import qualified PostgREST.RangeQuery as RangeQuery
Expand All @@ -33,7 +32,6 @@ import PostgREST.DbStructure.Identifiers (QualifiedIdentifier (..),
Schema)
import PostgREST.DbStructure.Proc (ProcDescription)
import PostgREST.DbStructure.Table (Table (..))
import PostgREST.Error (Error)
import PostgREST.GucHeader (GucHeader,
addHeadersIfNotIncluded,
unwrapGucHeader)
Expand All @@ -50,9 +48,8 @@ import Protolude.Conv (toS)

readResponse :: Bool -> QualifiedIdentifier -> AppConfig -> ApiRequest -> Statements.ResultsWithCount -> Maybe Int64 -> [GucHeader] -> Maybe HTTP.Status -> Wai.Response
readResponse headersOnly identifier AppConfig{..} apiRequest@ApiRequest{..} (_, queryTotal, _ , body, _, _) total gucHeaders gucStatus =
response status headers $ if headersOnly then mempty else toS body
gucResponse gucStatus gucHeaders status headers $ if headersOnly then mempty else toS body
where
response = gucResponse gucStatus gucHeaders
(status, contentRange) = RangeQuery.rangeStatusHeader iTopLevelRange queryTotal total
headers =
[ contentRange
Expand All @@ -67,12 +64,12 @@ readResponse headersOnly identifier AppConfig{..} apiRequest@ApiRequest{..} (_,
createResponse :: QualifiedIdentifier -> DbStructure -> ApiRequest -> WriteQueryResult -> Wai.Response
createResponse QualifiedIdentifier{..} dbStructure apiRequest@ApiRequest{..} WriteQueryResult{..} =
if iPreferRepresentation == Full then
response HTTP.status201 (headers ++ contentTypeHeaders apiRequest) (toS resBody)
response (headers ++ contentTypeHeaders apiRequest) (toS resBody)
else
response HTTP.status201 headers mempty
response headers mempty
where
pkCols = tablePKCols dbStructure qiSchema qiName
response = gucResponse resGucStatus resGucHeaders
response = gucResponse resGucStatus resGucHeaders HTTP.status201
headers =
catMaybes
[ if null resFields then
Expand All @@ -95,11 +92,11 @@ createResponse QualifiedIdentifier{..} dbStructure apiRequest@ApiRequest{..} Wri
updateResponse :: ApiRequest -> WriteQueryResult -> Wai.Response
updateResponse apiRequest@ApiRequest{..} WriteQueryResult{..} =
if fullRepr then
response status (contentTypeHeaders apiRequest ++ [contentRangeHeader]) (toS resBody)
response (contentTypeHeaders apiRequest ++ [contentRangeHeader]) (toS resBody)
else
response status [contentRangeHeader] mempty
response [contentRangeHeader] mempty
where
response = gucResponse resGucStatus resGucHeaders
response = gucResponse resGucStatus resGucHeaders status
fullRepr = iPreferRepresentation == Full
updateIsNoOp = Set.null iColumns
status
Expand Down Expand Up @@ -133,29 +130,20 @@ deleteResponse apiRequest@ApiRequest{..} WriteQueryResult{..} =
RangeQuery.contentRangeH 1 0 $
if shouldCount iPreferCount then Just resQueryTotal else Nothing

infoResponse :: QualifiedIdentifier -> DbStructure -> Either Error Wai.Response
infoResponse identifier dbStructure =
case find tableMatches $ dbTables dbStructure of
Just table ->
return $ Wai.responseLBS HTTP.status200 [allOrigins, allowH table] mempty
Nothing ->
throwError Error.NotFound
infoResponse :: Bool -> Table -> Wai.Response
infoResponse hasPrimaryKey table =
Wai.responseLBS HTTP.status200 [allOrigins, allowH] mempty
where
allOrigins = ("Access-Control-Allow-Origin", "*")
allowH table =
allowH =
( HTTP.hAllow
, BS8.intercalate "," $
["OPTIONS,GET,HEAD"]
++ ["POST" | tableInsertable table]
++ ["PUT" | tableInsertable table && tableUpdatable table && hasPK]
++ ["PUT" | tableInsertable table && tableUpdatable table && hasPrimaryKey]
++ ["PATCH" | tableUpdatable table]
++ ["DELETE" | tableDeletable table]
)
tableMatches table =
tableName table == qiName identifier
&& tableSchema table == qiSchema identifier
hasPK =
not $ null $ tablePKCols dbStructure (qiSchema identifier) (qiName identifier)

invokeResponse :: InvokeMethod -> ApiRequest -> Statements.ProcResults -> [GucHeader] -> Maybe HTTP.Status -> Wai.Response
invokeResponse invMethod apiRequest@ApiRequest{..} (tableTotal, queryTotal, body, _, _) gucHeaders gucStatus =
Expand Down

0 comments on commit 11c37bd

Please sign in to comment.