Sunday, August 25, 2013

OPEN SSL Commands

OPEN SSL to create PKCS12 Keystore

A root certificate is a fundamental component of the Public Key Infrastructure (PKI) that forms the backbone of secure communications on the internet. It is issued by a trusted entity called a Certificate Authority (CA) and is used to establish trust for a chain of certificates.


Key Characteristics of a Root Certificate:

  1. Self-Signed Certificate:

    • A root certificate is self-signed, meaning it is signed by the Certificate Authority (CA) itself.
    • This makes it the "trust anchor" of the certificate chain.
  2. Trusted by Operating Systems and Browsers:

    • Root certificates are pre-installed in the trust stores of operating systems (e.g., Windows, macOS, Linux) and browsers (e.g., Chrome, Firefox).
    • If a root certificate is in the trust store, all certificates signed by it (or intermediates it has signed) are trusted.
  3. Top of the Certificate Chain:

    • In the certificate chain, the root certificate is at the top, followed by one or more intermediate certificates, and finally the end-entity certificate (e.g., a website certificate).

Structure of a Root Certificate:

A root certificate includes:

  • Issuer: The name of the CA that issued the root certificate (usually itself, since it's self-signed).
  • Subject: The name of the entity the certificate is issued to (the CA itself).
  • Public Key: The CA's public key, used to verify signatures.
  • Validity Period: The start and expiry dates of the certificate.
  • Signature Algorithm: The cryptographic algorithm used to create the certificate's signature.

Why Root Certificates Are Important:

  1. Trust Establishment:

    • Root certificates enable secure connections (e.g., HTTPS, email encryption) by creating a chain of trust.
  2. Certificate Chain Validation:

    • When you visit a website, your browser validates the website’s certificate by following the chain of trust back to a root certificate in its trust store.
  3. Security:

    • Root certificates ensure that only trusted parties (like websites or services) can communicate securely with users.

Example of a Certificate Chain:

  1. Root Certificate:

    • Issued by "GlobalSign Root CA."
    • Installed in your system/browser's trust store.
  2. Intermediate Certificate:

    • Issued by "GlobalSign Intermediate CA" and signed by the root certificate.
  3. End-Entity Certificate:

    • Issued to "example.com" and signed by the intermediate certificate.

When you visit example.com, the browser validates the chain:

  • The end-entity certificate is trusted because it is signed by the intermediate certificate.
  • The intermediate certificate is trusted because it is signed by the root certificate.

1.)Create a Self Signed Certificate
openssl req -x509 -nodes -days 365  -newkey rsa:1024 -keyout selfsigned.pem -out selfsigned.pem

2.) Verify a self-signed certificate
openssl verify selfsigned.pem

3.) Export selfsigned.pem as PKCS#12 file, identity.pfx 
openssl pkcs12 -export -out identity.pfx -in selfsigned.pem -name "selfsigned"

4:) Extract public certificate from url
openssl s_client -showcerts -connect core-integrations.mindtelligent.com:443 </dev/null 2>/dev/null | openssl x509 -outform PEM > certificate.pem

5:) Extract Private Key

If you have a .p7b (PKCS#7) certificate file and need to extract the private key, it’s important to note that .p7b files typically do not include the private key. They usually only contain the certificate chain (public certificates).

If you still want to extract a private key and believe the key is associated with this file, you will need the original private key that was created during the Certificate Signing Request (CSR) process or convert the .p7b to another format like .pem to handle certificates and key extraction.


To extract the private key from a .p12 (PKCS#12) file, you can use the openssl command. Here's how to do it:


 openssl pkcs12 -in ./core-integrations.mindtelligent.com.p12 -out privatekey.pem -nodes -password pass:password123

6:) Extract Certificate Chain
 
 openssl pkcs12 -in core-integrations.mindtelligent.com.p12 -clcerts -nokeys -out  core-integrations-mindtelligent.com.certchain.pem -password pass:password123




Use SSH Keys to clone GIT Repository using SSH

  1. Generate a New SSH Key Pair bash ssh-keygen -t rsa -b 4096 -C "HSingh@MindTelligent.com" -t rsa specifies the type of key (...