Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

41 add client parameter to requests #66

Merged
merged 35 commits into from
Nov 20, 2024
Merged
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
6def565
Update AsyncRequestCallable.java
lukasmatusiewicz Nov 13, 2024
12c97b4
Update Challenge.java
lukasmatusiewicz Nov 13, 2024
4a6c7fc
Update Endpoint.java
lukasmatusiewicz Nov 13, 2024
a36776f
Update IPISimpleLogger.java
lukasmatusiewicz Nov 13, 2024
9da081c
Update JSONParser.java
lukasmatusiewicz Nov 13, 2024
6fc087e
Update PIConfig.java
lukasmatusiewicz Nov 13, 2024
95d13f5
Update PIConstants.java
lukasmatusiewicz Nov 13, 2024
1544491
Update PIError.java
lukasmatusiewicz Nov 13, 2024
dfa4aeb
Update PIResponse.java
lukasmatusiewicz Nov 13, 2024
65270f7
Update PrivacyIDEA.java
lukasmatusiewicz Nov 13, 2024
bd38a1a
Delete U2F.java
lukasmatusiewicz Nov 13, 2024
c312289
Update WebAuthn.java
lukasmatusiewicz Nov 13, 2024
5b82be8
Update TestGetTokenInfo.java
lukasmatusiewicz Nov 13, 2024
55dcc0d
Update TestPollTransaction.java
lukasmatusiewicz Nov 13, 2024
4d36bbc
Update TestRollout.java
lukasmatusiewicz Nov 13, 2024
25540a2
Update TestTriggerChallenge.java
lukasmatusiewicz Nov 13, 2024
6b80c16
Update TestU2F.java
lukasmatusiewicz Nov 13, 2024
e2ed830
Update TestValidateCheck.java
lukasmatusiewicz Nov 13, 2024
6982115
Update TestValidateCheckSerial.java
lukasmatusiewicz Nov 13, 2024
b45eb5f
Update TestWebAuthn.java
lukasmatusiewicz Nov 13, 2024
6328451
rm u2f
lukasmatusiewicz Nov 13, 2024
d6deb0c
Update Endpoint.java
lukasmatusiewicz Nov 18, 2024
143642b
Update PIConfig.java
lukasmatusiewicz Nov 18, 2024
8637e77
Update PIConstants.java
lukasmatusiewicz Nov 18, 2024
050e82e
Update PIResponse.java
lukasmatusiewicz Nov 18, 2024
63acc43
Update PrivacyIDEA.java
lukasmatusiewicz Nov 18, 2024
93da9d7
Update PrivacyIDEA.java
lukasmatusiewicz Nov 18, 2024
ebf2d6a
Update pom.xml
lukasmatusiewicz Nov 18, 2024
c6e6c1e
Update build.yml
lukasmatusiewicz Nov 19, 2024
a86029a
Update TestTriggerChallenge.java
lukasmatusiewicz Nov 19, 2024
c35cff7
Update PIConfig.java
lukasmatusiewicz Nov 20, 2024
f676429
Update PrivacyIDEA.java
lukasmatusiewicz Nov 20, 2024
4879f56
Update Endpoint.java
lukasmatusiewicz Nov 20, 2024
f2c22dd
Update Endpoint.java
lukasmatusiewicz Nov 20, 2024
ef7b246
change some private fields to protected or public
lukasmatusiewicz Nov 20, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ jobs:
echo "branches = ${{ steps.jacoco.outputs.branches }}"

- name: Upload JaCoCo coverage report as a workflow artifact
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v3
with:
name: jacoco-report
path: target/site/jacoco/
Expand Down
6 changes: 3 additions & 3 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -50,8 +50,8 @@
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<source>11</source>
<target>11</target>
</configuration>
</plugin>
<plugin>
Expand Down Expand Up @@ -86,7 +86,7 @@
<dependency>
<groupId>com.squareup.okhttp3</groupId>
<artifactId>okhttp</artifactId>
<version>4.10.0</version>
<version>4.12.0</version>
</dependency>
<dependency>
<groupId>org.jetbrains.kotlin</groupId>
Expand Down
9 changes: 5 additions & 4 deletions src/main/java/org/privacyidea/AsyncRequestCallable.java
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,17 @@
*/
package org.privacyidea;

import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.Response;
import org.jetbrains.annotations.NotNull;

import java.io.IOException;
import java.util.Collections;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;
import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.Response;
import org.jetbrains.annotations.NotNull;

import static org.privacyidea.PIConstants.ENDPOINT_AUTH;

Expand Down
8 changes: 4 additions & 4 deletions src/main/java/org/privacyidea/Challenge.java
Original file line number Diff line number Diff line change
Expand Up @@ -25,17 +25,17 @@ public class Challenge
private final String serial;
private final String clientMode;
private final String message;
private final String transactionId;
private final String transactionID;
private final String type;
private final String image;

public Challenge(String serial, String message, String clientMode, String image, String transactionId, String type)
public Challenge(String serial, String message, String clientMode, String image, String transactionID, String type)
{
this.serial = serial;
this.message = message;
this.clientMode = clientMode;
this.image = image;
this.transactionId = transactionId;
this.transactionID = transactionID;
this.type = type;
}

Expand All @@ -49,7 +49,7 @@ public Challenge(String serial, String message, String clientMode, String image,

public String getImage() {return image.replaceAll("\"", "");}

public String getTransactionID() {return transactionId;}
public String getTransactionID() {return transactionID;}

public String getType() {return type;}
}
74 changes: 42 additions & 32 deletions src/main/java/org/privacyidea/Endpoint.java
Original file line number Diff line number Diff line change
Expand Up @@ -16,36 +16,31 @@
*/
package org.privacyidea;

