blob: ecf908d1ad7cfc0974bafbe245e279a41ce6dc3c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/*
* Copyright (c) 2010, Isode Limited, London, England.
* All rights reserved.
*/
/*
* Copyright (c) 2010, Remko Tron¨on.
* All rights reserved.
*/
package com.isode.stroke.streamstack;
import com.isode.stroke.base.ByteArray;
import com.isode.stroke.signals.Signal;
import com.isode.stroke.signals.Slot1;
import com.isode.stroke.tls.Certificate;
import com.isode.stroke.tls.CertificateVerificationError;
import com.isode.stroke.tls.PKCS12Certificate;
import com.isode.stroke.tls.TLSContext;
import com.isode.stroke.tls.TLSContextFactory;
public class TLSLayer extends StreamLayer {
public TLSLayer(TLSContextFactory factory) {
context = factory.createTLSContext();
context.onDataForNetwork.connect(new Slot1<ByteArray>() {
public void call(ByteArray p1) {
writeDataToChildLayer(p1);
}
});
context.onDataForApplication.connect(new Slot1<ByteArray>() {
public void call(ByteArray p1) {
writeDataToParentLayer(p1);
}
});
context.onConnected.connect(onConnected);
context.onError.connect(onError);
}
public void connect() {
context.connect();
}
public void writeData(ByteArray data) {
context.handleDataFromApplication(data);
}
public void handleDataRead(ByteArray data) {
context.handleDataFromNetwork(data);
}
public boolean setClientCertificate(PKCS12Certificate certificate) {
return context.setClientCertificate(certificate);
}
public Certificate getPeerCertificate() {
return context.getPeerCertificate();
}
public CertificateVerificationError getPeerCertificateVerificationError() {
return context.getPeerCertificateVerificationError();
}
public TLSContext getContext() {
return context;
}
public final Signal onError = new Signal();
public final Signal onConnected = new Signal();
private final TLSContext context;
}
|