using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Globalization;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Security;
using System.Text;
using System.Threading.Tasks;
using Microsoft.VisualBasic;
// using Org.BouncyCastle.Crypto;
// using Org.BouncyCastle.Crypto.Engines;
// using Org.BouncyCastle.Crypto.Generators;
// using Org.BouncyCastle.Crypto.Modes;
// using Org.BouncyCastle.Crypto.Parameters;
// using Org.BouncyCastle.Security;
// using System.Configuration;

public class AES_GCM
{
    // Public Shared ReadOnly Random As Org.BouncyCastle.Security.SecureRandom = New SecureRandom()

    public static string SimpleEncryptWithPassword(string secretMessage, string password, byte[] nonSecretPayload = null)
    {
        if (string.IsNullOrEmpty(secretMessage))
            throw new ArgumentException("Secret Message Required!", "secretMessage");
        var plainText = Encoding.UTF8.GetBytes(secretMessage);
        var cipherText = SimpleEncryptWithPassword(plainText, password, nonSecretPayload);
        return Convert.ToBase64String(cipherText);
    }


    public static string SimpleDecryptWithPassword(string encryptedMessage, string password, int nonSecretPayloadLength = 0)
    {
        try
        {
            if (string.IsNullOrWhiteSpace(encryptedMessage))
                throw new ArgumentException("Encrypted Message Required!", "encryptedMessage");
            var cipherText = Convert.FromBase64String(encryptedMessage.TrimEnd(System.Convert.ToChar(0x0)));
            var plainText = SimpleDecryptWithPassword(cipherText, password, nonSecretPayloadLength);
            return plainText == null ? null : Encoding.UTF8.GetString(plainText);
        }
        catch (Exception ex)
        {
            LogManager.Log(ex);
            return null;
        }
    }

    public static byte[] SimpleEncrypt(byte[] secretMessage, byte[] key, byte[] nonSecretPayload = null)
    {
        if (key == null || key.Length != Convert.ToInt32(ConfigurationManager.AppSettings["KeyBitSize"], 16) / (double)8)
            throw new ArgumentException("Key needs to be {KeyBitSize} bit!", "key");
        if (secretMessage == null || secretMessage.Length == 0)
            throw new ArgumentException("Secret Message Required!", "secretMessage");
        nonSecretPayload = nonSecretPayload ?? new byte[] { };
        var nonce = new byte[System.Convert.ToInt32(Convert.ToInt32(ConfigurationManager.AppSettings["NonceBitSize"], 16) / (double)8 - 1) + 1];
        System.Security.Cryptography.RNGCryptoServiceProvider ran = new System.Security.Cryptography.RNGCryptoServiceProvider();
        ran.GetBytes(nonce);
        BitConverter.ToInt32(nonce, 0);


        var cipher = new GcmBlockCipher(new AesEngine());
        var parameters = new AeadParameters(new KeyParameter(key), Convert.ToInt32(ConfigurationManager.AppSettings["MacBitSize"], 16), nonce, nonSecretPayload);
        cipher.Init(true, parameters);
        var cipherText = new byte[cipher.GetOutputSize(secretMessage.Length) - 1 + 1];
        var len = cipher.ProcessBytes(secretMessage, 0, secretMessage.Length, cipherText, 0);
        cipher.DoFinal(cipherText, len);

        using (var combinedStream = new MemoryStream())
        {
            using (var binaryWriter = new BinaryWriter(combinedStream))
            {
                binaryWriter.Write(nonSecretPayload);
                binaryWriter.Write(nonce);
                binaryWriter.Write(cipherText);
            }

            return combinedStream.ToArray();
        }
    }

    public static byte[] SimpleDecrypt(byte[] encryptedMessage, byte[] key, int nonSecretPayloadLength = 0)
    {  
        if (key == null || key.Length != Convert.ToInt32(ConfigurationManager.AppSettings["KeyBitSize"], 16) / (double)8)
            throw new ArgumentException("Key needs to be {KeyBitSize} bit!", "key");
        if (encryptedMessage == null || encryptedMessage.Length == 0)
            throw new ArgumentException("Encrypted Message Required!", "encryptedMessage");

        using (var cipherStream = new MemoryStream(encryptedMessage))
        {
            using (var cipherReader = new BinaryReader(cipherStream))
            {
                var nonSecretPayload = cipherReader.ReadBytes(nonSecretPayloadLength);
                var nonce = cipherReader.ReadBytes(System.Convert.ToInt32(Convert.ToInt32(ConfigurationManager.AppSettings["NonceBitSize"], 16) / (double)8));
                var cipher = new GcmBlockCipher(new AesEngine());
                var parameters = new AeadParameters(new KeyParameter(key), Convert.ToInt32(ConfigurationManager.AppSettings["MacBitSize"], 16), nonce, nonSecretPayload);
                cipher.Init(false, parameters);
                var cipherText = cipherReader.ReadBytes(encryptedMessage.Length - nonSecretPayloadLength - nonce.Length);
                var plainText = new byte[cipher.GetOutputSize(cipherText.Length) - 1 + 1];

                try
                {
                    var len = cipher.ProcessBytes(cipherText, 0, cipherText.Length, plainText, 0);
                    cipher.DoFinal(plainText, len);
                }
                catch (InvalidCipherTextException unusedInvalidCipherTextException1)
                {
                    return null;
                }

                return plainText;
            }
        }
    }

