-
Notifications
You must be signed in to change notification settings - Fork 26
/
SimpleClientEncryption.java
66 lines (55 loc) · 2.65 KB
/
SimpleClientEncryption.java
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
/*
* Copyright (c) 2017, Joyent, Inc. All rights reserved.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/
import com.joyent.manta.client.MantaClient;
import com.joyent.manta.client.MantaObjectResponse;
import com.joyent.manta.config.*;
import static com.joyent.manta.client.MantaClient.SEPARATOR;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
import java.io.IOException;
import java.io.InputStream;
import java.util.Scanner;
/*
* Usage: set the mantaUserName, privateKeyPath, and publicKeyId with your own values.
*/
public class SimpleClientEncryption {
public static void main(String... args) throws IOException {
String mantaUserName = "USERNAME";
String privateKeyPath = "PATH/.ssh/id_rsa";
String publicKeyId = "04:92:7b:23:bc:08:4f:d7:3b:5a:38:9e:4a:17:2e:df";
ConfigContext config = new ChainedConfigContext(
new DefaultsConfigContext(),
new EnvVarConfigContext(),
new MapConfigContext(System.getProperties()))
.setMantaURL("https://us-east.manta.joyent.com")
// If there is no subuser, then just use the account name
.setMantaUser(mantaUserName)
.setMantaKeyPath(privateKeyPath)
.setMantaKeyId(publicKeyId)
.setClientEncryptionEnabled(true)
.setEncryptionAlgorithm("AES256/CTR/NoPadding")
.setEncryptionAuthenticationMode(EncryptionAuthenticationMode.Mandatory)
.setPermitUnencryptedDownloads(false)
.setEncryptionKeyId("simple/example")
.setEncryptionPrivateKeyBytes(Base64.getDecoder().decode("RkZGRkZGRkJEOTY3ODNDNkM5MUUyMjIyMTExMTIyMjI="));
try (MantaClient client = new MantaClient(config)) {
String mantaPath = SEPARATOR + mantaUserName + SEPARATOR
+ "stor" + SEPARATOR + "foo";
MantaObjectResponse response = client.put(mantaPath, "This is my secret\nthat I want encrypted.");
System.out.println("HTTP Response headers:");
System.out.println(response.getHttpHeaders().toString());
// Print out every line from file streamed real-time from Manta
try (InputStream is = client.getAsInputStream(mantaPath);
Scanner scanner = new Scanner(is, StandardCharsets.UTF_8.name())) {
while (scanner.hasNextLine()) {
System.out.println(scanner.nextLine());
}
}
}
}
}