mirror of
https://github.com/taigrr/nats.docs
synced 2025-01-18 04:03:23 -08:00
214 lines
8.3 KiB
HTML
214 lines
8.3 KiB
HTML
|
|
<div class="tab-wrap">
|
|
|
|
|
|
<input type="radio" id="connect_tls_go" name="connect_tls" class="tab" checked>
|
|
|
|
<label for="connect_tls_go" class="api-lang" data-language="go">Go</label>
|
|
|
|
|
|
<input type="radio" id="connect_tls_java" name="connect_tls" class="tab">
|
|
|
|
<label for="connect_tls_java" class="api-lang" data-language="java">Java</label>
|
|
|
|
|
|
<input type="radio" id="connect_tls_js" name="connect_tls" class="tab">
|
|
|
|
<label for="connect_tls_js" class="api-lang" data-language="js">JavaScript</label>
|
|
|
|
|
|
<input type="radio" id="connect_tls_py" name="connect_tls" class="tab">
|
|
|
|
<label for="connect_tls_py" class="api-lang" data-language="py">Python</label>
|
|
|
|
|
|
<input type="radio" id="connect_tls_ruby" name="connect_tls" class="tab">
|
|
|
|
<label for="connect_tls_ruby" class="api-lang" data-language="ruby">Ruby</label>
|
|
|
|
|
|
<input type="radio" id="connect_tls_ts" name="connect_tls" class="tab">
|
|
|
|
<label for="connect_tls_ts" class="api-lang" data-language="ts">TypeScript</label>
|
|
|
|
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_go_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/go-nats-examples/blob/master/api-examples/connect_tls/main.go#L10-21"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-go">nc, err := nats.Connect("localhost",
|
|
nats.ClientCert("resources/certs/cert.pem", "resources/certs/key.pem"),
|
|
nats.RootCAs("resources/certs/ca.pem"))
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
defer nc.Close()
|
|
|
|
// Do something with the connection
|
|
|
|
</code></pre>
|
|
</div>
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_java_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/java-nats-examples/blob/master/src/main/java/io/nats/examples/ConnectTLS.java#L18-81"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-java">class SSLUtils {
|
|
public static String KEYSTORE_PATH = "src/main/resources/keystore.jks";
|
|
public static String TRUSTSTORE_PATH = "src/main/resources/cacerts";
|
|
public static String STORE_PASSWORD = "password";
|
|
public static String KEY_PASSWORD = "password";
|
|
public static String ALGORITHM = "SunX509";
|
|
|
|
public static KeyStore loadKeystore(String path) throws Exception {
|
|
KeyStore store = KeyStore.getInstance("JKS");
|
|
BufferedInputStream in = new BufferedInputStream(new FileInputStream(path));
|
|
|
|
try {
|
|
store.load(in, STORE_PASSWORD.toCharArray());
|
|
} finally {
|
|
if (in != null) {
|
|
in.close();
|
|
}
|
|
}
|
|
|
|
return store;
|
|
}
|
|
|
|
public static KeyManager[] createTestKeyManagers() throws Exception {
|
|
KeyStore store = loadKeystore(KEYSTORE_PATH);
|
|
KeyManagerFactory factory = KeyManagerFactory.getInstance(ALGORITHM);
|
|
factory.init(store, KEY_PASSWORD.toCharArray());
|
|
return factory.getKeyManagers();
|
|
}
|
|
|
|
public static TrustManager[] createTestTrustManagers() throws Exception {
|
|
KeyStore store = loadKeystore(TRUSTSTORE_PATH);
|
|
TrustManagerFactory factory = TrustManagerFactory.getInstance(ALGORITHM);
|
|
factory.init(store);
|
|
return factory.getTrustManagers();
|
|
}
|
|
|
|
public static SSLContext createSSLContext() throws Exception {
|
|
SSLContext ctx = SSLContext.getInstance(Options.DEFAULT_SSL_PROTOCOL);
|
|
ctx.init(createTestKeyManagers(), createTestTrustManagers(), new SecureRandom());
|
|
return ctx;
|
|
}
|
|
}
|
|
|
|
public class ConnectTLS {
|
|
public static void main(String[] args) {
|
|
|
|
try {
|
|
SSLContext ctx = SSLUtils.createSSLContext();
|
|
Options options = new Options.Builder().
|
|
server("nats://localhost:4222").
|
|
sslContext(ctx). // Set the SSL context
|
|
build();
|
|
Connection nc = Nats.connect(options);
|
|
|
|
// Do something with the connection
|
|
|
|
nc.close();
|
|
} catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
}
|
|
</code></pre>
|
|
</div>
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_js_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/node-nats-examples/blob/master/src/tls_samples.js#L44-56"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-javascript">let caCert = fs.readFileSync(caCertPath);
|
|
let clientCert = fs.readFileSync(clientCertPath);
|
|
let clientKey = fs.readFileSync(clientKeyPath);
|
|
let nc = NATS.connect({
|
|
url: url,
|
|
tls: {
|
|
ca: [caCert],
|
|
key: [clientKey],
|
|
cert: [clientCert]
|
|
}
|
|
});
|
|
</code></pre>
|
|
</div>
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_py_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/asyncio-nats-examples/blob/master/connect_tls.py#L7-20"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-python">nc = NATS()
|
|
|
|
ssl_ctx = ssl.create_default_context(purpose=ssl.Purpose.SERVER_AUTH)
|
|
ssl_ctx.load_verify_locations('ca.pem')
|
|
ssl_ctx.load_cert_chain(certfile='client-cert.pem',
|
|
keyfile='client-key.pem')
|
|
await nc.connect(io_loop=loop, tls=ssl_ctx)
|
|
|
|
await nc.connect(servers=["nats://demo.nats.io:4222"], tls=ssl_ctx)
|
|
|
|
# Do something with the connection.
|
|
|
|
</code></pre>
|
|
</div>
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_ruby_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/ruby-nats-examples/blob/master/connect_tls.rb#L3-51"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-ruby">EM.run do
|
|
|
|
options = {
|
|
:servers => [
|
|
'nats://localhost:4222',
|
|
],
|
|
:tls => {
|
|
:private_key_file => './spec/configs/certs/key.pem',
|
|
:cert_chain_file => './spec/configs/certs/server.pem'
|
|
}
|
|
}
|
|
|
|
NATS.connect(options) do |nc|
|
|
puts "#{Time.now.to_f} - Connected to NATS at #{nc.connected_server}"
|
|
|
|
nc.subscribe("hello") do |msg|
|
|
puts "#{Time.now.to_f} - Received: #{msg}"
|
|
end
|
|
|
|
nc.flush do
|
|
nc.publish("hello", "world")
|
|
end
|
|
|
|
EM.add_periodic_timer(0.1) do
|
|
next unless nc.connected?
|
|
nc.publish("hello", "hello")
|
|
end
|
|
|
|
# Set default callbacks
|
|
nc.on_error do |e|
|
|
puts "#{Time.now.to_f } - Error: #{e}"
|
|
end
|
|
|
|
nc.on_disconnect do |reason|
|
|
puts "#{Time.now.to_f} - Disconnected: #{reason}"
|
|
end
|
|
|
|
nc.on_reconnect do |nc|
|
|
puts "#{Time.now.to_f} - Reconnected to NATS server at #{nc.connected_server}"
|
|
end
|
|
|
|
nc.on_close do
|
|
puts "#{Time.now.to_f} - Connection to NATS closed"
|
|
EM.stop
|
|
end
|
|
end
|
|
end
|
|
</code></pre>
|
|
</div>
|
|
|
|
<div class="tab__content">
|
|
<pre id="connect_tls_ts_content"><a class="toolbar-icons pull-right" target="_blank" href="https://github.com/nats-io/ts-nats-examples/blob/master/src/tls_samples.ts#L40-52"><i class="mdi mdi-github-circle" title="View on GitHub"></i></a><a class="toolbar-icons pull-right"><i class="mdi mdi-content-copy js-copy" title="Copy to Clipboard"></i></a><span class="copy-msg pull-right"></span><code class="language-javascript">let caCert = readFileSync(caCertPath);
|
|
let clientCert = readFileSync(clientCertPath);
|
|
let clientKey = readFileSync(clientKeyPath);
|
|
let nc = await connect({
|
|
url: url,
|
|
tls: {
|
|
ca: [caCert],
|
|
key: [clientKey],
|
|
cert: [clientCert]
|
|
}
|
|
});
|
|
</code></pre>
|
|
</div>
|
|
|
|
</div>
|