Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
C
CTF
Project
Project
Details
Activity
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
Grzegorz
CTF
Commits
312ad443
Commit
312ad443
authored
Apr 07, 2016
by
Michał
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
post forward stub
parent
fda85003
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
60 additions
and
7 deletions
+60
-7
Task.java
...ava/com/telephoners/krakyournet/ctf/beans/tasks/Task.java
+1
-1
WebTask.java
.../com/telephoners/krakyournet/ctf/beans/tasks/WebTask.java
+28
-6
TaskResource.java
...m/telephoners/krakyournet/ctf/resources/TaskResource.java
+31
-0
No files found.
service/src/main/java/com/telephoners/krakyournet/ctf/beans/tasks/Task.java
View file @
312ad443
...
...
@@ -38,7 +38,7 @@ public abstract class Task
{
}
public
abstract
TaskResponse
getTaskResponse
(
User
user
,
String
path
,
ContainerRequestContext
containerRequestContext
)
throws
IOException
;
public
abstract
TaskResponse
getTaskResponse
(
User
user
,
String
path
,
ContainerRequestContext
containerRequestContext
,
String
postContent
)
throws
IOException
;
public
String
getName
()
{
...
...
service/src/main/java/com/telephoners/krakyournet/ctf/beans/tasks/WebTask.java
View file @
312ad443
...
...
@@ -6,13 +6,19 @@ import com.telephoners.krakyournet.ctf.beans.Flag;
import
com.telephoners.krakyournet.ctf.beans.User
;
import
com.telephoners.krakyournet.ctf.helpers.StreamUtils
;
import
org.apache.http.Header
;
import
org.apache.http.HttpEntity
;
import
org.apache.http.client.methods.CloseableHttpResponse
;
import
org.apache.http.client.methods.HttpGet
;
import
org.apache.http.client.methods.HttpPost
;
import
org.apache.http.entity.ByteArrayEntity
;
import
org.apache.http.impl.client.CloseableHttpClient
;
import
org.apache.http.impl.client.HttpClients
;
import
org.jcp.xml.dsig.internal.dom.Utils
;
import
org.mongodb.morphia.annotations.Entity
;
import
javax.ws.rs.WebApplicationException
;
import
javax.ws.rs.container.ContainerRequestContext
;
import
javax.ws.rs.core.Response
;
import
java.io.IOException
;
import
java.util.List
;
...
...
@@ -38,7 +44,8 @@ public class WebTask extends Task
{
String
url
=
getUrl
()
+
path
;
String
kynHeaderValue
=
context
.
getHeaderString
(
KYN_HEADER_NAME
);
CloseableHttpResponse
response
=
proxyRequest
(
url
,
user
,
kynHeaderValue
);
String
postContent
=
Utils
.
readBytesFromStream
(
context
.
getEntityStream
());
//todo: is it working?
CloseableHttpResponse
response
=
proxyRequest
(
url
,
user
,
kynHeaderValue
,
context
.
getMethod
(),
postContent
);
String
text
=
StreamUtils
.
readStream
(
response
.
getEntity
().
getContent
());
Header
kynHeader
=
response
.
getFirstHeader
(
KYN_HEADER_NAME
);
return
new
TaskResponse
(
text
,
kynHeader
!=
null
?
kynHeader
.
getValue
()
:
null
);
//todo: needs refactorig
...
...
@@ -54,12 +61,27 @@ public class WebTask extends Task
this
.
url
=
url
;
}
private
CloseableHttpResponse
proxyRequest
(
String
url
,
User
user
,
String
kynHeaderValue
)
throws
IOException
private
CloseableHttpResponse
proxyRequest
(
String
url
,
User
user
,
String
kynHeaderValue
,
String
httpMethod
,
String
postContent
)
throws
IOException
{
CloseableHttpClient
httpClient
=
HttpClients
.
createDefault
();
HttpGet
httpget
=
new
HttpGet
(
url
);
httpget
.
setHeader
(
"CTF-User"
,
user
.
getName
());
//todo: is it necessary?
httpget
.
setHeader
(
"KYN_2016"
,
kynHeaderValue
);
//todo: move to configuration
return
httpClient
.
execute
(
httpget
);
//todo: merge
if
(
httpMethod
.
equals
(
"GET"
))
{
HttpGet
httpGet
=
new
HttpGet
(
url
);
httpGet
.
setHeader
(
"CTF-User"
,
user
.
getName
());
//todo: is it necessary?
httpGet
.
setHeader
(
"KYN_2016"
,
kynHeaderValue
);
//todo: move to configuration
return
httpClient
.
execute
(
httpGet
);
}
else
if
(
httpMethod
.
equals
(
"POST"
))
{
HttpPost
httpPost
=
new
HttpPost
(
url
);
httpPost
.
setHeader
(
"CTF-User"
,
user
.
getName
());
//todo: is it necessary?
httpPost
.
setHeader
(
"KYN_2016"
,
kynHeaderValue
);
//todo: move to configuration
HttpEntity
entity
=
new
ByteArrayEntity
(
postContent
.
getBytes
(
"UTF-8"
));
httpPost
.
setEntity
(
entity
);
return
httpClient
.
execute
(
httpPost
);
}
else
{
throw
new
WebApplicationException
(
"no such method"
,
Response
.
Status
.
INTERNAL_SERVER_ERROR
);
//todo
}
}
}
service/src/main/java/com/telephoners/krakyournet/ctf/resources/TaskResource.java
View file @
312ad443
...
...
@@ -10,6 +10,7 @@ import org.glassfish.jersey.server.ContainerRequest;
import
javax.inject.Inject
;
import
javax.inject.Singleton
;
import
javax.ws.rs.GET
;
import
javax.ws.rs.POST
;
import
javax.ws.rs.Path
;
import
javax.ws.rs.PathParam
;
import
javax.ws.rs.container.ContainerRequestContext
;
...
...
@@ -55,4 +56,34 @@ public class TaskResource
}
return
responseBuilder
.
build
();
}
@Path
(
"{task_level}/{path: .*}"
)
@POST
public
Response
postTask
(
@Auth
User
user
,
final
@PathParam
(
"task_level"
)
int
taskLevel
,
final
@PathParam
(
"path"
)
String
path
,
@Context
ContainerRequestContext
containerRequestContext
)
throws
IOException
{
//todo: merge
Task
task
=
tasksRepository
.
getByLevel
(
taskLevel
);
//todo: refactor, path not necessary in textTasks
ContainerRequest
context
=
(
ContainerRequest
)
containerRequestContext
;
String
query
=
context
.
getRequestUri
().
getQuery
();
String
fullPath
=
path
;
if
(
query
!=
null
)
{
//todo: refactor
fullPath
=
fullPath
+
"?"
+
query
;
}
TaskResponse
taskResponse
=
task
.
getTaskResponse
(
user
,
fullPath
,
containerRequestContext
);
Response
.
ResponseBuilder
responseBuilder
=
Response
.
ok
();
responseBuilder
.
entity
(
taskResponse
.
getText
());
String
kynHeaderValue
=
taskResponse
.
getKynHeader
();
if
(
kynHeaderValue
!=
null
)
{
responseBuilder
.
header
(
KYN_HEADER_NAME
,
kynHeaderValue
);
}
return
responseBuilder
.
build
();
}
}
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