    public static byte[] SimpleEncryptWithPassword(byte[] secretMessage, string password, byte[] nonSecretPayload = null)
    {
        nonSecretPayload = nonSecretPayload ?? new byte[] { };
        if (string.IsNullOrWhiteSpace(password))
            throw new ArgumentException("Must have a password ", "password");
        if (secretMessage == null || secretMessage.Length == 0)
            throw new ArgumentException("Secret Message Required!", "secretMessage");
        var generator = new Pkcs5S2ParametersGenerator();
        var salt = new byte[System.Convert.ToInt32(Convert.ToInt32(ConfigurationManager.AppSettings["SaltBitSize"], 16) / (double)8 - 1) + 1];
        System.Security.Cryptography.RNGCryptoServiceProvider ran = new System.Security.Cryptography.RNGCryptoServiceProvider();
        ran.GetBytes(salt);
        BitConverter.ToInt32(salt, 0);
        generator.Init(PbeParametersGenerator.Pkcs5PasswordToBytes(password.ToCharArray()), salt, Convert.ToInt32(ConfigurationManager.AppSettings["Iterations"], 16));
        var key = (KeyParameter)generator.GenerateDerivedMacParameters(Convert.ToInt32(ConfigurationManager.AppSettings["KeyBitSize"], 16));
        var payload = new byte[salt.Length + nonSecretPayload.Length - 1 + 1];
        Array.Copy(nonSecretPayload, payload, nonSecretPayload.Length);
        Array.Copy(salt, 0, payload, nonSecretPayload.Length, salt.Length);
        return SimpleEncrypt(secretMessage, key.GetKey(), payload);
    }

    public static byte[] SimpleDecryptWithPassword(byte[] encryptedMessage, string password, int nonSecretPayloadLength = 0)
    {
        try
        {
            if (string.IsNullOrWhiteSpace(password))
                throw new ArgumentException("Must have a password of at least MinPasswordLength characters!");
            if (encryptedMessage == null || encryptedMessage.Length == 0)
                throw new ArgumentException("Encrypted Message Required!", "encryptedMessage");
            var generator = new Pkcs5S2ParametersGenerator();
            var salt = new byte[System.Convert.ToInt32(Convert.ToInt32(ConfigurationManager.AppSettings["SaltBitSize"], 16) / (double)8 - 1) + 1];
            Array.Copy(encryptedMessage, nonSecretPayloadLength, salt, 0, salt.Length);
            generator.Init(PbeParametersGenerator.Pkcs5PasswordToBytes(password.ToCharArray()), salt, Convert.ToInt32(ConfigurationManager.AppSettings["Iterations"], 16));

            var key = (KeyParameter)generator.GenerateDerivedMacParameters(Convert.ToInt32(ConfigurationManager.AppSettings["KeyBitSize"], 16));
            return SimpleDecrypt(encryptedMessage, key.GetKey(), salt.Length + nonSecretPayloadLength);
        }
        catch (Exception ex)
        {
            LogManager.Log(ex);
            return null;
        }
    }
}
 

C Sharp Online Compiler

Write, Run & Share C# code online using OneCompiler's C# online compiler for free. It's one of the robust, feature-rich online compilers for C# language, running on the latest version 8.0. Getting started with the OneCompiler's C# compiler is simple and pretty fast. The editor shows sample boilerplate code when you choose language as C# and start coding.

Read inputs from stdin

OneCompiler's C# online compiler supports stdin and users can give inputs to programs using the STDIN textbox under the I/O tab. Following is a sample program which takes name as input and print your name with hello.

using System;
 
namespace Sample
{
  class Test
    {
      public static void Main(string[] args)
       {
         string name;
         name = Console.ReadLine();
         Console.WriteLine("Hello {0} ", name);
	}
     }
}

About C Sharp

C# is a general purpose object-oriented programming language by Microsoft. Though initially it was developed as part of .net but later it was approved by ECMA and ISO standards.

You can use C# to create variety of applications, like web, windows, mobile, console applications and much more using Visual studio.

Syntax help

Data types

Data TypeDescriptionRangesize
intTo store integers-2,147,483,648 to 2,147,483,6474 bytes
doubleto store large floating point numbers with decimalscan store 15 decimal digits8 bytes
floatto store floating point numbers with decimalscan store upto 7 decimal digits4 bytes
charto store single characters-2 bytes
stringto stores text-2 bytes per character
boolto stores either true or false-1 bit

Variables

Syntax

datatype variable-name = value;

Loops

1. If-Else:

When ever you want to perform a set of operations based on a condition or set of few conditions IF-ELSE is used.

if(conditional-expression) {
   // code
} 
else {
   // code
}

You can also use if-else for nested Ifs and If-Else-If ladder when multiple conditions are to be performed on a single variable.

2. Switch:

Switch is an alternative to If-Else-If ladder.

switch(conditional-expression) {    
case value1:    
 // code    
 break;  // optional  
case value2:    
 // code    
 break;  // optional  
...    
    
default:     
 // code to be executed when all the above cases are not matched;    
} 

3. For:

For loop is used to iterate a set of statements based on a condition.

for(Initialization; Condition; Increment/decrement) {
  // code  
} 

4. While:

While is also used to iterate a set of statements based on a condition. Usually while is preferred when number of iterations are not known in advance.

while(condition) {
 // code 
}

5. Do-While:

Do-while is also used to iterate a set of statements based on a condition. It is mostly used when you need to execute the statements atleast once.

do {
  // code 
} while (condition);

Arrays

Array is a collection of similar data which is stored in continuous memory addresses. Array values can be fetched using index. Index starts from 0 to size-1.

Syntax

data-type[] array-name;

Methods

Method is a set of statements which gets executed only when they are called. Call the method name in the main function to execute the method.

Syntax

static void method-name() 
{
  // code to be executed
}