import okhttp3.*;

import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.InetSocketAddress;
import java.net.Proxy;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.util.Map;
import java.util.concurrent.TimeUnit;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import okhttp3.Callback;
import okhttp3.FormBody;
import okhttp3.HttpUrl;
import okhttp3.OkHttpClient;
import okhttp3.Request;

import static org.privacyidea.PIConstants.GET;
import static org.privacyidea.PIConstants.HEADER_USER_AGENT;
import static org.privacyidea.PIConstants.POST;
import static org.privacyidea.PIConstants.WEBAUTHN_PARAMETERS;
import static org.privacyidea.PIConstants.*;

/**
* This class handles sending requests to the server.
*/
class Endpoint
{
private final PrivacyIDEA privacyIDEA;
private final PIConfig piconfig;
private final PIConfig piConfig;
private final OkHttpClient client;

final TrustManager[] trustAllManager = new TrustManager[]{new X509TrustManager()
Expand All @@ -67,17 +62,22 @@ public java.security.cert.X509Certificate[] getAcceptedIssuers()
}
}};

/**
* Constructor
*
lukasmatusiewicz marked this conversation as resolved.
Show resolved Hide resolved
* @param privacyIDEA privacyIDEA instance
*/
Endpoint(PrivacyIDEA privacyIDEA)
{
this.privacyIDEA = privacyIDEA;
this.piconfig = privacyIDEA.configuration();
this.piConfig = privacyIDEA.configuration();

OkHttpClient.Builder builder = new OkHttpClient.Builder();
builder.connectTimeout(piconfig.httpTimeoutMs, TimeUnit.MILLISECONDS)
.writeTimeout(piconfig.httpTimeoutMs, TimeUnit.MILLISECONDS)
.readTimeout(piconfig.httpTimeoutMs, TimeUnit.MILLISECONDS);
builder.connectTimeout(piConfig.getHttpTimeoutMs(), TimeUnit.MILLISECONDS)
.writeTimeout(piConfig.getHttpTimeoutMs(), TimeUnit.MILLISECONDS)
.readTimeout(piConfig.getHttpTimeoutMs(), TimeUnit.MILLISECONDS);

if (!this.piconfig.doSSLVerify)
if (!this.piConfig.getVerifySSL())
{
// Trust all certs and verify every host
try
Expand All @@ -93,6 +93,13 @@ public java.security.cert.X509Certificate[] getAcceptedIssuers()
privacyIDEA.error(e);
}
}

if (!piConfig.getProxyHost().isEmpty())
{
Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress(piConfig.getProxyHost(), piConfig.getProxyPort()));
builder.proxy(proxy);
}

this.client = builder.build();
}

Expand All @@ -105,44 +112,47 @@ public java.security.cert.X509Certificate[] getAcceptedIssuers()
* @param method http request method
* @param callback okhttp3 callback
*/
void sendRequestAsync(String endpoint, Map<String, String> params, Map<String, String> headers, String method,
Callback callback)
void sendRequestAsync(String endpoint, Map<String, String> params, Map<String, String> headers, String method, Callback callback)
{
HttpUrl httpUrl = HttpUrl.parse(piconfig.serverURL + endpoint);
HttpUrl httpUrl = HttpUrl.parse(piConfig.getServerURL() + endpoint);
if (httpUrl == null)
{
privacyIDEA.error("Server url could not be parsed: " + (piconfig.serverURL + endpoint));
privacyIDEA.error("Server url could not be parsed: " + (piConfig.getServerURL() + endpoint));
// Invoke the callback to terminate the thread that called this function.
callback.onFailure(null, new IOException("Request could not be created because the url could not be parsed"));
return;
}
HttpUrl.Builder urlBuilder = httpUrl.newBuilder();
if (!piConfig.getForwardClientIP().isEmpty())
{
privacyIDEA.log("Forwarding client IP: " + piConfig.getForwardClientIP());
params.put(CLIENT_IP, piConfig.getForwardClientIP());
}
privacyIDEA.log(method + " " + endpoint);
params.forEach((k, v) ->
{
{
if (k.equals("pass") || k.equals("password"))
{
v = "*".repeat(v.length());
}

privacyIDEA.log(k + "=" + v);
});
});

if (GET.equals(method))
{
params.forEach((key, value) ->
{
{
String encValue = URLEncoder.encode(value, StandardCharsets.UTF_8);
urlBuilder.addQueryParameter(key, encValue);
});
});
}

String url = urlBuilder.build().toString();
//privacyIDEA.log("URL: " + url);
Request.Builder requestBuilder = new Request.Builder().url(url);

// Add the headers
requestBuilder.addHeader(HEADER_USER_AGENT, piconfig.userAgent);
requestBuilder.addHeader(HEADER_USER_AGENT, piConfig.getUserAgent());
if (headers != null && !headers.isEmpty())
{
headers.forEach(requestBuilder::addHeader);
Expand All @@ -152,7 +162,7 @@ void sendRequestAsync(String endpoint, Map<String, String> params, Map<String, S
{
FormBody.Builder formBodyBuilder = new FormBody.Builder();
params.forEach((key, value) ->
{
{
if (key != null && value != null)
{
String encValue = value;
Expand All @@ -164,7 +174,7 @@ void sendRequestAsync(String endpoint, Map<String, String> params, Map<String, S
}
formBodyBuilder.add(key, encValue);
}
});
});
// This switches okhttp to make a post request
requestBuilder.post(formBodyBuilder.build());
}
Expand Down
2 changes: 1 addition & 1 deletion src/main/java/org/privacyidea/IPISimpleLogger.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,5 @@
*/
public interface IPISimpleLogger
{
void pilog(String message);
void piLog(String message);
}
Loading
Loading