Substitute the names of your systems for the names host1 and host2 in this procedure. You configure both IKE endpoints.
Before You Begin
You must become an administrator who is assigned the Network IPsec Management rights profile. You must be typing in a profile shell. For more information, see Using Your Assigned Administrative Rights in Securing Users and Processes in Oracle Solaris 11.3.
If you administer remotely, see Example 31, Configuring IPsec Policy Remotely by Using an ssh Connection and How to Remotely Administer ZFS With Secure Shell in Managing Secure Shell Access in Oracle Solaris 11.3 for secure remote login instructions.
# pfedit /etc/inet/ike/ikev2.config
The rules and global parameters in this file must manage the keys in the IPsec policy in the system's ipsecinit.conf file. The following IKEv2 configuration examples manage the keys of the ipsecinit.conf examples in How to Secure Network Traffic Between Two Servers With IPsec.
### ikev2.config file on host1, 192.0.2.16
## Global parameters
# This default value will apply to all transforms that follow
#
ikesa_lifetime_secs 3600
#
# Global transform definitions.  The algorithm choices are
# based on RFC 4921.
#
## Two transforms are acceptable to this system, Group 20 and Group 19.
## A peer can be configured with 19 or 20.
## To ensure that a particular peer uses a specific transform,
## include the transform in the rule.
## 
# Group 20 is 384-bit ECP - Elliptic Curve over Prime
ikesa_xform { encr_alg aes(256..256) auth_alg sha384 dh_group 20 }
# Group 19 is 256-bit ECP
ikesa_xform { encr_alg aes(128..128) auth_alg sha256 dh_group 19 }
#
## The rule to communicate with host2
##  Label must be unique
{ label "host1-host2"
  auth_method preshared
  local_addr  192.0.2.16
  remote_addr 192.0.2.213
}
## ikev2.config file on host2, 192.0.2.213
## Global Parameters
#
...
ikesa_xform { encr_alg aes(256..256) auth_alg sha384 dh_group 20 }
ikesa_xform { encr_alg aes(128..128) auth_alg sha256 dh_group 19 }
...
## The rule to communicate with host1
##  Label must be unique
{ label "host2-host1"
  auth_method preshared
  local_addr  192.0.2.213
  remote_addr 192.0.2.16
}
# /usr/lib/inet/in.ikev2d -c
An AES key of at least 256 bits is a good choice.
For a full description of how to create a key, see How to Generate a Symmetric Key by Using the pktool Command in Managing Encryption and Certificates in Oracle Solaris 11.3.
For examples of key generation, see Example 40, Generating a Preshared Key for IKEv2 and Example 41, Using Different Local and Remote IKEv2 Preshared Keys.
|  | Caution - This file has special permissions and is owned by ikeuser. Never delete or replace this file. Instead, use the pfedit -s command to edit its contents so that the file retains its original properties and the contents do not appear in the audit log. | 
# pfedit -s /etc/inet/ike/ikev2.preshared
## ikev2.preshared on host1, 192.0.2.16
# ...
## label must match the rule that uses this key
{ label "host1-host2"
   key  "1011e1f2d1fd..."
}
For information about the options to the pfedit command, see the pfedit(1M) man page.
## ikev2.preshared on host2, 192.0.2.213
# ...
## label must match the label of the rule that uses this key
{ label "host2-host1"
   key  "1011e1f2d1fd..."
}
# svcadm enable ipsec/ike:ikev2
When replacing the preshared key, edit the preshared key files on the peer systems and restart the ikev2 service.
# svcadm restart ikev2
In the following example, the administrator manually creates the keying material for two systems that are protected by IKE, local1 and remote1. The label of the preshared key entry matches the label in a rule in the ikev2.config file. Then, the administrator copies the key to the /etc/ike/ikev2.preshared file and destroys the original key file.
First, the administrator creates and displays the preshared key.
local1$ pktool genkey keystore=file outkey=ike2psk keytype=aes keylen=256 print=y Key Value ="2b823670b5aa1a..."
The administrator adds the key to the ikev2.preshared file on local1.
{ label "local1-remote1"
   key  "2b823670b5aa1a..."
}
          The administrator destroys the original key file.
$ rm ike2psk
The administrator copies the ikev2.preshared file to the communicating system by using the ssh command or another secure mechanism.
On remote1, the administrator appends the ikev2.preshared file to an existing /etc/inet/ike/ikev2.preshared file, or creates a new file.
Then, the administrator changes the label to match the rule in the ikev2.config file.
{ label "remote1-local1"
   key "2b823670b5aa1a..."
}
          In this example, the IKEv2 administrators create a preshared key per system, exchange them, and add each key to the /etc/inet/ike/ikev2.preshared file. The label of the preshared key entry matches the label in a rule in the ikev2.config file. Then, they restart the in.ikev2d daemons.
On host1, the administrator generates two keys.
$ pktool genkey keystore=file outkey=ikemykey keytype=aes keylen=256 print=y Key Value ="e6fc5402efd08..." $ pktool genkey keystore=file outkey=ikeotherkey keytype=aes keylen=256 print=y Key Value ="01ca0f4d32923..."
The administrator places the keys in the ikev2.preshared file.
##...
{ label "host1-host2"
## local and remote preshared keys 
  local_key  "e6fc5402efd08..."
  remote_key "01ca0f4d32923..."
}
          The administrator destroys the original keys files.
$ rm ikemykey ikeotherkey
The administrator copies the ikev2.preshared file to host2 by using the ssh command or another secure mechanism.
After receiving the other system's preshared key, the administrator edits the ikev2.preshared file. The file on host2 is the following:
##...
{ label "host2-host1"
## local and remote preshared keys 
  local_key  "01ca0f4d32923..."
  remote_key "e6fc5402efd08..."
}
          The administrators restart the IKEv2 service instance on each system.
# svcadm restart ikev2
Next Steps
If you have not completed establishing IPsec policy, return to the IPsec procedure to enable or refresh IPsec policy. For examples of IPsec policy protecting VPNs, see Protecting a VPN With IPsec. For other examples of IPsec policy, see How to Secure Network Traffic Between Two Servers With IPsec.
For more examples, see the ikev2.config(4) and ikev2.preshared(4) man pages.