mirror of
https://github.com/internetee/epp_proxy.git
synced 2025-08-15 12:03:47 +02:00
Merge pull request #11 from internetee/send-frame-parameter-as-well
Send frame as request paramater as well
This commit is contained in:
commit
ae2bfd5969
5 changed files with 29 additions and 16 deletions
|
@ -23,6 +23,14 @@ Login
|
|||
</command>
|
||||
</epp>
|
||||
|
||||
Logout without any parameters
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<epp xmlns="https://epp.tld.ee/schema/epp-ee-1.0.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="urn:ietf:params:xml:ns:epp-1.0 epp-1.0.xsd">
|
||||
<command>
|
||||
<logout/>
|
||||
</command>
|
||||
</epp>
|
||||
|
||||
Logout
|
||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<epp xmlns="https://epp.tld.ee/schema/epp-ee-1.0.xsd">
|
||||
|
|
20
README.md
20
README.md
|
@ -29,17 +29,17 @@ HTTP requests according to the following matrix. Application performs regex sear
|
|||
XPATH search for command name. It does not check against any XSD schema.
|
||||
|
||||
| EPP Command | HTTP request | Parameters | Headers | Payload Type | Cookies |
|
||||
|-------------|----------------------------------|---------------------|---------------------------------------------------------------------|----------------|---------|
|
||||
|-------------|----------------------------------|----------------------------|---------------------------------------------------------------------|----------------|---------|
|
||||
| hello | `GET /epp_session_url/hello` | | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | | session |
|
||||
| login | `POST /epp_session_url/login` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| logout | `POST /epp_session_url/logout` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| poll | `POST /epp_command_url/poll` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| check | `POST /epp_command_url/check` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| info | `POST /epp_command_url/info` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| create | `POST /epp_command_url/create` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| delete | `POST /epp_command_url/delete` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| renew | `POST /epp_command_url/renew` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| update | `POST /epp_command_url/update` | `raw_frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| login | `POST /epp_session_url/login` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| logout | `POST /epp_session_url/logout` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| poll | `POST /epp_command_url/poll` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| check | `POST /epp_command_url/check` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| info | `POST /epp_command_url/info` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| create | `POST /epp_command_url/create` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| delete | `POST /epp_command_url/delete` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| renew | `POST /epp_command_url/renew` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| update | `POST /epp_command_url/update` | `raw_frame, frame, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | form/multipart | session |
|
||||
| ANY (error) | `GET /epp_error_url` | `msg, code, clTRID` | SSL-CLIENT-CERT, SSL-CLIENT-S-DN-CN, User-Agent, X-Forwarded-for | query params | session |
|
||||
|
||||
Error route is used in case EPP frame is malformed.
|
||||
|
|
|
@ -16,9 +16,12 @@ class EppServer < Roda
|
|||
end
|
||||
|
||||
r.post "logout" do
|
||||
# Additional check if passes empty frame
|
||||
if r.params['frame']
|
||||
render("session/logout")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
r.on "command" do
|
||||
r.post "poll" do
|
||||
|
|
|
@ -82,10 +82,10 @@ request_from_map(#{command := Command,
|
|||
%% Return form data or an empty list.
|
||||
request_body(?helloCommand, _, _) -> "";
|
||||
request_body(_Command, RawFrame, nomatch) ->
|
||||
{multipart, [{<<"raw_frame">>, RawFrame}]};
|
||||
{multipart, [{<<"raw_frame">>, RawFrame}, {<<"frame">>, RawFrame}]};
|
||||
request_body(_Command, RawFrame, ClTRID) ->
|
||||
{multipart,
|
||||
[{<<"raw_frame">>, RawFrame}, {<<"clTRID">>, ClTRID}]}.
|
||||
[{<<"raw_frame">>, RawFrame}, {<<"frame">>, RawFrame}, {<<"clTRID">>, ClTRID}]}.
|
||||
|
||||
%% Return a list of properties that each represent a query part in a query string.
|
||||
%% [{"user", "eis"}]} becomes later https://example.com?user=eis
|
||||
|
|
|
@ -61,6 +61,7 @@ command_request_builder_test_case(_Config) ->
|
|||
"http://localhost:9292/command/create",
|
||||
{multipart,
|
||||
[{<<"raw_frame">>,"Some XML here"},
|
||||
{<<"frame">>,"Some XML here"},
|
||||
{<<"clTRID">>,"EE-123456789"}]},
|
||||
[<<"session=Random; Version=1">>],
|
||||
[{"User-Agent",<<"EPP proxy">>}], "create"},
|
||||
|
@ -74,6 +75,7 @@ registry_unreachable_test_case(_Config) ->
|
|||
"http://localhost:9999/someurl",
|
||||
{multipart,
|
||||
[{<<"raw_frame">>,"Some XML here"},
|
||||
{<<"frame">>,"Some XML here"},
|
||||
{<<"clTRID">>,"EE-123456789"}]},
|
||||
[<<"session=Random; Version=1">>],
|
||||
[{"User-Agent",<<"EPP proxy">>}], "create"},
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue