From 165c0b82bf13ec4250de03c67e003ed01557e4e6 Mon Sep 17 00:00:00 2001 From: Rory Rezzelle Date: Tue, 26 Jan 2021 17:11:24 -0500 Subject: [PATCH] Changed download site from MEGA to MediaFire. --- App.config | 6 +- Form1.Designer.cs | 48 +- Form1.cs | 397 +- Omnibus.csproj | 21 + bin/Debug/MediaFireSDK.dll | Bin 0 -> 113664 bytes bin/Debug/Omnibus.exe | Bin 67584 -> 68096 bytes bin/Debug/Omnibus.exe.config | 74 +- bin/Debug/Omnibus.pdb | Bin 62976 -> 67072 bytes bin/Debug/System.Net.Http.Extensions.dll | Bin 0 -> 22264 bytes bin/Debug/System.Net.Http.Extensions.xml | 50 + bin/Debug/System.Net.Http.Formatting.dll | Bin 0 -> 185544 bytes bin/Debug/System.Net.Http.Formatting.xml | 2094 ++ bin/Debug/System.Net.Http.Primitives.dll | Bin 0 -> 21744 bytes bin/Debug/System.Net.Http.Primitives.xml | 8 + bin/Debug/crypto.dll | Bin 0 -> 1375232 bytes bin/Debug/crypto.xml | 19296 ++++++++++++++++ ...gnTimeResolveAssemblyReferencesInput.cache | Bin 10926 -> 18557 bytes obj/Debug/Omnibus.csproj.App.config | 53 + .../Omnibus.csproj.CoreCompileInputs.cache | 2 +- obj/Debug/Omnibus.csproj.FileListAbsolute.txt | 10 + .../Omnibus.csproj.GenerateResource.cache | Bin 1359 -> 1359 bytes .../Omnibus.csprojAssemblyReference.cache | Bin 284002 -> 334323 bytes obj/Debug/Omnibus.exe | Bin 67584 -> 68096 bytes obj/Debug/Omnibus.pdb | Bin 62976 -> 67072 bytes obj/Release/Omnibus.csproj.App.config | 53 + .../Omnibus.csproj.CoreCompileInputs.cache | 2 +- .../Omnibus.csproj.FileListAbsolute.txt | 10 + .../Omnibus.csproj.GenerateResource.cache | Bin 1359 -> 1359 bytes obj/Release/Omnibus.exe | Bin 62976 -> 64512 bytes obj/Release/Omnibus.pdb | Bin 56832 -> 58880 bytes packages.config | 6 + 31 files changed, 22014 insertions(+), 116 deletions(-) create mode 100644 bin/Debug/MediaFireSDK.dll create mode 100644 bin/Debug/System.Net.Http.Extensions.dll create mode 100644 bin/Debug/System.Net.Http.Extensions.xml create mode 100644 bin/Debug/System.Net.Http.Formatting.dll create mode 100644 bin/Debug/System.Net.Http.Formatting.xml create mode 100644 bin/Debug/System.Net.Http.Primitives.dll create mode 100644 bin/Debug/System.Net.Http.Primitives.xml create mode 100644 bin/Debug/crypto.dll create mode 100644 bin/Debug/crypto.xml create mode 100644 obj/Debug/Omnibus.csproj.App.config create mode 100644 obj/Release/Omnibus.csproj.App.config diff --git a/App.config b/App.config index 9db9329..6570d07 100644 --- a/App.config +++ b/App.config @@ -34,7 +34,11 @@ - + + + + + diff --git a/Form1.Designer.cs b/Form1.Designer.cs index 0659923..edae1d8 100644 --- a/Form1.Designer.cs +++ b/Form1.Designer.cs @@ -54,6 +54,7 @@ private void InitializeComponent() this.cmsComics = new System.Windows.Forms.ContextMenuStrip(this.components); this.search = new System.Windows.Forms.ToolStripMenuItem(); this.validate = new System.Windows.Forms.ToolStripMenuItem(); + this.validateMF = new System.Windows.Forms.ToolStripMenuItem(); ((System.ComponentModel.ISupportInitialize)(this.pbCover)).BeginInit(); this.contextMenuStrip1.SuspendLayout(); this.cmsComics.SuspendLayout(); @@ -65,7 +66,7 @@ private void InitializeComponent() | System.Windows.Forms.AnchorStyles.Right))); this.lbComics.FormattingEnabled = true; this.lbComics.Location = new System.Drawing.Point(9, 113); - this.lbComics.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.lbComics.Margin = new System.Windows.Forms.Padding(2); this.lbComics.Name = "lbComics"; this.lbComics.Size = new System.Drawing.Size(402, 186); this.lbComics.TabIndex = 2; @@ -85,7 +86,7 @@ private void InitializeComponent() // tbComicSearch // this.tbComicSearch.Location = new System.Drawing.Point(9, 34); - this.tbComicSearch.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.tbComicSearch.Margin = new System.Windows.Forms.Padding(2); this.tbComicSearch.Name = "tbComicSearch"; this.tbComicSearch.Size = new System.Drawing.Size(216, 20); this.tbComicSearch.TabIndex = 0; @@ -94,7 +95,7 @@ private void InitializeComponent() // btnSearch // this.btnSearch.Location = new System.Drawing.Point(228, 31); - this.btnSearch.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnSearch.Margin = new System.Windows.Forms.Padding(2); this.btnSearch.Name = "btnSearch"; this.btnSearch.Size = new System.Drawing.Size(56, 25); this.btnSearch.TabIndex = 1; @@ -105,7 +106,7 @@ private void InitializeComponent() // btnOpenLink // this.btnOpenLink.Location = new System.Drawing.Point(9, 85); - this.btnOpenLink.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnOpenLink.Margin = new System.Windows.Forms.Padding(2); this.btnOpenLink.Name = "btnOpenLink"; this.btnOpenLink.Size = new System.Drawing.Size(70, 23); this.btnOpenLink.TabIndex = 4; @@ -116,7 +117,7 @@ private void InitializeComponent() // btnDownload // this.btnDownload.Location = new System.Drawing.Point(83, 85); - this.btnDownload.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnDownload.Margin = new System.Windows.Forms.Padding(2); this.btnDownload.Name = "btnDownload"; this.btnDownload.Size = new System.Drawing.Size(101, 23); this.btnDownload.TabIndex = 5; @@ -129,7 +130,7 @@ private void InitializeComponent() this.tbDesc.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) | System.Windows.Forms.AnchorStyles.Right))); this.tbDesc.Location = new System.Drawing.Point(9, 303); - this.tbDesc.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.tbDesc.Margin = new System.Windows.Forms.Padding(2); this.tbDesc.Name = "tbDesc"; this.tbDesc.ReadOnly = true; this.tbDesc.Size = new System.Drawing.Size(402, 103); @@ -139,7 +140,7 @@ private void InitializeComponent() // btnClear // this.btnClear.Location = new System.Drawing.Point(289, 31); - this.btnClear.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnClear.Margin = new System.Windows.Forms.Padding(2); this.btnClear.Name = "btnClear"; this.btnClear.Size = new System.Drawing.Size(58, 25); this.btnClear.TabIndex = 11; @@ -151,7 +152,7 @@ private void InitializeComponent() // this.button2.Image = global::Omnibus.Properties.Resources.downloads_32px; this.button2.Location = new System.Drawing.Point(590, 10); - this.button2.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.button2.Margin = new System.Windows.Forms.Padding(2); this.button2.Name = "button2"; this.button2.Size = new System.Drawing.Size(39, 42); this.button2.TabIndex = 13; @@ -162,7 +163,7 @@ private void InitializeComponent() // this.button1.Image = global::Omnibus.Properties.Resources.settings_32px; this.button1.Location = new System.Drawing.Point(546, 10); - this.button1.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.button1.Margin = new System.Windows.Forms.Padding(2); this.button1.Name = "button1"; this.button1.Size = new System.Drawing.Size(39, 42); this.button1.TabIndex = 12; @@ -176,7 +177,7 @@ private void InitializeComponent() this.pbCover.Image = global::Omnibus.Properties.Resources.omnibus_preview_image; this.pbCover.InitialImage = global::Omnibus.Properties.Resources.omnibus_preview_image; this.pbCover.Location = new System.Drawing.Point(415, 113); - this.pbCover.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.pbCover.Margin = new System.Windows.Forms.Padding(2); this.pbCover.Name = "pbCover"; this.pbCover.Size = new System.Drawing.Size(214, 292); this.pbCover.SizeMode = System.Windows.Forms.PictureBoxSizeMode.StretchImage; @@ -194,7 +195,7 @@ private void InitializeComponent() this.Progress}); this.lvDownloads.HideSelection = false; this.lvDownloads.Location = new System.Drawing.Point(9, 410); - this.lvDownloads.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.lvDownloads.Margin = new System.Windows.Forms.Padding(2); this.lvDownloads.Name = "lvDownloads"; this.lvDownloads.Scrollable = false; this.lvDownloads.Size = new System.Drawing.Size(620, 160); @@ -250,7 +251,7 @@ private void InitializeComponent() // this.btnLastPage.Enabled = false; this.btnLastPage.Location = new System.Drawing.Point(358, 85); - this.btnLastPage.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnLastPage.Margin = new System.Windows.Forms.Padding(2); this.btnLastPage.Name = "btnLastPage"; this.btnLastPage.Size = new System.Drawing.Size(23, 23); this.btnLastPage.TabIndex = 15; @@ -262,7 +263,7 @@ private void InitializeComponent() // this.btnNextPage.Enabled = false; this.btnNextPage.Location = new System.Drawing.Point(386, 85); - this.btnNextPage.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.btnNextPage.Margin = new System.Windows.Forms.Padding(2); this.btnNextPage.Name = "btnNextPage"; this.btnNextPage.Size = new System.Drawing.Size(23, 23); this.btnNextPage.TabIndex = 16; @@ -275,22 +276,32 @@ private void InitializeComponent() this.cmsComics.ImageScalingSize = new System.Drawing.Size(20, 20); this.cmsComics.Items.AddRange(new System.Windows.Forms.ToolStripItem[] { this.search, - this.validate}); + this.validate, + this.validateMF}); this.cmsComics.Name = "cmsComics"; - this.cmsComics.Size = new System.Drawing.Size(172, 48); + this.cmsComics.Size = new System.Drawing.Size(184, 92); + this.cmsComics.Opening += new System.ComponentModel.CancelEventHandler(this.cmsComics_Opening); this.cmsComics.ItemClicked += new System.Windows.Forms.ToolStripItemClickedEventHandler(this.cmsComics_ItemClicked); // // search // this.search.Name = "search"; - this.search.Size = new System.Drawing.Size(171, 22); + this.search.Size = new System.Drawing.Size(183, 22); this.search.Text = "Find more like this"; // // validate // this.validate.Name = "validate"; - this.validate.Size = new System.Drawing.Size(171, 22); + this.validate.Size = new System.Drawing.Size(183, 22); this.validate.Text = "Verify MEGA Link"; + this.validate.Click += new System.EventHandler(this.validate_Click); + // + // validateMF + // + this.validateMF.Name = "validateMF"; + this.validateMF.Size = new System.Drawing.Size(183, 22); + this.validateMF.Text = "Verify MediaFire Link"; + this.validateMF.Click += new System.EventHandler(this.verifyMediafireLinkToolStripMenuItem_Click); // // Form1 // @@ -312,7 +323,7 @@ private void InitializeComponent() this.Controls.Add(this.label1); this.Controls.Add(this.lbComics); this.Icon = ((System.Drawing.Icon)(resources.GetObject("$this.Icon"))); - this.Margin = new System.Windows.Forms.Padding(2, 2, 2, 2); + this.Margin = new System.Windows.Forms.Padding(2); this.Name = "Form1"; this.Load += new System.EventHandler(this.Form1_Load); ((System.ComponentModel.ISupportInitialize)(this.pbCover)).EndInit(); @@ -349,6 +360,7 @@ private void InitializeComponent() private System.Windows.Forms.ContextMenuStrip cmsComics; private System.Windows.Forms.ToolStripMenuItem search; private System.Windows.Forms.ToolStripMenuItem validate; + private System.Windows.Forms.ToolStripMenuItem validateMF; } } diff --git a/Form1.cs b/Form1.cs index 0c2fab9..2bae5ac 100644 --- a/Form1.cs +++ b/Form1.cs @@ -22,7 +22,7 @@ namespace Omnibus public partial class Form1 : Form { - private String version = "1.4.8.2"; + private String version = "1.4.8.4"; private String url = "https://getcomics.info/?s="; private int cancelled = 0; private bool isDownloading = false; @@ -221,35 +221,48 @@ private async void btnDownload_ClickAsync(object sender, EventArgs e) HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument(); doc.LoadHtml(data); - var htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='Mega Link']"); + //// FOR MEGA + //var htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='Mega Link']"); - if (htmlNodes == null) //Check to see if they just renamed the Node - { - htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='MEGA']"); - } + //if (htmlNodes == null) //Check to see if they just renamed the Node + //{ + // htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='MEGA']"); + //} + + //if (htmlNodes == null) + //{ + // foreach(HtmlNode node1 in doc.DocumentNode.SelectNodes("//a")) + // { + // if (node1.SelectNodes(".//span") != null) + // { + // foreach (HtmlNode node2 in node1.SelectNodes(".//span")) + // { + // string value = node2.InnerText; + // if (value == "Mega") + // { + // comicDLLink = node1.Attributes["href"].Value; + // } + + // } + // } + // } + //} + //else + //{ + // comicDLLink = htmlNodes.Attributes["href"].Value; + //} + + // FOR MEDIAFIRE + var htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='MEDIAFIRE']"); if (htmlNodes == null) { - foreach(HtmlNode node1 in doc.DocumentNode.SelectNodes("//a")) - { - if (node1.SelectNodes(".//span") != null) - { - foreach (HtmlNode node2 in node1.SelectNodes(".//span")) - { - string value = node2.InnerText; - if (value == "Mega") - { - comicDLLink = node1.Attributes["href"].Value; - } - - } - } - } + MessageBox.Show("No MediaFire button"); } else { comicDLLink = htmlNodes.Attributes["href"].Value; - } + } if (comicDLLink != "") { @@ -275,17 +288,54 @@ private async void btnDownload_ClickAsync(object sender, EventArgs e) */ //Check if the MEGA link is encrypted, decrypt Base64 string if it is - //!--- IT LOOKS LIKE THEY ARE NO LONGER ENCRYPTING THE LINKS, BUT KEEPING THIS IN JUST IN CASE ---!// + //!--- MEGA LINKS ARE NOW ENCRYPTED AND WE CANNOT DECRYPT THEM ---!// + //!--- ALL DOWNLOADS SHOULD BE DONE WITH MEDIAFIRE NOW ---!// string[] comicLinkArray = comicDLLink.Split('/'); - if (comicLinkArray[2] != "mega.nz") - { - string comicLinkEnc = comicLinkArray[4]; - byte[] comicLinkConverted = System.Convert.FromBase64String(comicLinkEnc); - megaURL = System.Text.ASCIIEncoding.ASCII.GetString(comicLinkConverted); - } - else + + //if (comicLinkArray[2] != "mega.nz") + //{ + // string comicLinkEnc = comicLinkArray[4]; + // byte[] comicLinkConverted = System.Convert.FromBase64String(comicLinkEnc); + // megaURL = System.Text.ASCIIEncoding.ASCII.GetString(comicLinkConverted); + //} + //else + //{ + // megaURL = comicDLLink; + //} + + HttpWebRequest requestMF = (HttpWebRequest)WebRequest.Create(comicDLLink); + HttpWebResponse responseMF = (HttpWebResponse)requestMF.GetResponse(); + + if (responseMF.StatusCode == HttpStatusCode.OK) { - megaURL = comicDLLink; + Stream receiveStreamMF = responseMF.GetResponseStream(); + StreamReader readStreamMF = null; + + if (responseMF.CharacterSet == null) + { + readStreamMF = new StreamReader(receiveStreamMF); + } + else + { + readStreamMF = new StreamReader(receiveStreamMF, Encoding.GetEncoding(responseMF.CharacterSet)); + } + + string dataMF = readStreamMF.ReadToEnd(); + + responseMF.Close(); + readStreamMF.Close(); + + string comicDLLinkMF = ""; + + HtmlAgilityPack.HtmlDocument docMF = new HtmlAgilityPack.HtmlDocument(); + docMF.LoadHtml(dataMF); + + var htmlNodesMF = docMF.DocumentNode.SelectSingleNode("//a[@id='downloadButton']"); + + string MFLink = "null"; + MFLink = htmlNodesMF.Attributes["href"].Value; + + megaURL = MFLink; } @@ -364,20 +414,21 @@ public async void DownloadComic(int idCount) Uri myStringWebResource = new Uri(url); - try - { - INodeInfo node = mClient.GetNodeFromLink(myStringWebResource); - } - catch (Exception e) - { - LogWriter("Exception from mega client: " + e); - } + ////FOR MEGA CLIENT + //try + //{ + // INodeInfo node = mClient.GetNodeFromLink(myStringWebResource); + //} + //catch (Exception e) + //{ + // LogWriter("Exception from mega client: " + e); + //} //string filename = titleList[0]; string filename = titleList[idCount]; downloadPath = Properties.Settings.Default.DownloadLocation + "\\" + filename + ".cbr"; - IProgress progressHandler = new Progress(x => UpdateItemValue(id, (int)x)); //update progressbar with progress + //IProgress progressHandler = new Progress(x => UpdateItemValue(sender, e, id)); //update progressbar with progress //IProgress progressHandler = new Progress(x => Console.WriteLine("{0}%", x)); //write progress to Console Console.WriteLine("Downloading: " + downloadPath); @@ -388,7 +439,11 @@ public async void DownloadComic(int idCount) try { - await mClient.DownloadFileAsync(myStringWebResource, downloadPath, progressHandler, cts.Token); + using (WebClient wc = new WebClient()) + { + wc.DownloadProgressChanged += (sender, e) => UpdateItemValue(sender, e, id); + wc.DownloadFileAsync(new System.Uri(url), downloadPath); + } } catch (OperationCanceledException ex) { @@ -407,7 +462,10 @@ public async void DownloadComic(int idCount) } try { - await mClient.DownloadFileAsync(myStringWebResource, downloadPath, progressHandler, cts.Token); + using (WebClient wc = new WebClient()) + { + wc.DownloadFileAsync(new System.Uri(url), downloadPath); + } } catch (OperationCanceledException ex) { @@ -433,13 +491,99 @@ public async void DownloadComic(int idCount) MessageBox.Show("There was a problem downloading the comic. Try again later or download manually by clicking the Open Link button.\n\nIf this continues to happen try the following:\n1: Close Omnibus\n2: Go to https://getcomics.info in your browser\n3: Search for any comic and click the Mega button\n4: Open Omnibus and attempt the download again."); } + ////FOR MEGA CLIENT + //try + //{ + // await mClient.DownloadFileAsync(myStringWebResource, downloadPath, progressHandler, cts.Token); + //} + //catch (OperationCanceledException ex) + //{ + // complete = 0; + // CancelDownload(downloadPath); + // isDownloading = false; + // LogWriter("Download Canceled: " + downloadPath); + //} + //catch (IOException io) + //{ + // if (MessageBox.Show("Would you like to overwrite?", "File already exists", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.Yes) + // { + // if (File.Exists(downloadPath)) + // { + // File.Delete(downloadPath); + // } + // try + // { + // await mClient.DownloadFileAsync(myStringWebResource, downloadPath, progressHandler, cts.Token); + // } + // catch (OperationCanceledException ex) + // { + // complete = 0; + // isDownloading = false; + // CancelDownload(downloadPath); + // } + // } + // else + // { + // complete = 0; + // isDownloading = false; + // CancelDownload(downloadPath); + // } + //} + //catch (ArgumentException aex) + //{ + // complete = 0; + // isDownloading = false; + // CancelDownload(downloadPath); + // LogWriter(aex.ToString()); + + // MessageBox.Show("There was a problem downloading the comic. Try again later or download manually by clicking the Open Link button.\n\nIf this continues to happen try the following:\n1: Close Omnibus\n2: Go to https://getcomics.info in your browser\n3: Search for any comic and click the Mega button\n4: Open Omnibus and attempt the download again."); + //} + //return "complete"; } - private void UpdateItemValue(string id, int value) + private void DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e, string id) + { + + } + + // Event to track the progress + void wc_DownloadProgressChanged(object sender, DownloadProgressChangedEventArgs e, int id) + { + //progressBar.Value = e.ProgressPercentage; + } + + //private void UpdateItemValue(string id, int value) + //{ + // ListViewItem lvi = GetLVItemById(id); + // ProgressBar pb = GetPBById(id); + + // if (lvi != null && pb != null) + // { + // pb.Value = value; + + // if (value == 1 && status == true) + // { + // lvi.SubItems[1].Text = "Downloading"; + // status = false; + // isDownloading = true; + // } + // else if (value >= 100) + // { + // lvi.SubItems[1].Text = "Complete"; + // lvDownloads.Controls.Remove(pb); + // complete = 1; + // isDownloading = false; + // DownloadComplete(); + // } + // } + //} + + private void UpdateItemValue(object sender, DownloadProgressChangedEventArgs e, string id) { ListViewItem lvi = GetLVItemById(id); ProgressBar pb = GetPBById(id); + int value = e.ProgressPercentage; if (lvi != null && pb != null) { @@ -637,33 +781,143 @@ private void cmsComics_ItemClicked(object sender, ToolStripItemClickedEventArgs if (comicDLLink != "") { - //string lastEV = ""; - string lastURL = ""; - List EVs = new List(); + ////string lastEV = ""; + //string lastURL = ""; + //List EVs = new List(); + + ////Get MEGA link by decrypting Base64 string in the address + //string[] comicLinkArray = comicDLLink.Split('/'); + //if (comicLinkArray[2] != "mega.nz") + //{ + // string comicLinkEnc = comicLinkArray[4]; + // byte[] comicLinkConverted = System.Convert.FromBase64String(comicLinkEnc); + // megaURL = System.Text.ASCIIEncoding.ASCII.GetString(comicLinkConverted); + // didDecrypt = 1; + //} + //else + //{ + // megaURL = comicDLLink; + //} + + //if (didDecrypt == 1) + //{ + // MessageBox.Show("DECRYPTED MEGA URL: " + megaURL); + //} + //else + //{ + // MessageBox.Show("MEGA URL: " + megaURL); + //} + + MessageBox.Show("MEGA URLs are not being used at this time"); - //Get MEGA link by decrypting Base64 string in the address - string[] comicLinkArray = comicDLLink.Split('/'); - if (comicLinkArray[2] != "mega.nz") - { - string comicLinkEnc = comicLinkArray[4]; - byte[] comicLinkConverted = System.Convert.FromBase64String(comicLinkEnc); - megaURL = System.Text.ASCIIEncoding.ASCII.GetString(comicLinkConverted); - didDecrypt = 1; - } - else - { - megaURL = comicDLLink; - } - if (didDecrypt == 1) + } + else + MessageBox.Show("No download link available. Go to comic's page and download manually."); + } + } + if (e.ClickedItem.Name == "validateMF") + { + HtmlNode n = nodes.ElementAt(lbComics.SelectedIndex); + string node = n.InnerHtml; + string[] a = node.Split('"'); + + HttpWebRequest request = (HttpWebRequest)WebRequest.Create(a[1]); + request.UserAgent = Properties.Settings.Default.UserAgent; + request.Headers.Add(HttpRequestHeader.Cookie, + "__cfduid=" + Properties.Settings.Default.cfduid + ";" + + "cf_clearance=" + Properties.Settings.Default.cf_clearance + ); + + HttpWebResponse response = (HttpWebResponse)request.GetResponse(); + + if (response.StatusCode == HttpStatusCode.OK) + { + Stream receiveStream = response.GetResponseStream(); + StreamReader readStream = null; + + if (response.CharacterSet == null) + { + readStream = new StreamReader(receiveStream); + } + else + { + readStream = new StreamReader(receiveStream, Encoding.GetEncoding(response.CharacterSet)); + } + + string data = readStream.ReadToEnd(); + + response.Close(); + readStream.Close(); + + string comicDLLink = ""; + + HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument(); + doc.LoadHtml(data); + + var htmlNodes = doc.DocumentNode.SelectSingleNode("//a[@title='MEDIAFIRE']"); + + if (htmlNodes == null) + { + foreach (HtmlNode node1 in doc.DocumentNode.SelectNodes("//a")) { - MessageBox.Show("DECRYPTED MEGA URL: " + megaURL); + if (node1.SelectNodes(".//span") != null) + { + foreach (HtmlNode node2 in node1.SelectNodes(".//span")) + { + string value = node2.InnerText; + if (value == "Mega") + { + comicDLLink = node1.Attributes["href"].Value; + } + + } + } } - else + } + else + { + comicDLLink = htmlNodes.Attributes["href"].Value; + } + + int didDecrypt = 0; + + if (comicDLLink != "") + { + HttpWebRequest requestMF = (HttpWebRequest)WebRequest.Create(comicDLLink); + HttpWebResponse responseMF = (HttpWebResponse)requestMF.GetResponse(); + + if (responseMF.StatusCode == HttpStatusCode.OK) { - MessageBox.Show("MEGA URL: " + megaURL); + Stream receiveStreamMF = responseMF.GetResponseStream(); + StreamReader readStreamMF = null; + + if (responseMF.CharacterSet == null) + { + readStreamMF = new StreamReader(receiveStreamMF); + } + else + { + readStreamMF = new StreamReader(receiveStreamMF, Encoding.GetEncoding(responseMF.CharacterSet)); + } + + string dataMF = readStreamMF.ReadToEnd(); + + responseMF.Close(); + readStreamMF.Close(); + + string comicDLLinkMF = ""; + + HtmlAgilityPack.HtmlDocument docMF = new HtmlAgilityPack.HtmlDocument(); + docMF.LoadHtml(dataMF); + + var htmlNodesMF = docMF.DocumentNode.SelectSingleNode("//a[@id='downloadButton']"); + + string MFLink = "null"; + MFLink = htmlNodesMF.Attributes["href"].Value; + + MessageBox.Show("MEGA URL: " + MFLink); } - } else @@ -742,6 +996,21 @@ private void DownloadComplete() } + private void cmsComics_Opening(object sender, CancelEventArgs e) + { + + } + + private void verifyMediafireLinkToolStripMenuItem_Click(object sender, EventArgs e) + { + + } + + private void validate_Click(object sender, EventArgs e) + { + + } + private string replaceASCII(string title) { if (title.Contains("–")) diff --git a/Omnibus.csproj b/Omnibus.csproj index ac43e16..503cf7c 100644 --- a/Omnibus.csproj +++ b/Omnibus.csproj @@ -35,6 +35,9 @@ omnibus-icon.ico + + ..\packages\Portable.BouncyCastle.1.7.0.2\lib\portable-net4+sl5+wp8+win8+wpa81+MonoTouch10+MonoAndroid10+xamarinmac20+xamarinios10\crypto.dll + ..\packages\HtmlAgilityPack.1.11.23\lib\Net45\HtmlAgilityPack.dll @@ -122,6 +125,9 @@ ..\packages\IKVM.8.1.5717.0\lib\IKVM.Runtime.JNI.dll + + ..\packages\MediaFireSDK.1.0.0.2\lib\portable-net45+win+wpa81+wp80+MonoAndroid10+xamarinios10+MonoTouch10\MediaFireSDK.dll + ..\packages\MegaApiClient.1.8.0\lib\net46\MegaApiClient.dll @@ -130,6 +136,16 @@ + + ..\packages\Microsoft.Net.Http.2.2.22\lib\net45\System.Net.Http.Extensions.dll + + + ..\packages\Microsoft.AspNet.WebApi.Client.5.2.3\lib\net45\System.Net.Http.Formatting.dll + + + ..\packages\Microsoft.Net.Http.2.2.22\lib\net45\System.Net.Http.Primitives.dll + + @@ -214,4 +230,9 @@ + + + + + \ No newline at end of file diff --git a/bin/Debug/MediaFireSDK.dll b/bin/Debug/MediaFireSDK.dll new file mode 100644 index 0000000000000000000000000000000000000000..64e2f50c8b587f6262fc66c98cd45742ed5e5ae6 GIT binary patch literal 113664 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
(@kfnWYmzKp4N8%7U8zE zj<*G1G!$BsKPxV9YSjz#X9uyf-C?G-R=)0In7Bsq6d5$?SFfve_jPd-SyPzj=dP<7xnU$zM?!iaFli+;=y=RPo1q-r!ZjMYE9{^em$=`IXhK_e;E2> z)R8O)to+t%Rox6J0&yr@Wrje&q3!ejo2_zHuT9O%moyDU0`HtN4Ln|TdBQ)2HAUwc zx;m>LT9xN!CNEYYGsh;c&Y$@T#?c_~5fWNCC&@tmE@i~anhp#rFoLIC#GA9g#F7=u zQ+=3K=i!LXQRu$9`c?gYqX>5fFY&7Kpo2kY; zWhr%*=j8MFh%@C-ZO9k>%ob}xILNNS9qswK$#bAfk+GOPWqN96Y90=Atl82=0)n&k zdJTRoMW%FICZF4@B5#>>1OZwHyfE*vum+N3sh=qgHl}DzkAR=TH@u7)vgSTNB}rx~ z)j9Pi4o6eO z6cjnfSF!waZr~z14AIV2)t@?KENZ9HQW{;hSH+p7YBpSbRWHCXWdnGnUa-tm6{xLp zONGW@x~$Y+sZWbym8=ycRlY`LXp=n)<5_&x@yz-2&q<}D;s_Yj?K$`!Zor9g0~#hx zgO5lD;abDLJ~a=9f%8!BBC#%=;dc~Q??e?0D6(*F`8GiMkMcM{W38MaU z?vos?TUZS$X0x1hp7ev8WxhP&JL5ZyZp4q_44RtBR=+G>t^6V@8v8qVy3!H&vdp!X zrM<^ngbqxHxgeF{)CzB!FfGTtzrU-$>okTTyPtgYXy`%fBIa%yWoTjHf{L#l$27NMv^v+eEr&N-Tm7@%QAA@!p2uX{cI5Z#p`D=rN zdn<6PY65FA@Z)as)&zTYSMYBy+CLD*`T~Kh1O{M-VNPbYd>-Bt;Yu~}KPb*}8Rf@XlXngARNKZ)gfyN&UgzZLM}Uf3F3HI`Sj1xhVph`z&1+E7LHItZ z02LY_q(CfBx#uWNV)63v`z6+sM+?&vBHQCgtL3Ai#npOgtd{AB$h1AJm6Ba4*N5bp o!zfW2)X#{;`ZvJshdl=|{BQo=K{pTNuk8EZg#Ulk|DFW?38+`pT>t<8 literal 0 HcmV?d00001 diff --git a/bin/Debug/Omnibus.exe b/bin/Debug/Omnibus.exe index cf8ef75df3a624577bd0950f844654c6826f4608..34190eb93ffec7d03351545411f6bfa1d39815cc 100644 GIT binary patch delta 23323 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 delta 22682 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 diff --git a/bin/Debug/Omnibus.exe.config b/bin/Debug/Omnibus.exe.config index 9db9329..c128e5a 100644 --- a/bin/Debug/Omnibus.exe.config +++ b/bin/Debug/Omnibus.exe.config @@ -1,40 +1,52 @@  - - -
- - - - - - - - - - - - - - - False - - - - - - - - - - - - + + +
+ + + + + + + + + + + + + + + False + + + + + + + + + + + + + + + + + + + + - + + + + + diff --git a/bin/Debug/Omnibus.pdb b/bin/Debug/Omnibus.pdb index 867af0c05237fc4004351012e095e817aa2cd65f..303149e6298c28d5ab640b8cee19306899a72d05 100644 GIT binary patch delta 17374 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 diff --git a/bin/Debug/System.Net.Http.Extensions.dll b/bin/Debug/System.Net.Http.Extensions.dll new file mode 100644 index 0000000000000000000000000000000000000000..7ebd0984994e67c7853b7fa27d03bebcd57f3fe5 GIT binary patch literal 22264 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 + + + System.Net.Http.Extensions + + + + + Extension methods for which expose differences in platform specific capabilities. + + + + + Gets a value that indicates if HttpClientHandler.AllowAutoRedirect is supported by the handler. + When this property is true and HttpClientHandler.SupportsRedirectConfiguration is false, setting HttpClientHandler.AllowAutoRedirect to true will cause the system default to be used for HttpClientHandler.MaximumAutomaticRedirections. + + The to check. + Returns .true if the if the handler supports configuration settings for the property; otherwise false. + + + + Gets a value that indicates if is supported by the handler. + + The to check. + Returns .true if the if the handler supports configuration settings for the property; otherwise false. + + + + Gets a value that indicates if , HttpRequestMessage.ProtocolVersion, and HttpResponseMessage.ProtocolVersion are supported by the handler. + + The to check. + Returns .true if the if the handler supports configuration settings for the , HttpRequestMessage.ProtocolVersion, and HttpResponseMessage.ProtocolVersion properties; otherwise false. + + + + Gets a value that indicates if HttpRequestMessage.Headers with or header value of 'chunked' is supported by the handler. + + The to check. + Returns .true if the if the handler supports setting HttpRequestMessage.Headers with or header value of 'chunked'; otherwise false. + + + + Gets a value that indicates if is supported by the handler. + When this property is true and HttpClientHandler.SupportsProxy is false, setting HttpClientHandler.UseProxy to true will cause the system default to be used for HttpClientHandler.Proxy. + + The to check. + Returns .true if the if the handler supports configuration settings for the property; otherwise false. + + + diff --git a/bin/Debug/System.Net.Http.Formatting.dll b/bin/Debug/System.Net.Http.Formatting.dll new file mode 100644 index 0000000000000000000000000000000000000000..3b76acd6beaf6c3584585a34d3b02729043d020c GIT binary patch literal 185544 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 OF7J1-=M#rXfBioIKPc<~ literal 0 HcmV?d00001 diff --git a/bin/Debug/System.Net.Http.Formatting.xml b/bin/Debug/System.Net.Http.Formatting.xml new file mode 100644 index 0000000..3fb6597 --- /dev/null +++ b/bin/Debug/System.Net.Http.Formatting.xml @@ -0,0 +1,2094 @@ + + + + System.Net.Http.Formatting + + + + + implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. The supports one or more byte ranges regardless of whether the ranges are consecutive or not. If there is only one range then a single partial response body containing a Content-Range header is generated. If there are more than one ranges then a multipart/byteranges response is generated where each body part contains a range indicated by the associated Content-Range header field. + + + + implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content. + The stream over which to generate a byte range view. + The range or ranges, typically obtained from the Range HTTP request header field. + The media type of the content stream. + + + + implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content. + The stream over which to generate a byte range view. + The range or ranges, typically obtained from the Range HTTP request header field. + The media type of the content stream. + The buffer size used when copying the content stream. + + + + implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content. + The stream over which to generate a byte range view. + The range or ranges, typically obtained from the Range HTTP request header field. + The media type of the content stream. + + + + implementation which provides a byte range view over a stream used to generate HTTP 206 (Partial Content) byte range responses. If none of the requested ranges overlap with the current extend of the selected resource represented by the content parameter then an is thrown indicating the valid Content-Range of the content. + The stream over which to generate a byte range view. + The range or ranges, typically obtained from the Range HTTP request header field. + The media type of the content stream. + The buffer size used when copying the content stream. + + + Releases the resources used by the current instance of the class. + true to release managed and unmanaged resources; false to release only unmanaged resources. + + + Asynchronously serialize and write the byte range to an HTTP content stream. + The task object representing the asynchronous operation. + The target stream. + Information about the transport. + + + Determines whether a byte array has a valid length in bytes. + true if length is a valid length; otherwise, false. + The length in bytes of the byte array. + + + Extension methods that aid in making formatted requests using . + + + + + + + + + Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as JSON. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as JSON. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + + + + + + + Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as XML. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with the given value serialized as XML. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + + + + + + + + + + + + + + + + Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + Sends a POST request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + + + + + + + Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as JSON. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as JSON. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + + + + + + + Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as XML. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with the given value serialized as XML. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + + + + + + + + + + + + + + + + Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + The authoritative value of the request's content's Content-Type header. Can be null in which case the <paramref name="formatter">formatter's</paramref> default content type will be used. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + Sends a PUT request as an asynchronous operation to the specified Uri with value serialized using the given formatter. + A task object representing the asynchronous operation. + The client used to make the request. + The Uri the request is sent to. + The value that will be placed in the request's entity body. + The formatter used to serialize the value. + A cancellation token that can be used by other objects or threads to receive notice of cancellation. + The type of value. + + + Represents the factory for creating new instance of . + + + Creates a new instance of the . + A new instance of the . + The list of HTTP handler that delegates the processing of HTTP response messages to another handler. + + + Creates a new instance of the . + A new instance of the . + The inner handler which is responsible for processing the HTTP response messages. + The list of HTTP handler that delegates the processing of HTTP response messages to another handler. + + + Creates a new instance of the which should be pipelined. + A new instance of the which should be pipelined. + The inner handler which is responsible for processing the HTTP response messages. + The list of HTTP handler that delegates the processing of HTTP response messages to another handler. + + + Specifies extension methods to allow strongly typed objects to be read from HttpContent instances. + + + Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The collection of MediaTyepFormatter instances to use. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type <typeparamref name="T" /> from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The collection of MediaTypeFormatter instances to use. + The IFormatterLogger to log events to. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The collection of MediaTypeFormatter instances to use. + The IFormatterLogger to log events to. + The token to cancel the operation. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The collection of MediaTypeFormatter instances to use. + The token to cancel the operation. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type from the content instance. + An object instance of the specified type. + The HttpContent instance from which to read. + The token to cancel the operation. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type from the content instance. + A Task that will yield an object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + + + Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + The collection of MediaTypeFormatter instances to use. + + + Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + The collection of MediaTypeFormatter instances to use. + The IFormatterLogger to log events to. + + + Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + The collection of MediaTypeFormatter instances to use. + The IFormatterLogger to log events to. + The token to cancel the operation. + + + Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + The collection of MediaTypeFormatter instances to use. + The token to cancel the operation. + + + Returns a Task that will yield an object of the specified type from the content instance using one of the provided formatters to deserialize the content. + An object instance of the specified type. + The HttpContent instance from which to read. + The type of the object to read. + The token to cancel the operation. + + + Extension methods to read HTML form URL-encoded datafrom instances. + + + Determines whether the specified content is HTML form URL-encoded data. + true if the specified content is HTML form URL-encoded data; otherwise, false. + The content. + + + Asynchronously reads HTML form URL-encoded from an instance and stores the results in a object. + A task object representing the asynchronous operation. + The content. + + + Asynchronously reads HTML form URL-encoded from an instance and stores the results in a object. + A task object representing the asynchronous operation. + The content. + The token to cancel the operation. + + + Provides extension methods to read and entities from instances. + + + Determines whether the specified content is HTTP request message content. + true if the specified content is HTTP message content; otherwise, false. + The content to check. + + + Determines whether the specified content is HTTP response message content. + true if the specified content is HTTP message content; otherwise, false. + The content to check. + + + Reads the as an . + The parsed instance. + The content to read. + + + Reads the as an . + The parsed instance. + The content to read. + The URI scheme to use for the request URI. + + + Reads the as an . + The parsed instance. + The content to read. + The URI scheme to use for the request URI. + The size of the buffer. + + + Reads the as an . + The parsed instance. + The content to read. + The URI scheme to use for the request URI. + The size of the buffer. + The maximum length of the HTTP header. + + + + + + + Reads the as an . + The parsed instance. + The content to read. + + + Reads the as an . + The parsed instance. + The content to read. + The size of the buffer. + + + Reads the as an . + The parsed instance. + The content to read. + The size of the buffer. + The maximum length of the HTTP header. + + + + + + Extension methods to read MIME multipart entities from instances. + + + Determines whether the specified content is MIME multipart content. + true if the specified content is MIME multipart content; otherwise, false. + The content. + + + Determines whether the specified content is MIME multipart content with the specified subtype. + true if the specified content is MIME multipart content with the specified subtype; otherwise, false. + The content. + The MIME multipart subtype to match. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + The token to cancel the operation. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + A stream provider providing output streams for where to write body parts as they are parsed. + The type of the MIME multipart. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written and bufferSize as read buffer size. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + A stream provider providing output streams for where to write body parts as they are parsed. + Size of the buffer used to read the contents. + The type of the MIME multipart. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written and bufferSize as read buffer size. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + A stream provider providing output streams for where to write body parts as they are parsed. + Size of the buffer used to read the contents. + The token to cancel the operation. + The type of the MIME multipart. + + + Reads all body parts within a MIME multipart message and produces a set of instances as a result using the streamProvider instance to determine where the contents of each body part is written. + A representing the tasks of getting the collection of instances where each instance represents a body part. + An existing instance to use for the object's content. + A stream provider providing output streams for where to write body parts as they are parsed. + The token to cancel the operation. + The type of the MIME multipart. + + + Derived class which can encapsulate an or an as an entity with media type "application/http". + + + Initializes a new instance of the class encapsulating an . + The instance to encapsulate. + + + Initializes a new instance of the class encapsulating an . + The instance to encapsulate. + + + Releases unmanaged and - optionally - managed resources + true to release both managed and unmanaged resources; false to release only unmanaged resources. + + + Gets the HTTP request message. + + + Gets the HTTP response message. + + + Asynchronously serializes the object's content to the given stream. + A instance that is asynchronously serializing the object's content. + The to which to write. + The associated . + + + Computes the length of the stream if possible. + true if the length has been computed; otherwise false. + The computed length of the stream. + + + Provides extension methods for the class. + + + Gets any cookie headers present in the request. + A collection of instances. + The request headers. + + + Gets any cookie headers present in the request that contain a cookie state whose name that matches the specified value. + A collection of instances. + The request headers. + The cookie state name to match. + + + + + Provides extension methods for the class. + + + Adds cookies to a response. Each Set-Cookie header is represented as one instance. A contains information about the domain, path, and other cookie information as well as one or more instances. Each instance contains a cookie name and whatever cookie state is associate with that name. The state is in the form of a which on the wire is encoded as HTML Form URL-encoded data. This representation allows for multiple related "cookies" to be carried within the same Cookie header while still providing separation between each cookie state. A sample Cookie header is shown below. In this example, there are two with names state1 and state2 respectively. Further, each cookie state contains two name/value pairs (name1/value1 and name2/value2) and (name3/value3 and name4/value4). <code> Set-Cookie: state1:name1=value1&amp;name2=value2; state2:name3=value3&amp;name4=value4; domain=domain1; path=path1; </code> + The response headers + The cookie values to add to the response. + + + An exception thrown by in case none of the requested ranges overlap with the current extend of the selected resource. The current extend of the resource is indicated in the ContentRange property. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + + + The current extend of the resource indicated in terms of a ContentRange header field. + + + Represents a multipart file data. + + + Initializes a new instance of the class. + The headers of the multipart file data. + The name of the local file for the multipart file data. + + + Gets or sets the headers of the multipart file data. + The headers of the multipart file data. + + + Gets or sets the name of the local file for the multipart file data. + The name of the local file for the multipart file data. + + + Represents an suited for writing each MIME body parts of the MIME multipart message to a file using a . + + + Initializes a new instance of the class. + The root path where the content of MIME multipart body parts are written to. + + + Initializes a new instance of the class. + The root path where the content of MIME multipart body parts are written to. + The number of bytes buffered for writes to the file. + + + Gets or sets the number of bytes buffered for writes to the file. + The number of bytes buffered for writes to the file. + + + Gets or sets the multipart file data. + The multipart file data. + + + Gets the name of the local file which will be combined with the root path to create an absolute file name where the contents of the current MIME body part will be stored. + A relative filename with no path component. + The headers for the current MIME body part. + + + Gets the stream instance where the message body part is written to. + The instance where the message body part is written to. + The content of HTTP. + The header fields describing the body part. + + + Gets or sets the root path where the content of MIME multipart body parts are written to. + The root path where the content of MIME multipart body parts are written to. + + + A implementation suited for use with HTML file uploads for writing file content to a remote storage . The stream provider looks at the Content-Disposition header field and determines an output remote based on the presence of a filename parameter. If a filename parameter is present in the Content-Disposition header field, then the body part is written to a remote provided by . Otherwise it is written to a . + + + Initializes a new instance of the class. + + + Read the non-file contents as form data. + A representing the post processing. + + + Read the non-file contents as form data. + A representing the post processing. + The token to monitor for cancellation requests. + + + Gets a collection of file data passed as part of the multipart form data. + + + Gets a of form data passed as part of the multipart form data. + + + Provides a for . Override this method to provide a remote stream to which the data should be written. + A result specifying a remote stream where the file will be written to and a location where the file can be accessed. It cannot be null and the stream must be writable. + The parent MIME multipart instance. + The header fields describing the body part's content. + + + + Represents an suited for use with HTML file uploads for writing file content to a . + + + Initializes a new instance of the class. + The root path where the content of MIME multipart body parts are written to. + + + Initializes a new instance of the class. + The root path where the content of MIME multipart body parts are written to. + The number of bytes buffered for writes to the file. + + + Reads the non-file contents as form data. + A task that represents the asynchronous operation. + + + + Gets a of form data passed as part of the multipart form data. + The of form data. + + + Gets the streaming instance where the message body part is written. + The instance where the message body part is written. + The HTTP content that contains this body part. + Header fields describing the body part. + + + Represents a multipart memory stream provider. + + + Initializes a new instance of the class. + + + Returns the for the . + The for the . + A object. + The HTTP content headers. + + + Represents the provider for the multipart related multistream. + + + Initializes a new instance of the class. + + + Gets the related stream for the provider. + The content headers. + The parent content. + The http content headers. + + + Gets the root content of the . + The root content of the . + + + Represents a multipart file data for remote storage. + + + Initializes a new instance of the class. + The headers of the multipart file data. + The remote file's location. + The remote file's name. + + + Gets the remote file's name. + + + Gets the headers of the multipart file data. + + + Gets the remote file's location. + + + Represents a stream provider that examines the headers provided by the MIME multipart parser as part of the MIME multipart extension methods (see ) and decides what kind of stream to return for the body part to be written to. + + + Initializes a new instance of the class. + + + Gets or sets the contents for this . + The contents for this . + + + Executes the post processing operation for this . + The asynchronous task for this operation. + + + Executes the post processing operation for this . + The asynchronous task for this operation. + The token to cancel the operation. + + + Gets the stream where to write the body part to. This method is called when a MIME multipart body part has been parsed. + The instance where the message body part is written to. + The content of the HTTP. + The header fields describing the body part. + + + Contains a value as well as an associated that will be used to serialize the value when writing this content. + + + Initializes a new instance of the class. + The type of object this instance will contain. + The value of the object this instance will contain. + The formatter to use when serializing the value. + + + Initializes a new instance of the class. + The type of object this instance will contain. + The value of the object this instance will contain. + The formatter to use when serializing the value. + The authoritative value of the Content-Type header. Can be null, in which case the default content type of the formatter will be used. + + + Initializes a new instance of the class. + The type of object this instance will contain. + The value of the object this instance will contain. + The formatter to use when serializing the value. + The authoritative value of the Content-Type header. + + + Gets the media-type formatter associated with this content instance. + The media type formatter associated with this content instance. + + + Gets the type of object managed by this instance. + The object type. + + + Asynchronously serializes the object's content to the given stream. + The task object representing the asynchronous operation. + The stream to write to. + The associated . + + + Computes the length of the stream if possible. + true if the length has been computed; otherwise, false. + Receives the computed length of the stream. + + + Gets or sets the value of the content. + The content value. + + + Generic form of . + The type of object this class will contain. + + + Initializes a new instance of the class. + The value of the object this instance will contain. + The formatter to use when serializing the value. + + + Initializes a new instance of the <see cref="T:System.Net.Http.ObjectContent`1" /> class. + The value of the object this instance will contain. + The formatter to use when serializing the value. + The authoritative value of the Content-Type header. Can be null, in which case the default content type of the formatter will be used. + + + Initializes a new instance of the class. + The value of the object this instance will contain. + The formatter to use when serializing the value. + The authoritative value of the Content-Type header. + + + Enables scenarios where a data producer wants to write directly (either synchronously or asynchronously) using a stream. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + The media type. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + The media type. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + The media type. + + + Initializes a new instance of the class. + An action that is called when an output stream is available, allowing the action to write to it directly. + The media type. + + + Asynchronously serializes the push content into stream. + The serialized push content. + The stream where the push content will be serialized. + The context. + + + Determines whether the stream content has a valid length in bytes. + true if length is a valid length; otherwise, false. + The length in bytes of the stream content. + + + Represents the result for . + + + Initializes a new instance of the class. + The remote stream instance where the file will be written to. + The remote file's location. + The remote file's name. + + + Gets the remote file's location. + + + Gets the remote file's location. + + + Gets the remote stream instance where the file will be written to. + + + Defines an exception type for signalling that a request's media type was not supported. + + + Initializes a new instance of the class. + The message that describes the error. + The unsupported media type. + + + Gets or sets the media type. + The media type. + + + Contains extension methods to allow strongly typed objects to be read from the query component of instances. + + + Parses the query portion of the specified URI. + A that contains the query parameters. + The URI to parse. + + + Reads HTML form URL encoded data provided in the URI query string as an object of a specified type. + true if the query component of the URI can be read as the specified type; otherwise, false. + The URI to read. + The type of object to read. + When this method returns, contains an object that is initialized from the query component of the URI. This parameter is treated as uninitialized. + + + Reads HTML form URL encoded data provided in the URI query string as an object of a specified type. + true if the query component of the URI can be read as the specified type; otherwise, false. + The URI to read. + When this method returns, contains an object that is initialized from the query component of the URI. This parameter is treated as uninitialized. + The type of object to read. + + + Reads HTML form URL encoded data provided in the query component as a object. + true if the query component can be read as ; otherwise false. + The instance from which to read. + An object to be initialized with this instance or null if the conversion cannot be performed. + + + Abstract media type formatter class to support Bson and Json. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Determines whether this formatter can read objects of the specified type. + true if objects of this type can be read, otherwise false. + The type of object that will be read. + + + Determines whether this formatter can write objects of the specified type. + true if objects of this type can be written, otherwise false. + The type of object to write. + + + Creates a instance with the default settings used by the . + Returns . + + + Called during deserialization to get the . + The reader to use during deserialization. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + + + Called during serialization and deserialization to get the . + The JsonSerializer used during serialization and deserialization. + + + Called during serialization to get the . + The writer to use during serialization. + The type of the object to write. + The stream to write to. + The encoding to use when writing. + + + Gets or sets the maximum depth allowed by this formatter. + The maximum depth allowed by this formatter. + + + Called during deserialization to read an object of the specified type from the specified stream. + The object that has been read. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + The logger to log events to. + + + Called during deserialization to read an object of the specified type from the specified stream. + A task whose result will be the object instance that has been read. + The type of the object to read. + The stream from which to read. + The for the content being read. + The logger to log events to. + + + Gets or sets the JsonSerializerSettings used to configure the JsonSerializer. + The JsonSerializerSettings used to configure the JsonSerializer. + + + Called during serialization to write an object of the specified type to the specified stream. + The type of the object to write. + The object to write. + The stream to write to. + The encoding to use when writing. + + + Called during serialization to write an object of the specified type to the specified stream. + Returns . + The type of the object to write. + The object to write. + The stream to write to. + The for the content being written. + The transport context. + The token to monitor for cancellation. + + + Represents a media type formatter to handle Bson. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The formatter to copy settings from. + + + Called during deserialization to get the . + The reader to use during deserialization. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + + + Called during serialization to get the . + The writer to use during serialization. + The type of the object to write. + The stream to write to. + The encoding to use when writing. + + + Gets the default media type for Json, namely "application/bson". + The default media type for Json, namely "application/bson". + + + Gets or sets the maximum depth allowed by this formatter. + The maximum depth allowed by this formatter. + + + Called during deserialization to read an object of the specified type from the specified stream. + The object that has been read. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + The logger to log events to. + + + Called during deserialization to read an object of the specified type from the specified stream. + A task whose result will be the object instance that has been read. + The type of the object to read. + The stream from which to read. + The for the content being read. + The logger to log events to. + + + Called during serialization to write an object of the specified type to the specified stream. + The type of the object to write. + The object to write. + The stream to write to. + The encoding to use when writing. + + + Represents a helper class to allow a synchronous formatter on top of the asynchronous formatter infrastructure. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Gets or sets the suggested size of buffer to use with streams in bytes. + The suggested size of buffer to use with streams in bytes. + + + Reads synchronously from the buffered stream. + An object of the given . + The type of the object to deserialize. + The stream from which to read. + The , if available. Can be null. + The to log events to. + + + Reads synchronously from the buffered stream. + An object of the given . + The type of the object to deserialize. + The stream from which to read. + The , if available. Can be null. + The to log events to. + The token to cancel the operation. + + + Reads asynchronously from the buffered stream. + A task object representing the asynchronous operation. + The type of the object to deserialize. + The stream from which to read. + The , if available. Can be null. + The to log events to. + + + Reads asynchronously from the buffered stream. + A task object representing the asynchronous operation. + The type of the object to deserialize. + The stream from which to read. + The , if available. Can be null. + The to log events to. + The token to cancel the operation. + + + Writes synchronously to the buffered stream. + The type of the object to serialize. + The object value to write. Can be null. + The stream to which to write. + The , if available. Can be null. + + + Writes synchronously to the buffered stream. + The type of the object to serialize. + The object value to write. Can be null. + The stream to which to write. + The , if available. Can be null. + The token to cancel the operation. + + + Writes asynchronously to the buffered stream. + A task object representing the asynchronous operation. + The type of the object to serialize. + The object value to write. It may be null. + The stream to which to write. + The , if available. Can be null. + The transport context. + + + Writes asynchronously to the buffered stream. + A task object representing the asynchronous operation. + The type of the object to serialize. + The object value to write. It may be null. + The stream to which to write. + The , if available. Can be null. + The transport context. + The token to cancel the operation. + + + Represents the result of content negotiation performed using <see cref="M:System.Net.Http.Formatting.IContentNegotiator.Negotiate(System.Type,System.Net.Http.HttpRequestMessage,System.Collections.Generic.IEnumerable{System.Net.Http.Formatting.MediaTypeFormatter})" /> + + + Create the content negotiation result object. + The formatter. + The preferred media type. Can be null. + + + The formatter chosen for serialization. + + + The media type that is associated with the formatter chosen for serialization. Can be null. + + + The default implementation of , which is used to select a for an or . + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + true to exclude formatters that match only on the object type; otherwise, false. + + + Determines how well each formatter matches an HTTP request. + Returns a collection of objects that represent all of the matches. + The type to be serialized. + The request. + The set of objects from which to choose. + + + If true, exclude formatters that match only on the object type; otherwise, false. + Returns a . + + + Matches a set of Accept header fields against the media types that a formatter supports. + Returns a object that indicates the quality of the match, or null if there is no match. + A list of Accept header values, sorted in descending order of q factor. You can create this list by calling the method. + The formatter to match against. + + + Matches a request against the objects in a media-type formatter. + Returns a object that indicates the quality of the match, or null if there is no match. + The request to match. + The media-type formatter. + + + Match the content type of a request against the media types that a formatter supports. + Returns a object that indicates the quality of the match, or null if there is no match. + The request to match. + The formatter to match against. + + + Selects the first supported media type of a formatter. + Returns a with set to MatchOnCanWriteType, or null if there is no match. A indicating the quality of the match or null is no match. + The type to match. + The formatter to match against. + + + Performs content negotiating by selecting the most appropriate out of the passed in for the given that can serialize an object of the given . + The result of the negotiation containing the most appropriate instance, or null if there is no appropriate formatter. + The type to be serialized. + The request. + The set of objects from which to choose. + + + Determines the best character encoding for writing the response. + Returns the that is the best match. + The request. + The selected media formatter. + + + Select the best match among the candidate matches found. + Returns the object that represents the best match. + The collection of matches. + + + Determine whether to match on type or not. This is used to determine whether to generate a 406 response or use the default media type formatter in case there is no match against anything in the request. If ExcludeMatchOnTypeOnly is true then we don't match on type unless there are no accept headers. + True if not ExcludeMatchOnTypeOnly and accept headers with a q-factor bigger than 0.0 are present. + The sorted accept header values to match. + + + Sorts Accept header values in descending order of q factor. + Returns the sorted list of MediaTypeWithQualityHeaderValue objects. + A collection of StringWithQualityHeaderValue objects, representing the header fields. + + + Sorts a list of Accept-Charset, Accept-Encoding, Accept-Language or related header values in descending order or q factor. + Returns the sorted list of StringWithQualityHeaderValue objects. + A collection of StringWithQualityHeaderValue objects, representing the header fields. + + + Evaluates whether a match is better than the current match. + Returns whichever object is a better match. + The current match. + The match to evaluate against the current match. + + + Helper class to serialize <see cref="T:System.Collections.Generic.IEnumerable`1" /> types by delegating them through a concrete implementation."/&gt;. + The interface implementing to proxy. + + + Initialize a DelegatingEnumerable. This constructor is necessary for to work. + + + Initialize a DelegatingEnumerable with an <see cref="T:System.Collections.Generic.IEnumerable`1" />. This is a helper class to proxy <see cref="T:System.Collections.Generic.IEnumerable`1" /> interfaces for . + The <see cref="T:System.Collections.Generic.IEnumerable`1" /> instance to get the enumerator from. + + + This method is not implemented but is required method for serialization to work. Do not use. + The item to add. Unused. + + + Get the enumerator of the associated <see cref="T:System.Collections.Generic.IEnumerable`1" />. + The enumerator of the <see cref="T:System.Collections.Generic.IEnumerable`1" /> source. + + + Get the enumerator of the associated <see cref="T:System.Collections.Generic.IEnumerable`1" />. + The enumerator of the <see cref="T:System.Collections.Generic.IEnumerable`1" /> source. + + + Represent the collection of form data. + + + Initializes a new instance of class. + The pairs. + + + Initializes a new instance of class. + The query. + + + Initializes a new instance of class. + The URI + + + Gets the collection of form data. + The collection of form data. + The key. + + + Gets an enumerable that iterates through the collection. + The enumerable that iterates through the collection. + + + Gets the values of the collection of form data. + The values of the collection of form data. + The key. + + + Gets values associated with a given key. If there are multiple values, they're concatenated. + Values associated with a given key. If there are multiple values, they're concatenated. + + + Reads the collection of form data as a collection of name value. + The collection of form data as a collection of name value. + + + Gets an enumerable that iterates through the collection. + The enumerable that iterates through the collection. + + + + class for handling HTML form URL-ended data, also known as application/x-www-form-urlencoded. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Queries whether the can deserializean object of the specified type. + true if the can deserialize the type; otherwise, false. + The type to deserialize. + + + Queries whether the can serializean object of the specified type. + true if the can serialize the type; otherwise, false. + The type to serialize. + + + Gets the default media type for HTML form-URL-encoded data, which is application/x-www-form-urlencoded. + The default media type for HTML form-URL-encoded data + + + Gets or sets the maximum depth allowed by this formatter. + The maximum depth. + + + Gets or sets the size of the buffer when reading the incoming stream. + The buffer size. + + + Asynchronously deserializes an object of the specified type. + A whose result will be the object instance that has been read. + The type of object to deserialize. + The to read. + The for the content being read. + The to log events to. + + + Performs content negotiation. This is the process of selecting a response writer (formatter) in compliance with header values in the request. + + + Performs content negotiating by selecting the most appropriate out of the passed in formatters for the given request that can serialize an object of the given type. + The result of the negotiation containing the most appropriate instance, or null if there is no appropriate formatter. + The type to be serialized. + Request message, which contains the header values used to perform negotiation. + The set of objects from which to choose. + + + Specifies a callback interface that a formatter can use to log errors while reading. + + + Logs an error. + The path to the member for which the error is being logged. + The error message. + + + Logs an error. + The path to the member for which the error is being logged. + The error message to be logged. + + + Defines method that determines whether a given member is required on deserialization. + + + Determines whether a given member is required on deserialization. + true if should be treated as a required member; otherwise false. + The to be deserialized. + + + Represents the default used by . It uses the formatter's to select required members and recognizes the type annotation. + + + Initializes a new instance of the class. + The formatter to use for resolving required members. + + + Creates a property on the specified class by using the specified parameters. + A to create on the specified class by using the specified parameters. + The member info. + The member serialization. + + + Represents the class to handle JSON. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Determines whether this can read objects of the specified . + true if objects of this can be read, otherwise false. + The type of object that will be read. + + + Determines whether this can write objects of the specified . + true if objects of this can be written, otherwise false. + The type of object that will be written. + + + Called during deserialization to get the . + The object used for serialization. + The type of object that will be serialized or deserialized. + + + Called during deserialization to get the . + The reader to use during deserialization. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + + + Called during serialization to get the . + The writer to use during serialization. + The type of the object to write. + The stream to write to. + The encoding to use when writing. + + + Gets the default media type for JSON, namely "application/json". + The for JSON. + + + Gets or sets a value indicating whether to indent elements when writing data. + true if to indent elements when writing data; otherwise, false. + + + Gets or sets the maximum depth allowed by this formatter. + The maximum depth allowed by this formatter. + + + Called during deserialization to read an object of the specified type from the specified stream. + The object that has been read. + The type of the object to read. + The stream from which to read. + The encoding to use when reading. + The logger to log events to. + + + Gets or sets a value indicating whether to use by default. + true if to by default; otherwise, false. + + + Called during serialization to write an object of the specified type to the specified stream. + The type of the object to write. + The object to write. + The stream to write to. + The encoding to use when writing. + + + Called during serialization to write an object of the specified type to the specified stream. + Returns . + The type of the object to write. + The object to write. + The stream to write to. + The for the content being written. + The transport context. + The token to monitor for cancellation. + + + Base class to handle serializing and deserializing strongly-typed objects using . + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Queries whether this can deserializean object of the specified type. + true if the can deserialize the type; otherwise, false. + The type to deserialize. + + + Queries whether this can serializean object of the specified type. + true if the can serialize the type; otherwise, false. + The type to serialize. + + + Gets the default value for the specified type. + The default value. + The type for which to get the default value. + + + Returns a specialized instance of the that can format a response for the given parameters. + Returns . + The type to format. + The request. + The media type. + + + Gets or sets the maximum number of keys stored in a T: . + The maximum number of keys. + + + Gets the mutable collection of objects that match HTTP requests to media types. + The collection. + + + Asynchronously deserializes an object of the specified type. + A whose result will be an object of the given type. + The type of the object to deserialize. + The to read. + The , if available. It may be null. + The to log events to. + Derived types need to support reading. + + + Asynchronously deserializes an object of the specified type. + A whose result will be an object of the given type. + The type of the object to deserialize. + The to read. + The , if available. It may be null. + The to log events to. + The token to cancel the operation. + + + Gets or sets the instance used to determine required members. + The instance. + + + Determines the best character encoding for reading or writing an HTTP entity body, given a set of content headers. + The encoding that is the best match. + The content headers. + + + Sets the default headers for content that will be formatted using this formatter. This method is called from the constructor. This implementation sets the Content-Type header to the value of mediaType if it is not null. If it is null it sets the Content-Type to the default media type of this formatter. If the Content-Type does not specify a charset it will set it using this formatters configured . + The type of the object being serialized. See . + The content headers that should be configured. + The authoritative media type. Can be null. + + + Gets the mutable collection of character encodings supported bythis . + The collection of objects. + + + Gets the mutable collection of media types supported bythis . + The collection of objects. + + + Asynchronously writes an object of the specified type. + A that will perform the write. + The type of the object to write. + The object value to write. It may be null. + The to which to write. + The if available. It may be null. + The if available. It may be null. + Derived types need to support writing. + + + Asynchronously writes an object of the specified type. + A that will perform the write. + The type of the object to write. + The object value to write. It may be null. + The to which to write. + The if available. It may be null. + The if available. It may be null. + The token to cancel the operation. + Derived types need to support writing. + + + Collection class that contains instances. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + A collection of instances to place in the collection. + + + Adds the elements of the specified collection to the end of the . + The items that should be added to the end of the . The items collection itself cannot be , but it can contain elements that are . + + + Removes all items in the collection. + + + Helper to search a collection for a formatter that can read the .NET type in the given mediaType. + The formatter that can read the type. Null if no formatter found. + The .NET type to read + The media type to match on. + + + Helper to search a collection for a formatter that can write the .NET type in the given mediaType. + The formatter that can write the type. Null if no formatter found. + The .NET type to read + The media type to match on. + + + Gets the to use for application/x-www-form-urlencoded data. + The to use for application/x-www-form-urlencoded data. + + + Inserts the specified item at the specified index in the collection. + The index to insert at. + The item to insert. + + + Inserts the elements of a collection into the at the specified index. + The zero-based index at which the new elements should be inserted. + The items that should be inserted into the . The items collection itself cannot be , but it can contain elements that are . + + + Returns true if the type is one of those loosely defined types that should be excluded from validation. + true if the type should be excluded; otherwise, false. + The .NET to validate. + + + Gets the to use for JSON. + The to use for JSON. + + + Removes the item at the specified index. + The index of the item to remove. + + + Assigns the item at the specified index in the collection. + The index to insert at. + The item to assign. + + + Gets the to use for XML. + The to use for XML. + + + + + + + This class describes how well a particular matches a request. + + + Initializes a new instance of the class. + The matching formatter. + The media type. Can be null in which case the media type application/octet-stream is used. + The quality of the match. Can be null in which case it is considered a full match with a value of 1.0 + The kind of match. + + + Gets the media type formatter. + + + Gets the matched media type. + + + Gets the quality of the match + + + Gets the kind of match that occurred. + + + Contains information about the degree to which a matches the explicit or implicit preferences found in an incoming request. + + + Matched on a type, meaning that the formatter is able to serialize the type. + + + Matched on an explicit “*/*” range in the Accept header. + + + Matched on an explicit literal accept header, such as “application/json”. + + + Matched on an explicit subtype range in an Accept header, such as “application/*”. + + + Matched on the media type of the entity body in the HTTP request message. + + + Matched on after having applied the various s. + + + No match was found + + + An abstract base class used to create an association between or instances that have certain characteristics and a specific . + + + Initializes a new instance of a with the given mediaType value. + The that is associated with or instances that have the given characteristics of the . + + + Initializes a new instance of a with the given mediaType value. + The that is associated with or instances that have the given characteristics of the . + + + Gets the that is associated with or instances that have the given characteristics of the . + + + Returns the quality of the match of the associated with request. + The quality of the match. It must be between 0.0 and 1.0. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match. + The to evaluate for the characteristics associated with the of the . + + + Class that provides s from query strings. + + + Initializes a new instance of the class. + The name of the query string parameter to match, if present. + The value of the query string parameter specified by queryStringParameterName. + The to use if the query parameter specified by queryStringParameterName is present and assigned the value specified by queryStringParameterValue. + + + Initializes a new instance of the class. + The name of the query string parameter to match, if present. + The value of the query string parameter specified by queryStringParameterName. + The media type to use if the query parameter specified by queryStringParameterName is present and assigned the value specified by queryStringParameterValue. + + + Gets the query string parameter name. + + + Gets the query string parameter value. + + + Returns a value indicating whether the current instance can return a from request. + If this instance can produce a from request it returns 1.0 otherwise 0.0. + The to check. + + + This class provides a mapping from an arbitrary HTTP request header field to a used to select instances for handling the entity body of an or . <remarks>This class only checks header fields associated with for a match. It does not check header fields associated with or instances.</remarks> + + + Initializes a new instance of the class. + Name of the header to match. + The header value to match. + The to use when matching headerValue. + if set to true then headerValue is considered a match if it matches a substring of the actual header value. + The to use if headerName and headerValue is considered a match. + + + Initializes a new instance of the class. + Name of the header to match. + The header value to match. + The value comparison to use when matching headerValue. + if set to true then headerValue is considered a match if it matches a substring of the actual header value. + The media type to use if headerName and headerValue is considered a match. + + + Gets the name of the header to match. + + + Gets the header value to match. + + + Gets the to use when matching . + + + Gets a value indicating whether is a matched as a substring of the actual header value. this instance is value substring. + truefalse + + + Returns a value indicating whether the current instance can return a from request. + The quality of the match. It must be between 0.0 and 1.0. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match. + The to check. + + + A that maps the X-Requested-With http header field set by AJAX XmlHttpRequest (XHR) to the media type application/json if no explicit Accept header fields are present in the request. + + + Initializes a new instance of class + + + Returns a value indicating whether the current instance can return a from request. + The quality of the match. A value of 0.0 signifies no match. A value of 1.0 signifies a complete match and that the request was made using XmlHttpRequest without an Accept header. + The to check. + + + + class to handle Xml. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The instance to copy settings from. + + + Queries whether the can deserializean object of the specified type. + true if the can deserialize the type; otherwise, false. + The type to deserialize. + + + Queries whether the can serializean object of the specified type. + true if the can serialize the type; otherwise, false. + The type to serialize. + + + Called during deserialization to get the DataContractSerializer serializer. + The object used for serialization. + The type of object that will be serialized or deserialized. + + + Called during deserialization to get the XML reader to use for reading objects from the stream. + The to use for reading objects. + The to read from. + The for the content being read. + + + Called during deserialization to get the XML serializer. + The object used for serialization. + The type of object that will be serialized or deserialized. + + + Called during serialization to get the XML writer to use for writing objects to the stream. + The to use for writing objects. + The to write to. + The for the content being written. + + + Gets the default media type for the XML formatter. + The default media type, which is “application/xml”. + + + Called during deserialization to get the XML serializer to use for deserializing objects. + An instance of or to use for deserializing the object. + The type of object to deserialize. + The for the content being read. + + + Called during serialization to get the XML serializer to use for serializing objects. + An instance of or to use for serializing the object. + The type of object to serialize. + The object to serialize. + The for the content being written. + + + Gets or sets a value indicating whether to indent elements when writing data. + true to indent elements; otherwise, false. + + + This method is to support infrastructure and is not intended to be used directly from your code. + Returns . + + + This method is to support infrastructure and is not intended to be used directly from your code. + Returns . + + + This method is to support infrastructure and is not intended to be used directly from your code. + Returns . + + + This method is to support infrastructure and is not intended to be used directly from your code. + Returns . + + + Gets and sets the maximum nested node depth. + The maximum nested node depth. + + + Called during deserialization to read an object of the specified type from the specified readStream. + A whose result will be the object instance that has been read. + The type of object to read. + The from which to read. + The for the content being read. + The to log events to. + + + Unregisters the serializer currently associated with the given type. + true if a serializer was previously registered for the type; otherwise, false. + The type of object whose serializer should be removed. + + + Registers an to read or write objects of a specified type. + The instance. + The type of object that will be serialized or deserialized with. + + + Registers an to read or write objects of a specified type. + The type of object that will be serialized or deserialized with. + The instance. + + + Registers an to read or write objects of a specified type. + The type of object that will be serialized or deserialized with. + The instance. + + + Registers an to read or write objects of a specified type. + The instance. + The type of object that will be serialized or deserialized with. + + + Gets or sets a value indicating whether the XML formatter uses the as the default serializer, instead of using the . + If true, the formatter uses the by default; otherwise, it uses the by default. + + + Gets the settings to be used while writing. + The settings to be used while writing. + + + Called during serialization to write an object of the specified type to the specified writeStream. + A that will write the value to the stream. + The type of object to write. + The object to write. + The to which to write. + The for the content being written. + The . + The token to monitor cancellation. + + + Represents the event arguments for the HTTP progress. + + + Initializes a new instance of the class. + The percentage of the progress. + The user token. + The number of bytes transferred. + The total number of bytes transferred. + + + + + Generates progress notification for both request entities being uploaded and response entities being downloaded. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The inner message handler. + + + Occurs when event entities are being downloaded. + + + Occurs when event entities are being uploaded. + + + Raises the event that handles the request of the progress. + The request. + The event handler for the request. + + + Raises the event that handles the response of the progress. + The request. + The event handler for the request. + + + Sends the specified progress message to an HTTP server for delivery. + The sent progress message. + The request. + The cancellation token. + + + Provides value for the cookie header. + + + Initializes a new instance of the class. + + + Initializes a new instance of the class. + The value of the name. + The values. + + + Initializes a new instance of the class. + The value of the name. + The value. + + + Creates a shallow copy of the cookie value. + A shallow copy of the cookie value. + + + Gets a collection of cookies sent by the client. + A collection object representing the client’s cookie variables. + + + Gets or sets the domain to associate the cookie with. + The name of the domain to associate the cookie with. + + + Gets or sets the expiration date and time for the cookie. + The time of day (on the client) at which the cookie expires. + + + Gets or sets a value that specifies whether a cookie is accessible by client-side script. + true if the cookie has the HttpOnly attribute and cannot be accessed through a client-side script; otherwise, false. + + + Gets a shortcut to the cookie property. + The cookie value. + + + Gets or sets the maximum age permitted for a resource. + The maximum age permitted for a resource. + + + Gets or sets the virtual path to transmit with the current cookie. + The virtual path to transmit with the cookie. + + + Gets or sets a value indicating whether to transmit the cookie using Secure Sockets Layer (SSL)—that is, over HTTPS only. + true to transmit the cookie over an SSL connection (HTTPS); otherwise, false. + + + Returns a string that represents the current object. + A string that represents the current object. + + + Indicates a value whether the string representation will be converted. + true if the string representation will be converted; otherwise, false. + The input value. + The parsed value to convert. + + + Contains cookie name and its associated cookie state. + + + Initializes a new instance of the class. + The name of the cookie. + + + Initializes a new instance of the class. + The name of the cookie. + The collection of name-value pair for the cookie. + + + Initializes a new instance of the class. + The name of the cookie. + The value of the cookie. + + + Returns a new object that is a copy of the current instance. + A new object that is a copy of the current instance. + + + Gets or sets the cookie value with the specified cookie name, if the cookie data is structured. + The cookie value with the specified cookie name. + + + Gets or sets the name of the cookie. + The name of the cookie. + + + Returns the string representation the current object. + The string representation the current object. + + + Gets or sets the cookie value, if cookie data is a simple string value. + The value of the cookie. + + + Gets or sets the collection of name-value pair, if the cookie data is structured. + The collection of name-value pair for the cookie. + + + \ No newline at end of file diff --git a/bin/Debug/System.Net.Http.Primitives.dll b/bin/Debug/System.Net.Http.Primitives.dll new file mode 100644 index 0000000000000000000000000000000000000000..2d9655c8b745645d2ec3b31e4056e237205e9ef7 GIT binary patch literal 21744 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 U6sMugUqMn_p38BwuT1Cv0mZx5OaK4? literal 0 HcmV?d00001 diff --git a/bin/Debug/System.Net.Http.Primitives.xml b/bin/Debug/System.Net.Http.Primitives.xml new file mode 100644 index 0000000..53640c6 --- /dev/null +++ b/bin/Debug/System.Net.Http.Primitives.xml @@ -0,0 +1,8 @@ + + + + System.Net.Http.Primitives + + + + diff --git a/bin/Debug/crypto.dll b/bin/Debug/crypto.dll new file mode 100644 index 0000000000000000000000000000000000000000..b768536e421b6109f8b75f6ca97b526a8fa2bbf7 GIT binary patch literal 1375232 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%0AChTZ__EB>ce3E~D6?~Ray1v8Fw{(s#en5!QTfh- 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�b5LKq*__RkY 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

ybHa*dz|SL5c4v?taSkNH{gqP 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

HwmadZoaAUTLtuS2Z}m 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

sF4i9htpSXAHt?NkgJr`jZ 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 z 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 literal 0 HcmV?d00001 diff --git a/bin/Debug/crypto.xml b/bin/Debug/crypto.xml new file mode 100644 index 0000000..9e9a4d1 --- /dev/null +++ b/bin/Debug/crypto.xml @@ -0,0 +1,19296 @@ + + + + crypto + + + + Base class for both the compress and decompress classes. + Holds common arrays, and static data. + + @author Keiron Liddle + + + An input stream that decompresses from the BZip2 format (with the file + header chars) to be read as any other stream. + + @author Keiron Liddle + + NB: note this class has been modified to read the leading BZ from the + start of the BZIP2 stream to make it compatible with other PGP programs. + + + An output stream that compresses into the BZip2 format (with the file + header chars) into another stream. + + @author Keiron Liddle + + TODO: Update to BZip2 1.0.1 + NB: note this class has been modified to add a leading BZ to the + start of the BZIP2 stream to make it compatible with other PGP programs. + + + + modified by Oliver Merkel, 010128 + + + + A simple class the hold and calculate the CRC for sanity checking + of the data. + + @author Keiron Liddle + + + Return the DER encoding of the object, null if the DER encoding can not be made. + + @return a DER byte array, null otherwise. + + + a general purpose ASN.1 decoder - note: this class differs from the + others in that it returns null after it has read the last object in + the stream. If an ASN.1 Null is encountered a Der/BER Null object is + returned. + + + Create an ASN1InputStream where no DER object will be longer than limit. + + @param input stream containing ASN.1 encoded data. + @param limit maximum size of a DER encoded object. + + + Create an ASN1InputStream based on the input byte array. The length of DER objects in + the stream is automatically limited to the length of the input array. + + @param input array containing ASN.1 encoded data. + + + build an object given its tag and the number of bytes to construct it from. + + + A Null object. + + +

Create a base ASN.1 object from a byte array. + The byte array to parse. + The base ASN.1 object represented by the byte array. + If there is a problem parsing the data. + + + Read a base ASN.1 object from a stream. + The stream to parse. + The base ASN.1 object represented by the byte array. + If there is a problem parsing the data. + + + return an Octet string from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + return an Octet string from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + @param string the octets making up the octet string. + + + return an Asn1Sequence from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Return an ASN1 sequence from a tagged object. There is a special + case here, if an object appears to have been explicitly tagged on + reading but we were expecting it to be implicitly tagged in the + normal course of events it indicates that we lost the surrounding + sequence - so we need to add it back (this will happen if the tagged + object is a sequence that contains other sequences). If you are + dealing with implicitly tagged sequences you really should + be using this method. + + @param obj the tagged object. + @param explicitly true if the object is meant to be explicitly tagged, + false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + return the object at the sequence position indicated by index. + + @param index the sequence number (starting at zero) of the object + @return the object at the sequence position indicated by index. + + + return an ASN1Set from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Return an ASN1 set from a tagged object. There is a special + case here, if an object appears to have been explicitly tagged on + reading but we were expecting it to be implicitly tagged in the + normal course of events it indicates that we lost the surrounding + set - so we need to add it back (this will happen if the tagged + object is a sequence that contains other sequences). If you are + dealing with implicitly tagged sets you really should + be using this method. + + @param obj the tagged object. + @param explicitly true if the object is meant to be explicitly tagged + false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + return the object at the set position indicated by index. + + @param index the set number (starting at zero) of the object + @return the object at the set position indicated by index. + + + return true if a <= b (arrays are assumed padded with zeros). + + + ASN.1 TaggedObject - in ASN.1 notation this is any object preceded by + a [n] where n is some number - these are assumed to follow the construction + rules (as with sequences). + + + @param tagNo the tag number for this object. + @param obj the tagged object. + + + @param explicitly true if the object is explicitly tagged. + @param tagNo the tag number for this object. + @param obj the tagged object. + + + return whether or not the object may be explicitly tagged. +

+ Note: if the object has been read from an input stream, the only + time you can be sure if isExplicit is returning the true state of + affairs is if it returns false. An implicitly tagged object may appear + to be explicitly tagged, so you need to understand the context under + which the reading was done as well, see GetObject below.

+
+ + return whatever was following the tag. +

+ Note: tagged objects are generally context dependent if you're + trying to extract a tagged object you should be going via the + appropriate GetInstance method.

+
+ + Return the object held in this tagged object as a parser assuming it has + the type of the passed in tag. If the object doesn't have a parser + associated with it, the base object is returned. + + + A BER Null object. + + + convert a vector of octet strings into a single byte string + + + The octets making up the octet string. + + + return the DER octets that make up this string. + + + create an empty sequence + + + create a sequence containing one object + + + create a sequence containing a vector of objects. + + + create an empty sequence + + + create a set containing one object + + + create a set containing a vector of objects. + + + BER TaggedObject - in ASN.1 notation this is any object preceded by + a [n] where n is some number - these are assumed to follow the construction + rules (as with sequences). + + + @param tagNo the tag number for this object. + @param obj the tagged object. + + + @param explicitly true if an explicitly tagged object. + @param tagNo the tag number for this object. + @param obj the tagged object. + + + create an implicitly tagged object that contains a zero + length sequence. + + +
+            CAKeyUpdAnnContent ::= SEQUENCE {
+                                        oldWithNew   CmpCertificate, -- old pub signed with new priv
+                                        newWithOld   CmpCertificate, -- new pub signed with old priv
+                                        newWithNew   CmpCertificate  -- new pub signed with new priv
+             }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertConfirmContent ::= SEQUENCE OF CertStatus
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertifiedKeyPair ::= SEQUENCE {
+                                             certOrEncCert       CertOrEncCert,
+                                             privateKey      [0] EncryptedValue      OPTIONAL,
+                                             -- see [CRMF] for comment on encoding
+                                             publicationInfo [1] PKIPublicationInfo  OPTIONAL
+                  }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertOrEncCert ::= CHOICE {
+                                 certificate     [0] CMPCertificate,
+                                 encryptedCert   [1] EncryptedValue
+                      }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertRepMessage ::= SEQUENCE {
+                                     caPubs       [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+                                                                                        OPTIONAL,
+                                     response         SEQUENCE OF CertResponse
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertResponse ::= SEQUENCE {
+                                       certReqId           INTEGER,
+                                       -- to match this response with corresponding request (a value
+                                       -- of -1 is to be used if certReqId is not specified in the
+                                       -- corresponding request)
+                                       status              PKIStatusInfo,
+                                       certifiedKeyPair    CertifiedKeyPair    OPTIONAL,
+                                       rspInfo             OCTET STRING        OPTIONAL
+                                       -- analogous to the id-regInfo-utf8Pairs string defined
+                                       -- for regInfo in CertReqMsg [CRMF]
+                        }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertStatus ::= SEQUENCE {
+                              certHash    OCTET STRING,
+                              -- the hash of the certificate, using the same hash algorithm
+                              -- as is used to create and verify the certificate signature
+                              certReqId   INTEGER,
+                              -- to match this confirmation with the corresponding req/rep
+                              statusInfo  PKIStatusInfo OPTIONAL
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+             Challenge ::= SEQUENCE {
+                             owf                 AlgorithmIdentifier  OPTIONAL,
+            
+                             -- MUST be present in the first Challenge; MAY be omitted in
+                             -- any subsequent Challenge in POPODecKeyChallContent (if
+                             -- omitted, then the owf used in the immediately preceding
+                             -- Challenge is to be used).
+            
+                             witness             OCTET STRING,
+                             -- the result of applying the one-way function (owf) to a
+                             -- randomly-generated INTEGER, A.  [Note that a different
+                             -- INTEGER MUST be used for each Challenge.]
+                             challenge           OCTET STRING
+                             -- the encryption (under the public key for which the cert.
+                             -- request is being made) of Rand, where Rand is specified as
+                             --   Rand ::= SEQUENCE {
+                             --      int      INTEGER,
+                             --       - the randomly-generated INTEGER A (above)
+                             --      sender   GeneralName
+                             --       - the sender's name (as included in PKIHeader)
+                             --   }
+                  }
+             
+ @return a basic ASN.1 object representation. +
+ + Note: the addition of attribute certificates is a BC extension. + + +
+             CMPCertificate ::= CHOICE {
+                        x509v3PKCert        Certificate
+                        x509v2AttrCert      [1] AttributeCertificate
+              }
+             
+ Note: the addition of attribute certificates is a BC extension. + + @return a basic ASN.1 object representation. +
+ +
+            CrlAnnContent ::= SEQUENCE OF CertificateList
+            
+ @return a basic ASN.1 object representation. +
+ +
+            ErrorMsgContent ::= SEQUENCE {
+                                   pKIStatusInfo          PKIStatusInfo,
+                                   errorCode              INTEGER           OPTIONAL,
+                                   -- implementation-specific error codes
+                                   errorDetails           PKIFreeText       OPTIONAL
+                                   -- implementation-specific error details
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            GenMsgContent ::= SEQUENCE OF InfoTypeAndValue
+            
+ @return a basic ASN.1 object representation. +
+ +
+            GenRepContent ::= SEQUENCE OF InfoTypeAndValue
+            
+ @return a basic ASN.1 object representation. +
+ + Example InfoTypeAndValue contents include, but are not limited + to, the following (un-comment in this ASN.1 module and use as + appropriate for a given environment): +
+               id-it-caProtEncCert    OBJECT IDENTIFIER ::= {id-it 1}
+                  CAProtEncCertValue      ::= CMPCertificate
+               id-it-signKeyPairTypes OBJECT IDENTIFIER ::= {id-it 2}
+                 SignKeyPairTypesValue   ::= SEQUENCE OF AlgorithmIdentifier
+               id-it-encKeyPairTypes  OBJECT IDENTIFIER ::= {id-it 3}
+                 EncKeyPairTypesValue    ::= SEQUENCE OF AlgorithmIdentifier
+               id-it-preferredSymmAlg OBJECT IDENTIFIER ::= {id-it 4}
+                  PreferredSymmAlgValue   ::= AlgorithmIdentifier
+               id-it-caKeyUpdateInfo  OBJECT IDENTIFIER ::= {id-it 5}
+                  CAKeyUpdateInfoValue    ::= CAKeyUpdAnnContent
+               id-it-currentCRL       OBJECT IDENTIFIER ::= {id-it 6}
+                  CurrentCRLValue         ::= CertificateList
+               id-it-unsupportedOIDs  OBJECT IDENTIFIER ::= {id-it 7}
+                  UnsupportedOIDsValue    ::= SEQUENCE OF OBJECT IDENTIFIER
+               id-it-keyPairParamReq  OBJECT IDENTIFIER ::= {id-it 10}
+                  KeyPairParamReqValue    ::= OBJECT IDENTIFIER
+               id-it-keyPairParamRep  OBJECT IDENTIFIER ::= {id-it 11}
+                  KeyPairParamRepValue    ::= AlgorithmIdentifer
+               id-it-revPassphrase    OBJECT IDENTIFIER ::= {id-it 12}
+                  RevPassphraseValue      ::= EncryptedValue
+               id-it-implicitConfirm  OBJECT IDENTIFIER ::= {id-it 13}
+                  ImplicitConfirmValue    ::= NULL
+               id-it-confirmWaitTime  OBJECT IDENTIFIER ::= {id-it 14}
+                  ConfirmWaitTimeValue    ::= GeneralizedTime
+               id-it-origPKIMessage   OBJECT IDENTIFIER ::= {id-it 15}
+                  OrigPKIMessageValue     ::= PKIMessages
+               id-it-suppLangTags     OBJECT IDENTIFIER ::= {id-it 16}
+                  SuppLangTagsValue       ::= SEQUENCE OF UTF8String
+            
+             where
+            
+               id-pkix OBJECT IDENTIFIER ::= {
+                  iso(1) identified-organization(3)
+                  dod(6) internet(1) security(5) mechanisms(5) pkix(7)}
+             and
+                  id-it   OBJECT IDENTIFIER ::= {id-pkix 4}
+             
+
+ +
+            InfoTypeAndValue ::= SEQUENCE {
+                                    infoType               OBJECT IDENTIFIER,
+                                    infoValue              ANY DEFINED BY infoType  OPTIONAL
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            KeyRecRepContent ::= SEQUENCE {
+                                    status                  PKIStatusInfo,
+                                    newSigCert          [0] CMPCertificate OPTIONAL,
+                                    caCerts             [1] SEQUENCE SIZE (1..MAX) OF
+                                                                      CMPCertificate OPTIONAL,
+                                    keyPairHist         [2] SEQUENCE SIZE (1..MAX) OF
+                                                                      CertifiedKeyPair OPTIONAL
+                         }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            OobCertHash ::= SEQUENCE {
+                                 hashAlg     [0] AlgorithmIdentifier     OPTIONAL,
+                                 certId      [1] CertId                  OPTIONAL,
+                                 hashVal         BIT STRING
+                                 -- hashVal is calculated over the Der encoding of the
+                                 -- self-signed certificate with the identifier certID.
+                  }
+            
+ @return a basic ASN.1 object representation. +
+ +
+             PbmParameter ::= SEQUENCE {
+                                   salt                OCTET STRING,
+                                   -- note:  implementations MAY wish to limit acceptable sizes
+                                   -- of this string to values appropriate for their environment
+                                   -- in order to reduce the risk of denial-of-service attacks
+                                   owf                 AlgorithmIdentifier,
+                                   -- AlgId for a One-Way Function (SHA-1 recommended)
+                                   iterationCount      INTEGER,
+                                   -- number of times the OWF is applied
+                                   -- note:  implementations MAY wish to limit acceptable sizes
+                                   -- of this integer to values appropriate for their environment
+                                   -- in order to reduce the risk of denial-of-service attacks
+                                   mac                 AlgorithmIdentifier
+                                   -- the MAC AlgId (e.g., DES-MAC, Triple-DES-MAC [PKCS11],
+               }   -- or HMAC [RFC2104, RFC2202])
+            
+ @return a basic ASN.1 object representation. +
+ + Creates a new PkiBody. + @param type one of the TYPE_* constants + @param content message content + + +
+            PkiBody ::= CHOICE {       -- message-specific body elements
+                   ir       [0]  CertReqMessages,        --Initialization Request
+                   ip       [1]  CertRepMessage,         --Initialization Response
+                   cr       [2]  CertReqMessages,        --Certification Request
+                   cp       [3]  CertRepMessage,         --Certification Response
+                   p10cr    [4]  CertificationRequest,   --imported from [PKCS10]
+                   popdecc  [5]  POPODecKeyChallContent, --pop Challenge
+                   popdecr  [6]  POPODecKeyRespContent,  --pop Response
+                   kur      [7]  CertReqMessages,        --Key Update Request
+                   kup      [8]  CertRepMessage,         --Key Update Response
+                   krr      [9]  CertReqMessages,        --Key Recovery Request
+                   krp      [10] KeyRecRepContent,       --Key Recovery Response
+                   rr       [11] RevReqContent,          --Revocation Request
+                   rp       [12] RevRepContent,          --Revocation Response
+                   ccr      [13] CertReqMessages,        --Cross-Cert. Request
+                   ccp      [14] CertRepMessage,         --Cross-Cert. Response
+                   ckuann   [15] CAKeyUpdAnnContent,     --CA Key Update Ann.
+                   cann     [16] CertAnnContent,         --Certificate Ann.
+                   rann     [17] RevAnnContent,          --Revocation Ann.
+                   crlann   [18] CRLAnnContent,          --CRL Announcement
+                   pkiconf  [19] PKIConfirmContent,      --Confirmation
+                   nested   [20] NestedMessageContent,   --Nested Message
+                   genm     [21] GenMsgContent,          --General Message
+                   genp     [22] GenRepContent,          --General Response
+                   error    [23] ErrorMsgContent,        --Error Message
+                   certConf [24] CertConfirmContent,     --Certificate confirm
+                   pollReq  [25] PollReqContent,         --Polling request
+                   pollRep  [26] PollRepContent          --Polling response
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PkiConfirmContent ::= NULL
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PKIFailureInfo ::= BIT STRING {
+            badAlg               (0),
+              -- unrecognized or unsupported Algorithm Identifier
+            badMessageCheck      (1), -- integrity check failed (e.g., signature did not verify)
+            badRequest           (2),
+              -- transaction not permitted or supported
+            badTime              (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+            badCertId            (4), -- no certificate could be found matching the provided criteria
+            badDataFormat        (5),
+              -- the data submitted has the wrong format
+            wrongAuthority       (6), -- the authority indicated in the request is different from the one creating the response token
+            incorrectData        (7), -- the requester's data is incorrect (for notary services)
+            missingTimeStamp     (8), -- when the timestamp is missing but should be there (by policy)
+            badPOP               (9)  -- the proof-of-possession failed
+            timeNotAvailable    (14),
+              -- the TSA's time source is not available
+            unacceptedPolicy    (15),
+              -- the requested TSA policy is not supported by the TSA
+            unacceptedExtension (16),
+              -- the requested extension is not supported by the TSA
+             addInfoNotAvailable (17)
+               -- the additional information requested could not be understood
+               -- or is not available
+             systemFailure       (25)
+               -- the request cannot be handled due to system failure
+            
+
+ + Basic constructor. + + + Return the number of string elements present. + + @return number of elements present. + + + Return the UTF8STRING at index. + + @param index index of the string of interest + @return the string at index. + + +
+            PkiFreeText ::= SEQUENCE SIZE (1..MAX) OF UTF8String
+            
+
+ + Value for a "null" recipient or sender. + + +
+             PkiHeader ::= SEQUENCE {
+                       pvno                INTEGER     { cmp1999(1), cmp2000(2) },
+                       sender              GeneralName,
+                       -- identifies the sender
+                       recipient           GeneralName,
+                       -- identifies the intended recipient
+                       messageTime     [0] GeneralizedTime         OPTIONAL,
+                       -- time of production of this message (used when sender
+                       -- believes that the transport will be "suitable"; i.e.,
+                       -- that the time will still be meaningful upon receipt)
+                       protectionAlg   [1] AlgorithmIdentifier     OPTIONAL,
+                       -- algorithm used for calculation of protection bits
+                       senderKID       [2] KeyIdentifier           OPTIONAL,
+                       recipKID        [3] KeyIdentifier           OPTIONAL,
+                       -- to identify specific keys used for protection
+                       transactionID   [4] OCTET STRING            OPTIONAL,
+                       -- identifies the transaction; i.e., this will be the same in
+                       -- corresponding request, response, certConf, and PKIConf
+                       -- messages
+                       senderNonce     [5] OCTET STRING            OPTIONAL,
+                       recipNonce      [6] OCTET STRING            OPTIONAL,
+                       -- nonces used to provide replay protection, senderNonce
+                       -- is inserted by the creator of this message; recipNonce
+                       -- is a nonce previously inserted in a related message by
+                       -- the intended recipient of this message
+                       freeText        [7] PKIFreeText             OPTIONAL,
+                       -- this may be used to indicate context-specific instructions
+                       -- (this field is intended for human consumption)
+                       generalInfo     [8] SEQUENCE SIZE (1..MAX) OF
+                                            InfoTypeAndValue     OPTIONAL
+                       -- this may be used to convey context-specific information
+                       -- (this field not primarily intended for human consumption)
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+             PKIHeader ::= SEQUENCE {
+                       pvno                INTEGER     { cmp1999(1), cmp2000(2) },
+                       sender              GeneralName,
+                       -- identifies the sender
+                       recipient           GeneralName,
+                       -- identifies the intended recipient
+                       messageTime     [0] GeneralizedTime         OPTIONAL,
+                       -- time of production of this message (used when sender
+                       -- believes that the transport will be "suitable"; i.e.,
+                       -- that the time will still be meaningful upon receipt)
+                       protectionAlg   [1] AlgorithmIdentifier     OPTIONAL,
+                       -- algorithm used for calculation of protection bits
+                       senderKID       [2] KeyIdentifier           OPTIONAL,
+                       recipKID        [3] KeyIdentifier           OPTIONAL,
+                       -- to identify specific keys used for protection
+                       transactionID   [4] OCTET STRING            OPTIONAL,
+                       -- identifies the transaction; i.e., this will be the same in
+                       -- corresponding request, response, certConf, and PKIConf
+                       -- messages
+                       senderNonce     [5] OCTET STRING            OPTIONAL,
+                       recipNonce      [6] OCTET STRING            OPTIONAL,
+                       -- nonces used to provide replay protection, senderNonce
+                       -- is inserted by the creator of this message; recipNonce
+                       -- is a nonce previously inserted in a related message by
+                       -- the intended recipient of this message
+                       freeText        [7] PKIFreeText             OPTIONAL,
+                       -- this may be used to indicate context-specific instructions
+                       -- (this field is intended for human consumption)
+                       generalInfo     [8] SEQUENCE SIZE (1..MAX) OF
+                                            InfoTypeAndValue     OPTIONAL
+                       -- this may be used to convey context-specific information
+                       -- (this field not primarily intended for human consumption)
+            }
+            
+ @return a basic ASN.1 object representation. +
+ + Creates a new PkiMessage. + + @param header message header + @param body message body + @param protection message protection (may be null) + @param extraCerts extra certificates (may be null) + + +
+            PkiMessage ::= SEQUENCE {
+                             header           PKIHeader,
+                             body             PKIBody,
+                             protection   [0] PKIProtection OPTIONAL,
+                             extraCerts   [1] SEQUENCE SIZE (1..MAX) OF CMPCertificate
+                                                                                OPTIONAL
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PkiMessages ::= SEQUENCE SIZE (1..MAX) OF PkiMessage
+            
+ @return a basic ASN.1 object representation. +
+ + @param status + + + @param status + @param statusString + + +
+             PkiStatusInfo ::= SEQUENCE {
+                 status        PKIStatus,                (INTEGER)
+                 statusString  PkiFreeText     OPTIONAL,
+                 failInfo      PkiFailureInfo  OPTIONAL  (BIT STRING)
+             }
+            
+             PKIStatus:
+               granted                (0), -- you got exactly what you asked for
+               grantedWithMods        (1), -- you got something like what you asked for
+               rejection              (2), -- you don't get it, more information elsewhere in the message
+               waiting                (3), -- the request body part has not yet been processed, expect to hear more later
+               revocationWarning      (4), -- this message contains a warning that a revocation is imminent
+               revocationNotification (5), -- notification that a revocation has occurred
+               keyUpdateWarning       (6)  -- update already done for the oldCertId specified in CertReqMsg
+            
+             PkiFailureInfo:
+               badAlg           (0), -- unrecognized or unsupported Algorithm Identifier
+               badMessageCheck  (1), -- integrity check failed (e.g., signature did not verify)
+               badRequest       (2), -- transaction not permitted or supported
+               badTime          (3), -- messageTime was not sufficiently close to the system time, as defined by local policy
+               badCertId        (4), -- no certificate could be found matching the provided criteria
+               badDataFormat    (5), -- the data submitted has the wrong format
+               wrongAuthority   (6), -- the authority indicated in the request is different from the one creating the response token
+               incorrectData    (7), -- the requester's data is incorrect (for notary services)
+               missingTimeStamp (8), -- when the timestamp is missing but should be there (by policy)
+               badPOP           (9)  -- the proof-of-possession failed
+            
+             
+
+ +
+            PollRepContent ::= SEQUENCE OF SEQUENCE {
+                    certReqId              INTEGER,
+                    checkAfter             INTEGER,  -- time in seconds
+                    reason                 PKIFreeText OPTIONAL
+                }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PollReqContent ::= SEQUENCE OF SEQUENCE {
+                                   certReqId              INTEGER
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PopoDecKeyChallContent ::= SEQUENCE OF Challenge
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PopoDecKeyRespContent ::= SEQUENCE OF INTEGER
+            
+ @return a basic ASN.1 object representation. +
+ +
+            ProtectedPart ::= SEQUENCE {
+                               header    PKIHeader,
+                               body      PKIBody
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            RevAnnContent ::= SEQUENCE {
+                  status              PKIStatus,
+                  certId              CertId,
+                  willBeRevokedAt     GeneralizedTime,
+                  badSinceDate        GeneralizedTime,
+                  crlDetails          Extensions  OPTIONAL
+                   -- extra CRL details (e.g., crl number, reason, location, etc.)
+            }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            RevDetails ::= SEQUENCE {
+                             certDetails         CertTemplate,
+                              -- allows requester to specify as much as they can about
+                              -- the cert. for which revocation is requested
+                              -- (e.g., for cases in which serialNumber is not available)
+                              crlEntryDetails     Extensions       OPTIONAL
+                              -- requested crlEntryExtensions
+                        }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            RevRepContent ::= SEQUENCE {
+                   status       SEQUENCE SIZE (1..MAX) OF PKIStatusInfo,
+                   -- in same order as was sent in RevReqContent
+                   revCerts [0] SEQUENCE SIZE (1..MAX) OF CertId OPTIONAL,
+                   -- IDs for which revocation was requested
+                   -- (same order as status)
+                   crls     [1] SEQUENCE SIZE (1..MAX) OF CertificateList OPTIONAL
+                   -- the resulting CRLs (there may be more than one)
+              }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            RevReqContent ::= SEQUENCE OF RevDetails
+            
+ @return a basic ASN.1 object representation. +
+ + return an Attribute object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            Attribute ::= SEQUENCE {
+                attrType OBJECT IDENTIFIER,
+                attrValues SET OF AttributeValue
+            }
+            
+
+ +
+            Attributes ::=
+              SET SIZE(1..MAX) OF Attribute -- according to RFC 5652
+            
+ @return +
+ + Return the first attribute matching the given OBJECT IDENTIFIER + + + Return all the attributes matching the OBJECT IDENTIFIER oid. The vector will be + empty if there are no attributes of the required type present. + + @param oid type of attribute required. + @return a vector of all the attributes found of type oid. + + + Return a new table with the passed in attribute added. + + @param attrType + @param attrValue + @return + + + return an AuthenticatedData object from a tagged object. + + @param obj the tagged object holding the object we want. + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @throws ArgumentException if the object held by the + tagged object cannot be converted. + + + return an AuthenticatedData object from the given object. + + @param obj the object we want converted. + @throws ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+             AuthenticatedData ::= SEQUENCE {
+                   version CMSVersion,
+                   originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+                   recipientInfos RecipientInfos,
+                   macAlgorithm MessageAuthenticationCodeAlgorithm,
+                   digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+                   encapContentInfo EncapsulatedContentInfo,
+                   authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+                   mac MessageAuthenticationCode,
+                   unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+            
+             AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+            
+             UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+            
+             MessageAuthenticationCode ::= OCTET STRING
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+             AuthenticatedData ::= SEQUENCE {
+                   version CMSVersion,
+                   originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+                   recipientInfos RecipientInfos,
+                   macAlgorithm MessageAuthenticationCodeAlgorithm,
+                   digestAlgorithm [1] DigestAlgorithmIdentifier OPTIONAL,
+                   encapContentInfo EncapsulatedContentInfo,
+                   authAttrs [2] IMPLICIT AuthAttributes OPTIONAL,
+                   mac MessageAuthenticationCode,
+                   unauthAttrs [3] IMPLICIT UnauthAttributes OPTIONAL }
+            
+             AuthAttributes ::= SET SIZE (1..MAX) OF Attribute
+            
+             UnauthAttributes ::= SET SIZE (1..MAX) OF Attribute
+            
+             MessageAuthenticationCode ::= OCTET STRING
+             
+
+ + return an AuthEnvelopedData object from a tagged object. + + @param obj the tagged object holding the object we want. + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @throws ArgumentException if the object held by the + tagged object cannot be converted. + + + return an AuthEnvelopedData object from the given object. + + @param obj the object we want converted. + @throws ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            AuthEnvelopedData ::= SEQUENCE {
+              version CMSVersion,
+              originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+              recipientInfos RecipientInfos,
+              authEncryptedContentInfo EncryptedContentInfo,
+              authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+              mac MessageAuthenticationCode,
+              unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. + +
+            AuthEnvelopedData ::= SEQUENCE {
+              version CMSVersion,
+              originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+              recipientInfos RecipientInfos,
+              authEncryptedContentInfo EncryptedContentInfo,
+              authAttrs [1] IMPLICIT AuthAttributes OPTIONAL,
+              mac MessageAuthenticationCode,
+              unauthAttrs [2] IMPLICIT UnauthAttributes OPTIONAL }
+            
+
+ + RFC 3274 - CMS Compressed Data. +
+            CompressedData ::= Sequence {
+             version CMSVersion,
+             compressionAlgorithm CompressionAlgorithmIdentifier,
+             encapContentInfo EncapsulatedContentInfo
+            }
+            
+
+ + return a CompressedData object from a tagged object. + + @param ato the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a CompressedData object from the given object. + + @param _obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + RFC 3274 - CMS Compressed Data. +
+            CompressedData ::= SEQUENCE {
+             version CMSVersion,
+             compressionAlgorithm CompressionAlgorithmIdentifier,
+             encapContentInfo EncapsulatedContentInfo
+            }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ContentInfo ::= Sequence {
+                     contentType ContentType,
+                     content
+                     [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ContentInfo ::= SEQUENCE {
+                     contentType ContentType,
+                     content
+                     [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+            
+
+ + return an AuthEnvelopedData object from a tagged object. + + @param obj the tagged object holding the object we want. + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @throws ArgumentException if the object held by the + tagged object cannot be converted. + + + return an AuthEnvelopedData object from the given object. + + @param obj the object we want converted. + @throws ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            MQVuserKeyingMaterial ::= SEQUENCE {
+              ephemeralPublicKey OriginatorPublicKey,
+              addedukm [0] EXPLICIT UserKeyingMaterial OPTIONAL  }
+            
+
+ + return an EncryptedContentInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            EncryptedContentInfo ::= Sequence {
+                contentType ContentType,
+                contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+                encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+            }
+            
+
+ +
+            EncryptedContentInfo ::= SEQUENCE {
+                contentType ContentType,
+                contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,
+                encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+            }
+            
+
+ +
+                  EncryptedData ::= SEQUENCE {
+                                version CMSVersion,
+                                encryptedContentInfo EncryptedContentInfo,
+                                unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL }
+            
+ @return a basic ASN.1 object representation. +
+ + return an EnvelopedData object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return an EnvelopedData object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            EnvelopedData ::= Sequence {
+                version CMSVersion,
+                originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+                recipientInfos RecipientInfos,
+                encryptedContentInfo EncryptedContentInfo,
+                unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+            }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            EnvelopedData ::= SEQUENCE {
+                version CMSVersion,
+                originatorInfo [0] IMPLICIT OriginatorInfo OPTIONAL,
+                recipientInfos RecipientInfos,
+                encryptedContentInfo EncryptedContentInfo,
+                unprotectedAttrs [1] IMPLICIT UnprotectedAttributes OPTIONAL
+            }
+            
+
+ + return a KekIdentifier object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a KekIdentifier object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            KekIdentifier ::= Sequence {
+                keyIdentifier OCTET STRING,
+                date GeneralizedTime OPTIONAL,
+                other OtherKeyAttribute OPTIONAL
+            }
+            
+
+ + return a KekRecipientInfo object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a KekRecipientInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            KekRecipientInfo ::= Sequence {
+                version CMSVersion,  -- always set to 4
+                kekID KekIdentifier,
+                keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+                encryptedKey EncryptedKey
+            }
+            
+
+ + return an KeyAgreeRecipientIdentifier object from a tagged object. + + @param obj the tagged object holding the object we want. + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return an KeyAgreeRecipientIdentifier object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            KeyAgreeRecipientIdentifier ::= CHOICE {
+                issuerAndSerialNumber IssuerAndSerialNumber,
+                rKeyId [0] IMPLICIT RecipientKeyIdentifier
+            }
+            
+
+ + return a KeyAgreeRecipientInfo object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a KeyAgreeRecipientInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + * Produce an object suitable for an Asn1OutputStream. + *
+                     * KeyAgreeRecipientInfo ::= Sequence {
+                     *     version CMSVersion,  -- always set to 3
+                     *     originator [0] EXPLICIT OriginatorIdentifierOrKey,
+                     *     ukm [1] EXPLICIT UserKeyingMaterial OPTIONAL,
+                     *     keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+                     *     recipientEncryptedKeys RecipientEncryptedKeys
+                     * }
+            		 *
+            		 * UserKeyingMaterial ::= OCTET STRING
+                     * 
+
+ + return a KeyTransRecipientInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            KeyTransRecipientInfo ::= Sequence {
+                version CMSVersion,  -- always set to 0 or 2
+                rid RecipientIdentifier,
+                keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+                encryptedKey EncryptedKey
+            }
+            
+
+ +
+            MetaData ::= SEQUENCE {
+              hashProtected        BOOLEAN,
+              fileName             UTF8String OPTIONAL,
+              mediaType            IA5String OPTIONAL,
+              otherMetaData        Attributes OPTIONAL
+            }
+            
+ @return +
+ + return an OriginatorIdentifierOrKey object from a tagged object. + + @param o the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return an OriginatorIdentifierOrKey object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+             OriginatorIdentifierOrKey ::= CHOICE {
+                 issuerAndSerialNumber IssuerAndSerialNumber,
+                 subjectKeyIdentifier [0] SubjectKeyIdentifier,
+                 originatorKey [1] OriginatorPublicKey
+             }
+            
+             SubjectKeyIdentifier ::= OCTET STRING
+             
+
+ + return an OriginatorInfo object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return an OriginatorInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            OriginatorInfo ::= Sequence {
+                certs [0] IMPLICIT CertificateSet OPTIONAL,
+                crls [1] IMPLICIT CertificateRevocationLists OPTIONAL
+            }
+            
+
+ + return an OriginatorPublicKey object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return an OriginatorPublicKey object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            OriginatorPublicKey ::= Sequence {
+                algorithm AlgorithmIdentifier,
+                publicKey BIT STRING
+            }
+            
+
+ + return an OtherKeyAttribute object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            OtherKeyAttribute ::= Sequence {
+                keyAttrId OBJECT IDENTIFIER,
+                keyAttr ANY DEFINED BY keyAttrId OPTIONAL
+            }
+            
+
+ + return a OtherRecipientInfo object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a OtherRecipientInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            OtherRecipientInfo ::= Sequence {
+               oriType OBJECT IDENTIFIER,
+               oriValue ANY DEFINED BY oriType }
+            
+
+ + return a PasswordRecipientInfo object from a tagged object. + + @param obj the tagged object holding the object we want. + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a PasswordRecipientInfo object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            PasswordRecipientInfo ::= Sequence {
+              version CMSVersion,   -- Always set to 0
+              keyDerivationAlgorithm [0] KeyDerivationAlgorithmIdentifier
+                                        OPTIONAL,
+             keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
+             encryptedKey EncryptedKey }
+            
+
+ + return an RecipientEncryptedKey object from a tagged object. + + @param obj the tagged object holding the object we want. + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a RecipientEncryptedKey object from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            RecipientEncryptedKey ::= SEQUENCE {
+                rid KeyAgreeRecipientIdentifier,
+                encryptedKey EncryptedKey
+            }
+            
+
+ + return a RecipientIdentifier object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+             RecipientIdentifier ::= CHOICE {
+                 issuerAndSerialNumber IssuerAndSerialNumber,
+                 subjectKeyIdentifier [0] SubjectKeyIdentifier
+             }
+            
+             SubjectKeyIdentifier ::= OCTET STRING
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            RecipientInfo ::= CHOICE {
+                ktri KeyTransRecipientInfo,
+                kari [1] KeyAgreeRecipientInfo,
+                kekri [2] KekRecipientInfo,
+                pwri [3] PasswordRecipientInfo,
+                ori [4] OtherRecipientInfo }
+            
+
+ + return a RecipientKeyIdentifier object from a tagged object. + + @param _ato the tagged object holding the object we want. + @param _explicit true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the object held by the + tagged object cannot be converted. + + + return a RecipientKeyIdentifier object from the given object. + + @param _obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+             RecipientKeyIdentifier ::= Sequence {
+                 subjectKeyIdentifier SubjectKeyIdentifier,
+                 date GeneralizedTime OPTIONAL,
+                 other OtherKeyAttribute OPTIONAL
+             }
+            
+             SubjectKeyIdentifier ::= OCTET STRING
+             
+
+ + a signed data object. + + + Produce an object suitable for an Asn1OutputStream. +
+            SignedData ::= Sequence {
+                version CMSVersion,
+                digestAlgorithms DigestAlgorithmIdentifiers,
+                encapContentInfo EncapsulatedContentInfo,
+                certificates [0] IMPLICIT CertificateSet OPTIONAL,
+                crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+                signerInfos SignerInfos
+              }
+            
+
+ +
+            SignedData ::= SEQUENCE {
+                version CMSVersion,
+                digestAlgorithms DigestAlgorithmIdentifiers,
+                encapContentInfo EncapsulatedContentInfo,
+                certificates [0] IMPLICIT CertificateSet OPTIONAL,
+                crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+                signerInfos SignerInfos
+              }
+            
+
+ + return a SignerIdentifier object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+             SignerIdentifier ::= CHOICE {
+                 issuerAndSerialNumber IssuerAndSerialNumber,
+                 subjectKeyIdentifier [0] SubjectKeyIdentifier
+             }
+            
+             SubjectKeyIdentifier ::= OCTET STRING
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+              SignerInfo ::= Sequence {
+                  version Version,
+                  SignerIdentifier sid,
+                  digestAlgorithm DigestAlgorithmIdentifier,
+                  authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+                  digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+                  encryptedDigest EncryptedDigest,
+                  unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+              }
+            
+              EncryptedDigest ::= OCTET STRING
+            
+              DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+            
+              DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+             
+
+ + creates a time object from a given date - if the date is between 1950 + and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime + is used. + + + Produce an object suitable for an Asn1OutputStream. +
+            Time ::= CHOICE {
+                        utcTime        UTCTime,
+                        generalTime    GeneralizedTime }
+            
+
+ +
+            TimeStampAndCRL ::= SEQUENCE {
+                timeStamp   TimeStampToken,          -- according to RFC 3161
+                crl         CertificateList OPTIONAL -- according to RFC 5280
+             }
+            
+ @return +
+ +
+            TimeStampedData ::= SEQUENCE {
+              version              INTEGER { v1(1) },
+              dataUri              IA5String OPTIONAL,
+              metaData             MetaData OPTIONAL,
+              content              OCTET STRING OPTIONAL,
+              temporalEvidence     Evidence
+            }
+            
+ @return +
+ +
+            TimeStampTokenEvidence ::=
+               SEQUENCE SIZE(1..MAX) OF TimeStampAndCrl
+            
+ @return +
+ +
+            AttributeTypeAndValue ::= SEQUENCE {
+                      type         OBJECT IDENTIFIER,
+                      value        ANY DEFINED BY type }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertId ::= SEQUENCE {
+                            issuer           GeneralName,
+                            serialNumber     INTEGER }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertReqMessages ::= SEQUENCE SIZE (1..MAX) OF CertReqMsg
+            
+ @return a basic ASN.1 object representation. +
+ + Creates a new CertReqMsg. + @param certReq CertRequest + @param popo may be null + @param regInfo may be null + + +
+            CertReqMsg ::= SEQUENCE {
+                               certReq   CertRequest,
+                               pop       ProofOfPossession  OPTIONAL,
+                               -- content depends upon key type
+                               regInfo   SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue OPTIONAL }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            CertRequest ::= SEQUENCE {
+                                 certReqId     INTEGER,          -- ID for matching request and reply
+                                 certTemplate  CertTemplate,  -- Selected fields of cert to be issued
+                                 controls      Controls OPTIONAL }   -- Attributes affecting issuance
+            
+ @return a basic ASN.1 object representation. +
+ +
+             CertTemplate ::= SEQUENCE {
+                 version      [0] Version               OPTIONAL,
+                 serialNumber [1] INTEGER               OPTIONAL,
+                 signingAlg   [2] AlgorithmIdentifier   OPTIONAL,
+                 issuer       [3] Name                  OPTIONAL,
+                 validity     [4] OptionalValidity      OPTIONAL,
+                 subject      [5] Name                  OPTIONAL,
+                 publicKey    [6] SubjectPublicKeyInfo  OPTIONAL,
+                 issuerUID    [7] UniqueIdentifier      OPTIONAL,
+                 subjectUID   [8] UniqueIdentifier      OPTIONAL,
+                 extensions   [9] Extensions            OPTIONAL }
+            
+ @return a basic ASN.1 object representation. +
+ + Sets the X.509 version. Note: for X509v3, use 2 here. + + + Sets the issuer unique ID (deprecated in X.509v3) + + + Sets the subject unique ID (deprecated in X.509v3) + + +
+             CertTemplate ::= SEQUENCE {
+                 version      [0] Version               OPTIONAL,
+                 serialNumber [1] INTEGER               OPTIONAL,
+                 signingAlg   [2] AlgorithmIdentifier   OPTIONAL,
+                 issuer       [3] Name                  OPTIONAL,
+                 validity     [4] OptionalValidity      OPTIONAL,
+                 subject      [5] Name                  OPTIONAL,
+                 publicKey    [6] SubjectPublicKeyInfo  OPTIONAL,
+                 issuerUID    [7] UniqueIdentifier      OPTIONAL,
+                 subjectUID   [8] UniqueIdentifier      OPTIONAL,
+                 extensions   [9] Extensions            OPTIONAL }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            Controls  ::= SEQUENCE SIZE(1..MAX) OF AttributeTypeAndValue
+            
+ @return a basic ASN.1 object representation. +
+ +
+            EncKeyWithID ::= SEQUENCE {
+                 privateKey           PrivateKeyInfo,
+                 identifier CHOICE {
+                    string               UTF8String,
+                    generalName          GeneralName
+                } OPTIONAL
+            }
+            
+ @return +
+ +
+               EncryptedKey ::= CHOICE {
+                   encryptedValue        EncryptedValue, -- deprecated
+                   envelopedData     [0] EnvelopedData }
+                   -- The encrypted private key MUST be placed in the envelopedData
+                   -- encryptedContentInfo encryptedContent OCTET STRING.
+            
+
+ +
+            EncryptedValue ::= SEQUENCE {
+                                intendedAlg   [0] AlgorithmIdentifier  OPTIONAL,
+                                -- the intended algorithm for which the value will be used
+                                symmAlg       [1] AlgorithmIdentifier  OPTIONAL,
+                                -- the symmetric algorithm used to encrypt the value
+                                encSymmKey    [2] BIT STRING           OPTIONAL,
+                                -- the (encrypted) symmetric key used to encrypt the value
+                                keyAlg        [3] AlgorithmIdentifier  OPTIONAL,
+                                -- algorithm used to encrypt the symmetric key
+                                valueHint     [4] OCTET STRING         OPTIONAL,
+                                -- a brief description or identifier of the encValue content
+                                -- (may be meaningful only to the sending entity, and used only
+                                -- if EncryptedValue might be re-examined by the sending entity
+                                -- in the future)
+                                encValue       BIT STRING }
+                                -- the encrypted value itself
+            
+ @return a basic ASN.1 object representation. +
+ +
+            OptionalValidity ::= SEQUENCE {
+                                   notBefore  [0] Time OPTIONAL,
+                                   notAfter   [1] Time OPTIONAL } --at least one MUST be present
+            
+ @return a basic ASN.1 object representation. +
+ +
+             PkiArchiveOptions ::= CHOICE {
+                 encryptedPrivKey     [0] EncryptedKey,
+                 -- the actual value of the private key
+                 keyGenParameters     [1] KeyGenParameters,
+                 -- parameters which allow the private key to be re-generated
+                 archiveRemGenPrivKey [2] BOOLEAN }
+                 -- set to TRUE if sender wishes receiver to archive the private
+                 -- key of a key pair that the receiver generates in response to
+                 -- this request; set to FALSE if no archival is desired.
+            
+
+ +
+            PkiPublicationInfo ::= SEQUENCE {
+                             action     INTEGER {
+                                            dontPublish (0),
+                                            pleasePublish (1) },
+                             pubInfos  SEQUENCE SIZE (1..MAX) OF SinglePubInfo OPTIONAL }
+            -- pubInfos MUST NOT be present if action is "dontPublish"
+            -- (if action is "pleasePublish" and pubInfos is omitted,
+            -- "dontCare" is assumed)
+            
+ @return a basic ASN.1 object representation. +
+ + Password-based MAC value for use with POPOSigningKeyInput. + + + Creates a new PKMACValue. + @param params parameters for password-based MAC + @param value MAC of the DER-encoded SubjectPublicKeyInfo + + + Creates a new PKMACValue. + @param aid CMPObjectIdentifiers.passwordBasedMAC, with PBMParameter + @param value MAC of the DER-encoded SubjectPublicKeyInfo + + +
+            PKMACValue ::= SEQUENCE {
+                 algId  AlgorithmIdentifier,
+                 -- algorithm value shall be PasswordBasedMac 1.2.840.113533.7.66.13
+                 -- parameter value is PBMParameter
+                 value  BIT STRING }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            PopoPrivKey ::= CHOICE {
+                   thisMessage       [0] BIT STRING,         -- Deprecated
+                    -- possession is proven in this message (which contains the private
+                    -- key itself (encrypted for the CA))
+                   subsequentMessage [1] SubsequentMessage,
+                    -- possession will be proven in a subsequent message
+                   dhMAC             [2] BIT STRING,         -- Deprecated
+                   agreeMAC          [3] PKMACValue,
+                   encryptedKey      [4] EnvelopedData }
+            
+
+ + Creates a new Proof of Possession object for a signing key. + @param poposkIn the PopoSigningKeyInput structure, or null if the + CertTemplate includes both subject and publicKey values. + @param aid the AlgorithmIdentifier used to sign the proof of possession. + @param signature a signature over the DER-encoded value of poposkIn, + or the DER-encoded value of certReq if poposkIn is null. + + +
+            PopoSigningKey ::= SEQUENCE {
+                                 poposkInput           [0] PopoSigningKeyInput OPTIONAL,
+                                 algorithmIdentifier   AlgorithmIdentifier,
+                                 signature             BIT STRING }
+             -- The signature (using "algorithmIdentifier") is on the
+             -- DER-encoded value of poposkInput.  NOTE: If the CertReqMsg
+             -- certReq CertTemplate contains the subject and publicKey values,
+             -- then poposkInput MUST be omitted and the signature MUST be
+             -- computed on the DER-encoded value of CertReqMsg certReq.  If
+             -- the CertReqMsg certReq CertTemplate does not contain the public
+             -- key and subject values, then poposkInput MUST be present and
+             -- MUST be signed.  This strategy ensures that the public key is
+             -- not present in both the poposkInput and CertReqMsg certReq
+             -- CertTemplate fields.
+            
+ @return a basic ASN.1 object representation. +
+ + Creates a new PopoSigningKeyInput with sender name as authInfo. + + + Creates a new PopoSigningKeyInput using password-based MAC. + + + Returns the sender field, or null if authInfo is publicKeyMac + + + Returns the publicKeyMac field, or null if authInfo is sender + + +
+            PopoSigningKeyInput ::= SEQUENCE {
+                   authInfo             CHOICE {
+                                            sender              [0] GeneralName,
+                                            -- used only if an authenticated identity has been
+                                            -- established for the sender (e.g., a DN from a
+                                            -- previously-issued and currently-valid certificate
+                                            publicKeyMac        PKMacValue },
+                                            -- used if no authenticated GeneralName currently exists for
+                                            -- the sender; publicKeyMac contains a password-based MAC
+                                            -- on the DER-encoded value of publicKey
+                   publicKey           SubjectPublicKeyInfo }  -- from CertTemplate
+            
+ @return a basic ASN.1 object representation. +
+ + Creates a ProofOfPossession with type raVerified. + + + Creates a ProofOfPossession for a signing key. + + + Creates a ProofOfPossession for key encipherment or agreement. + @param type one of TYPE_KEY_ENCIPHERMENT or TYPE_KEY_AGREEMENT + + +
+            ProofOfPossession ::= CHOICE {
+                                      raVerified        [0] NULL,
+                                      -- used if the RA has already verified that the requester is in
+                                      -- possession of the private key
+                                      signature         [1] PopoSigningKey,
+                                      keyEncipherment   [2] PopoPrivKey,
+                                      keyAgreement      [3] PopoPrivKey }
+            
+ @return a basic ASN.1 object representation. +
+ +
+            SinglePubInfo ::= SEQUENCE {
+                   pubMethod    INTEGER {
+                      dontCare    (0),
+                      x500        (1),
+                      web         (2),
+                      ldap        (3) },
+                  pubLocation  GeneralName OPTIONAL }
+            
+ @return a basic ASN.1 object representation. +
+ + table of the available named parameters for GOST 3410-2001. + + + return the ECDomainParameters object for the given OID, null if it + isn't present. + + @param oid an object identifier representing a named parameters, if present. + + + returns an enumeration containing the name strings for curves + contained in this structure. + + + return the named curve name represented by the given object identifier. + + +
+             Gost28147-89-Parameters ::=
+                           SEQUENCE {
+                                   iv                   Gost28147-89-IV,
+                                   encryptionParamSet   OBJECT IDENTIFIER
+                            }
+            
+               Gost28147-89-IV ::= OCTET STRING (SIZE (8))
+             
+
+ + table of the available named parameters for GOST 3410-94. + + + return the GOST3410ParamSetParameters object for the given OID, null if it + isn't present. + + @param oid an object identifier representing a named parameters, if present. + + + returns an enumeration containing the name strings for parameters + contained in this structure. + + + Base class for an application specific object + + + Return the enclosed object assuming explicit tagging. + + @return the resulting object + @throws IOException if reconstruction fails. + + + Return the enclosed object assuming implicit tagging. + + @param derTagNo the type tag that should be applied to the object's contents. + @return the resulting object + @throws IOException if reconstruction fails. + + + return the correct number of pad bits for a bit string defined in + a 32 bit constant + + + return the correct number of bytes for a bit string defined in + a 32 bit constant + + + return a Bit string from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return a Bit string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + @param data the octets making up the bit string. + @param padBits the number of extra bits at the end of the string. + + + @return the value of the bit string as an int (truncating if necessary) + + + Der BMPString object. + + + return a BMP string from the given object. + + @param obj the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + return a BMP string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - byte encoded string. + + + basic constructor + + + return a bool from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return a DerBoolean from the passed in bool. + + + return a Boolean from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + return an integer from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return an Enumerated from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + Class representing the DER-type External + + + Creates a new instance of DerExternal + See X.690 for more informations about the meaning of these parameters + @param directReference The direct reference or null if not set. + @param indirectReference The indirect reference or null if not set. + @param dataValueDescriptor The data value descriptor or null if not set. + @param externalData The external data in its encoded form. + + + Creates a new instance of DerExternal. + See X.690 for more informations about the meaning of these parameters + @param directReference The direct reference or null if not set. + @param indirectReference The indirect reference or null if not set. + @param dataValueDescriptor The data value descriptor or null if not set. + @param encoding The encoding to be used for the external data + @param externalData The external data + + + The encoding of the content. Valid values are +
    +
  • 0 single-ASN1-type
  • +
  • 1 OCTET STRING
  • +
  • 2 BIT STRING
  • +
+
+ + Generalized time object. + + + return a generalized time from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return a Generalized Time object from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + The correct format for this is YYYYMMDDHHMMSS[.f]Z, or without the Z + for local time, or Z+-HHMM on the end, for difference between local + time and UTC time. The fractional second amount f must consist of at + least one number with trailing zeroes removed. + + @param time the time string. + @exception ArgumentException if string is an illegal format. + + + base constructor from a local time object + + + Return the time. + @return The time string as it appeared in the encoded object. + + + return the time - always in the form of + YYYYMMDDhhmmssGMT(+hh:mm|-hh:mm). +

+ Normally in a certificate we would expect "Z" rather than "GMT", + however adding the "GMT" means we can just use: +

+                dateF = new SimpleDateFormat("yyyyMMddHHmmssz");
+            
+ To read in the time and Get a date which is compatible with our local + time zone.

+
+ + Der IA5String object - this is an ascii string. + + + return a IA5 string from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return an IA5 string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - with bytes. + + + basic constructor - without validation. + + + Constructor with optional validation. + + @param string the base string to wrap. + @param validate whether or not to check the string. + @throws ArgumentException if validate is true and the string + contains characters that should not be in an IA5String. + + + return true if the passed in String can be represented without + loss as an IA5String, false otherwise. + + @return true if in printable set, false otherwise. + + + return an integer from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return an Integer from a tagged object. + + @param obj the tagged object holding the object we want + @param isExplicit true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + in some cases positive values Get crammed into a space, + that's not quite big enough... + + + A Null object. + + + Der NumericString object - this is an ascii string of characters {0,1,2,3,4,5,6,7,8,9, }. + + + return a Numeric string from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return an Numeric string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - with bytes. + + + basic constructor - without validation.. + + + Constructor with optional validation. + + @param string the base string to wrap. + @param validate whether or not to check the string. + @throws ArgumentException if validate is true and the string + contains characters that should not be in a NumericString. + + + Return true if the string can be represented as a NumericString ('0'..'9', ' ') + + @param str string to validate. + @return true if numeric, fale otherwise. + + + return an Oid from the passed in object + + @exception ArgumentException if the object cannot be converted. + + + return an object Identifier from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + Return true if this oid is an extension of the passed in branch, stem. + @param stem the arc or branch that is a possible parent. + @return true if the branch is on the passed in stem, false otherwise. + + + The octets making up the octet string. + + + Der PrintableString object. + + + return a printable string from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return a Printable string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - byte encoded string. + + + basic constructor - this does not validate the string + + + Constructor with optional validation. + + @param string the base string to wrap. + @param validate whether or not to check the string. + @throws ArgumentException if validate is true and the string + contains characters that should not be in a PrintableString. + + + return true if the passed in String can be represented without + loss as a PrintableString, false otherwise. + + @return true if in printable set, false otherwise. + + + create an empty sequence + + + create a sequence containing one object + + + create a sequence containing a vector of objects. + + + A Der encoded set object + + + create an empty set + + + @param obj - a single object that makes up the set. + + + @param v - a vector of objects making up the set. + + + Der T61String (also the teletex string) - 8-bit characters + + + return a T61 string from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return an T61 string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - with bytes. + + + basic constructor - with string. + + + DER TaggedObject - in ASN.1 notation this is any object preceded by + a [n] where n is some number - these are assumed to follow the construction + rules (as with sequences). + + + @param tagNo the tag number for this object. + @param obj the tagged object. + + + @param explicitly true if an explicitly tagged object. + @param tagNo the tag number for this object. + @param obj the tagged object. + + + create an implicitly tagged object that contains a zero + length sequence. + + + Der UniversalString object. + + + return a Universal string from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return a Universal string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - byte encoded string. + + + We insert one of these when we find a tag we don't recognise. + + + @param tag the tag value. + @param data the contents octets. + + + UTC time object. + + + return an UTC Time from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return an UTC Time from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + The correct format for this is YYMMDDHHMMSSZ (it used to be that seconds were + never encoded. When you're creating one of these objects from scratch, that's + what you want to use, otherwise we'll try to deal with whatever Gets read from + the input stream... (this is why the input format is different from the GetTime() + method output). +

+ @param time the time string.

+
+ + base constructor from a DateTime object + + + return the time as a date based on whatever a 2 digit year will return. For + standardised processing use ToAdjustedDateTime(). + + @return the resulting date + @exception ParseException if the date string cannot be parsed. + + + return the time as an adjusted date + in the range of 1950 - 2049. + + @return a date in the range of 1950 to 2049. + @exception ParseException if the date string cannot be parsed. + + + return the time - always in the form of + YYMMDDhhmmssGMT(+hh:mm|-hh:mm). +

+ Normally in a certificate we would expect "Z" rather than "GMT", + however adding the "GMT" means we can just use: +

+                dateF = new SimpleDateFormat("yyMMddHHmmssz");
+            
+ To read in the time and Get a date which is compatible with our local + time zone.

+

+ Note: In some cases, due to the local date processing, this + may lead to unexpected results. If you want to stick the normal + convention of 1950 to 2049 use the GetAdjustedTime() method.

+
+ + + Return a time string as an adjusted date with a 4 digit year. + This goes in the range of 1950 - 2049. + + + + Der UTF8String object. + + + return an UTF8 string from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return an UTF8 string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - byte encoded string. + + + basic constructor + + + Der VisibleString object. + + + return a Visible string from the passed in object. + + @exception ArgumentException if the object cannot be converted. + + + return a Visible string from a tagged object. + + @param obj the tagged object holding the object we want + @param explicitly true if the object is meant to be explicitly + tagged false otherwise. + @exception ArgumentException if the tagged object cannot + be converted. + + + basic constructor - byte encoded string. + + + basic constructor + + + + RFC 3126: 4.3.1 Certificate Values Attribute Definition + + CertificateValues ::= SEQUENCE OF Certificate + + + + +
+            CommitmentTypeIndication ::= SEQUENCE {
+                 commitmentTypeId   CommitmentTypeIdentifier,
+                 commitmentTypeQualifier   SEQUENCE SIZE (1..MAX) OF
+                         CommitmentTypeQualifier OPTIONAL }
+            
+
+ + Commitment type qualifiers, used in the Commitment-Type-Indication attribute (RFC3126). + +
+               CommitmentTypeQualifier ::= SEQUENCE {
+                   commitmentTypeIdentifier  CommitmentTypeIdentifier,
+                   qualifier          ANY DEFINED BY commitmentTypeIdentifier OPTIONAL }
+             
+
+ + Creates a new CommitmentTypeQualifier instance. + + @param commitmentTypeIdentifier a CommitmentTypeIdentifier value + + + Creates a new CommitmentTypeQualifier instance. + + @param commitmentTypeIdentifier a CommitmentTypeIdentifier value + @param qualifier the qualifier, defined by the above field. + + + Creates a new CommitmentTypeQualifier instance. + + @param as CommitmentTypeQualifier structure + encoded as an Asn1Sequence. + + + Returns a DER-encodable representation of this instance. + + @return a Asn1Object value + + + + RFC 3126: 4.2.1 Complete Certificate Refs Attribute Definition + + CompleteCertificateRefs ::= SEQUENCE OF OtherCertID + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + CompleteRevocationRefs ::= SEQUENCE OF CrlOcspRef + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + CrlIdentifier ::= SEQUENCE + { + crlissuer Name, + crlIssuedTime UTCTime, + crlNumber INTEGER OPTIONAL + } + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + CRLListID ::= SEQUENCE + { + crls SEQUENCE OF CrlValidatedID + } + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + CrlOcspRef ::= SEQUENCE { + crlids [0] CRLListID OPTIONAL, + ocspids [1] OcspListID OPTIONAL, + otherRev [2] OtherRevRefs OPTIONAL + } + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + CrlValidatedID ::= SEQUENCE { + crlHash OtherHash, + crlIdentifier CrlIdentifier OPTIONAL} + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + OcspIdentifier ::= SEQUENCE { + ocspResponderID ResponderID, + -- As in OCSP response data + producedAt GeneralizedTime + -- As in OCSP response data + } + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + OcspListID ::= SEQUENCE { + ocspResponses SEQUENCE OF OcspResponsesID + } + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + OcspResponsesID ::= SEQUENCE { + ocspIdentifier OcspIdentifier, + ocspRepHash OtherHash OPTIONAL + } + + + + + + + OtherCertID ::= SEQUENCE { + otherCertHash OtherHash, + issuerSerial IssuerSerial OPTIONAL + } + + + + + + + OtherHash ::= CHOICE { + sha1Hash OtherHashValue, -- This contains a SHA-1 hash + otherHash OtherHashAlgAndValue + } + + OtherHashValue ::= OCTET STRING + + + + + + Summary description for OtherHashAlgAndValue. + + + + OtherHashAlgAndValue ::= SEQUENCE { + hashAlgorithm AlgorithmIdentifier, + hashValue OtherHashValue + } + + OtherHashValue ::= OCTET STRING + + + + + + RFC 3126: 4.2.2 Complete Revocation Refs Attribute Definition + + OtherRevRefs ::= SEQUENCE + { + otherRevRefType OtherRevRefType, + otherRevRefs ANY DEFINED BY otherRevRefType + } + + OtherRevRefType ::= OBJECT IDENTIFIER + + + + + + RFC 3126: 4.3.2 Revocation Values Attribute Definition + + OtherRevVals ::= SEQUENCE + { + otherRevValType OtherRevValType, + otherRevVals ANY DEFINED BY otherRevValType + } + + OtherRevValType ::= OBJECT IDENTIFIER + + + + + + + OtherSigningCertificate ::= SEQUENCE { + certs SEQUENCE OF OtherCertID, + policies SEQUENCE OF PolicyInformation OPTIONAL + } + + + + + + RFC 5126: 6.3.4. revocation-values Attribute Definition + + RevocationValues ::= SEQUENCE { + crlVals [0] SEQUENCE OF CertificateList OPTIONAL, + ocspVals [1] SEQUENCE OF BasicOCSPResponse OPTIONAL, + otherRevVals [2] OtherRevVals OPTIONAL + } + + + + + + + SignaturePolicyId ::= SEQUENCE { + sigPolicyIdentifier SigPolicyId, + sigPolicyHash SigPolicyHash, + sigPolicyQualifiers SEQUENCE SIZE (1..MAX) OF SigPolicyQualifierInfo OPTIONAL + } + + SigPolicyId ::= OBJECT IDENTIFIER + + SigPolicyHash ::= OtherHashAlgAndValue + + + + + + + SignaturePolicyIdentifier ::= CHOICE { + SignaturePolicyId SignaturePolicyId, + SignaturePolicyImplied SignaturePolicyImplied + } + + SignaturePolicyImplied ::= NULL + + + + + +
+              SignerAttribute ::= SEQUENCE OF CHOICE {
+                  claimedAttributes   [0] ClaimedAttributes,
+                  certifiedAttributes [1] CertifiedAttributes }
+            
+              ClaimedAttributes ::= SEQUENCE OF Attribute
+              CertifiedAttributes ::= AttributeCertificate -- as defined in RFC 3281: see clause 4.1.
+             
+
+ + Signer-Location attribute (RFC3126). + +
+               SignerLocation ::= SEQUENCE {
+                   countryName        [0] DirectoryString OPTIONAL,
+                   localityName       [1] DirectoryString OPTIONAL,
+                   postalAddress      [2] PostalAddress OPTIONAL }
+            
+               PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+             
+
+ +
+               SignerLocation ::= SEQUENCE {
+                   countryName        [0] DirectoryString OPTIONAL,
+                   localityName       [1] DirectoryString OPTIONAL,
+                   postalAddress      [2] PostalAddress OPTIONAL }
+            
+               PostalAddress ::= SEQUENCE SIZE(1..6) OF DirectoryString
+            
+               DirectoryString ::= CHOICE {
+                     teletexString           TeletexString (SIZE (1..MAX)),
+                     printableString         PrintableString (SIZE (1..MAX)),
+                     universalString         UniversalString (SIZE (1..MAX)),
+                     utf8String              UTF8String (SIZE (1.. MAX)),
+                     bmpString               BMPString (SIZE (1..MAX)) }
+             
+
+ + + + SigPolicyQualifierInfo ::= SEQUENCE { + sigPolicyQualifierId SigPolicyQualifierId, + sigQualifier ANY DEFINED BY sigPolicyQualifierId + } + + SigPolicyQualifierId ::= OBJECT IDENTIFIER + + + + + constructor + + +
+            ContentHints ::= SEQUENCE {
+              contentDescription UTF8String (SIZE (1..MAX)) OPTIONAL,
+              contentType ContentType }
+            
+
+ + Create from OCTET STRING whose octets represent the identifier. + + + Create from byte array representing the identifier. + + + The definition of ContentIdentifier is +
+            ContentIdentifier ::=  OCTET STRING
+            
+ id-aa-contentIdentifier OBJECT IDENTIFIER ::= { iso(1) + member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) + smime(16) id-aa(2) 7 } +
+ + constructor + + +
+            EssCertID ::= SEQUENCE {
+                certHash Hash,
+                issuerSerial IssuerSerial OPTIONAL }
+            
+
+ +
+             EssCertIDv2 ::=  SEQUENCE {
+                 hashAlgorithm     AlgorithmIdentifier
+                          DEFAULT {algorithm id-sha256},
+                 certHash          Hash,
+                 issuerSerial      IssuerSerial OPTIONAL
+             }
+            
+             Hash ::= OCTET STRING
+            
+             IssuerSerial ::= SEQUENCE {
+                 issuer         GeneralNames,
+                 serialNumber   CertificateSerialNumber
+             }
+             
+
+ + constructor + + +
+             OtherCertID ::= SEQUENCE {
+                 otherCertHash    OtherHash,
+                 issuerSerial     IssuerSerial OPTIONAL }
+            
+             OtherHash ::= CHOICE {
+                 sha1Hash     OCTET STRING,
+                 otherHash    OtherHashAlgAndValue }
+            
+             OtherHashAlgAndValue ::= SEQUENCE {
+                 hashAlgorithm    AlgorithmIdentifier,
+                 hashValue        OCTET STRING }
+            
+             
+
+ + constructors + + + The definition of OtherSigningCertificate is +
+            OtherSigningCertificate ::=  SEQUENCE {
+                 certs        SEQUENCE OF OtherCertID,
+                 policies     SEQUENCE OF PolicyInformation OPTIONAL
+            }
+            
+ id-aa-ets-otherSigCert OBJECT IDENTIFIER ::= { iso(1) + member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) + smime(16) id-aa(2) 19 } +
+ + constructors + + + The definition of SigningCertificate is +
+            SigningCertificate ::=  SEQUENCE {
+                 certs        SEQUENCE OF EssCertID,
+                 policies     SEQUENCE OF PolicyInformation OPTIONAL
+            }
+            
+ id-aa-signingCertificate OBJECT IDENTIFIER ::= { iso(1) + member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) + smime(16) id-aa(2) 12 } +
+ + The definition of SigningCertificateV2 is +
+            SigningCertificateV2 ::=  SEQUENCE {
+                 certs        SEQUENCE OF EssCertIDv2,
+                 policies     SEQUENCE OF PolicyInformation OPTIONAL
+            }
+            
+ id-aa-signingCertificateV2 OBJECT IDENTIFIER ::= { iso(1) + member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) + smime(16) id-aa(2) 47 } +
+ + Marker interface for CHOICE objects - if you implement this in a roll-your-own + object, any attempt to tag the object implicitly will convert the tag to an + explicit one as the encoding rules require. +

+ If you use this interface your class should also implement the getInstance + pattern which takes a tag object and the tagging mode used. +

+
+ + basic interface for Der string objects. + + + The CscaMasterList object. This object can be wrapped in a + CMSSignedData to be published in LDAP. + +
+             CscaMasterList ::= SEQUENCE {
+               version                CscaMasterListVersion,
+               certList               SET OF Certificate }
+               
+             CscaMasterListVersion :: INTEGER {v0(0)}
+             
+
+ + The DataGroupHash object. +
+             DataGroupHash  ::=  SEQUENCE {
+                  dataGroupNumber         DataGroupNumber,
+                  dataGroupHashValue     OCTET STRING }
+            
+             DataGroupNumber ::= INTEGER {
+                     dataGroup1    (1),
+                     dataGroup1    (2),
+                     dataGroup1    (3),
+                     dataGroup1    (4),
+                     dataGroup1    (5),
+                     dataGroup1    (6),
+                     dataGroup1    (7),
+                     dataGroup1    (8),
+                     dataGroup1    (9),
+                     dataGroup1    (10),
+                     dataGroup1    (11),
+                     dataGroup1    (12),
+                     dataGroup1    (13),
+                     dataGroup1    (14),
+                     dataGroup1    (15),
+                     dataGroup1    (16) }
+            
+             
+
+ + The LDSSecurityObject object (V1.8). +
+             LDSSecurityObject ::= SEQUENCE {
+               version                LDSSecurityObjectVersion,
+               hashAlgorithm          DigestAlgorithmIdentifier,
+               dataGroupHashValues    SEQUENCE SIZE (2..ub-DataGroups) OF DataHashGroup,
+               ldsVersionInfo         LDSVersionInfo OPTIONAL
+                 -- if present, version MUST be v1 }
+            
+             DigestAlgorithmIdentifier ::= AlgorithmIdentifier,
+            
+             LDSSecurityObjectVersion :: INTEGER {V0(0)}
+             
+
+ +
+            LDSVersionInfo ::= SEQUENCE {
+               ldsVersion PRINTABLE STRING
+               unicodeVersion PRINTABLE STRING
+             }
+            
+ @return +
+ + The id-isismtt-cp-accredited OID indicates that the certificate is a + qualified certificate according to Directive 1999/93/EC of the European + Parliament and of the Council of 13 December 1999 on a Community + Framework for Electronic Signatures, which additionally conforms the + special requirements of the SigG and has been issued by an accredited CA. + + + Certificate extensionDate of certificate generation + +
+            		DateOfCertGenSyntax ::= GeneralizedTime
+             
+
+ + Attribute to indicate that the certificate holder may sign in the name of + a third person. May also be used as extension in a certificate. + + + Attribute to indicate admissions to certain professions. May be used as + attribute in attribute certificate or as extension in a certificate + + + Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST + be used in new certificates in place of the extension/attribute + MonetaryLimit since January 1, 2004. For the sake of backward + compatibility with certificates already in use, SigG conforming + components MUST support MonetaryLimit (as well as QcEuLimitValue). + + + A declaration of majority. May be used as attribute in attribute + certificate or as extension in a certificate + + + + Serial number of the smart card containing the corresponding private key + +
+            		ICCSNSyntax ::= OCTET STRING (SIZE(8..20))
+             
+
+ + + Reference for a file of a smartcard that stores the public key of this + certificate and that is used as �security anchor�. + +
+            		PKReferenceSyntax ::= OCTET STRING (SIZE(20))
+             
+
+ + Some other restriction regarding the usage of this certificate. May be + used as attribute in attribute certificate or as extension in a + certificate. + +
+            		RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+             
+ + @see Org.BouncyCastle.Asn1.IsisMtt.X509.Restriction +
+ + + (Single)Request extension: Clients may include this extension in a + (single) Request to request the responder to send the certificate in the + response message along with the status information. Besides the LDAP + service, this extension provides another mechanism for the distribution + of certificates, which MAY optionally be provided by certificate + repositories. + +
+            		RetrieveIfAllowed ::= BOOLEAN
+             
+
+ + SingleOCSPResponse extension: The certificate requested by the client by + inserting the RetrieveIfAllowed extension in the request, will be + returned in this extension. + + @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.RequestedCertificate + + + Base ObjectIdentifier for naming authorities + + + SingleOCSPResponse extension: Date, when certificate has been published + in the directory and status information has become available. Currently, + accrediting authorities enforce that SigG-conforming OCSP servers include + this extension in the responses. + +
+            		CertInDirSince ::= GeneralizedTime
+             
+
+ + Hash of a certificate in OCSP. + + @see Org.BouncyCastle.Asn1.IsisMtt.Ocsp.CertHash + + +
+            		NameAtBirth ::= DirectoryString(SIZE(1..64)
+             
+ + Used in + {@link Org.BouncyCastle.Asn1.X509.SubjectDirectoryAttributes SubjectDirectoryAttributes} +
+ + Some other information of non-restrictive nature regarding the usage of + this certificate. May be used as attribute in atribute certificate or as + extension in a certificate. + +
+                          AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+            
+ + @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdditionalInformationSyntax +
+ + Indicates that an attribute certificate exists, which limits the + usability of this public key certificate. Whenever verifying a signature + with the help of this certificate, the content of the corresponding + attribute certificate should be concerned. This extension MUST be + included in a PKC, if a corresponding attribute certificate (having the + PKC as base certificate) contains some attribute that restricts the + usability of the PKC too. Attribute certificates with restricting content + MUST always be included in the signed document. + +
+            		LiabilityLimitationFlagSyntax ::= BOOLEAN
+             
+
+ + ISIS-MTT PROFILE: The responder may include this extension in a response to + send the hash of the requested certificate to the responder. This hash is + cryptographically bound to the certificate and serves as evidence that the + certificate is known to the responder (i.e. it has been issued and is present + in the directory). Hence, this extension is a means to provide a positive + statement of availability as described in T8.[8]. As explained in T13.[1], + clients may rely on this information to be able to validate signatures after + the expiry of the corresponding certificate. Hence, clients MUST support this + extension. If a positive statement of availability is to be delivered, this + extension syntax and OID MUST be used. +

+

+

+                CertHash ::= SEQUENCE {
+                  hashAlgorithm AlgorithmIdentifier,
+                  certificateHash OCTET STRING
+                }
+            
+
+ + Constructor from Asn1Sequence. +

+ The sequence is of type CertHash: +

+

+                 CertHash ::= SEQUENCE {
+                   hashAlgorithm AlgorithmIdentifier,
+                   certificateHash OCTET STRING
+                 }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. + + @param hashAlgorithm The hash algorithm identifier. + @param certificateHash The hash of the whole DER encoding of the certificate. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                 CertHash ::= SEQUENCE {
+                   hashAlgorithm AlgorithmIdentifier,
+                   certificateHash OCTET STRING
+                 }
+             
+ + @return an Asn1Object +
+ + ISIS-MTT-Optional: The certificate requested by the client by inserting the + RetrieveIfAllowed extension in the request, will be returned in this + extension. +

+ ISIS-MTT-SigG: The signature act allows publishing certificates only then, + when the certificate owner gives his isExplicit permission. Accordingly, there + may be �nondownloadable� certificates, about which the responder must provide + status information, but MUST NOT include them in the response. Clients may + get therefore the following three kind of answers on a single request + including the RetrieveIfAllowed extension: +

    +
  • a) the responder supports the extension and is allowed to publish the + certificate: RequestedCertificate returned including the requested + certificate
  • +
  • b) the responder supports the extension but is NOT allowed to publish + the certificate: RequestedCertificate returned including an empty OCTET + STRING
  • +
  • c) the responder does not support the extension: RequestedCertificate is + not included in the response
  • +
+ Clients requesting RetrieveIfAllowed MUST be able to handle these cases. If + any of the OCTET STRING options is used, it MUST contain the DER encoding of + the requested certificate. +

+

+                       RequestedCertificate ::= CHOICE {
+                         Certificate Certificate,
+                         publicKeyCertificate [0] EXPLICIT OCTET STRING,
+                         attributeCertificate [1] EXPLICIT OCTET STRING
+                       }
+            
+
+ + Constructor from a given details. +

+ Only one parameter can be given. All other must be null. + + @param certificate Given as Certificate + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                        RequestedCertificate ::= CHOICE {
+                          Certificate Certificate,
+                          publicKeyCertificate [0] EXPLICIT OCTET STRING,
+                          attributeCertificate [1] EXPLICIT OCTET STRING
+                        }
+             
+ + @return an Asn1Object +
+ + Some other information of non-restrictive nature regarding the usage of this + certificate. + +
+               AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+            
+
+ + Constructor from a given details. + + @param information The describtion of the information. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+               AdditionalInformationSyntax ::= DirectoryString (SIZE(1..2048))
+             
+ + @return an Asn1Object +
+ + An Admissions structure. +

+

+                        Admissions ::= SEQUENCE
+                        {
+                          admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+                          namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+                          professionInfos SEQUENCE OF ProfessionInfo
+                        }
+             

+

+ + @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax + @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo + @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority +
+ + Constructor from Asn1Sequence. +

+ The sequence is of type ProcurationSyntax: +

+

+                        Admissions ::= SEQUENCE
+                        {
+                          admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+                          namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+                          professionInfos SEQUENCE OF ProfessionInfo
+                        }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. +

+ Parameter professionInfos is mandatory. + + @param admissionAuthority The admission authority. + @param namingAuthority The naming authority. + @param professionInfos The profession infos. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                   Admissions ::= SEQUENCE
+                   {
+                     admissionAuthority [0] EXPLICIT GeneralName OPTIONAL
+                     namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL
+                     professionInfos SEQUENCE OF ProfessionInfo
+                   }
+             

+

+ + @return an Asn1Object +
+ + Attribute to indicate admissions to certain professions. +

+

+                 AdmissionSyntax ::= SEQUENCE
+                 {
+                   admissionAuthority GeneralName OPTIONAL,
+                   contentsOfAdmissions SEQUENCE OF Admissions
+                 }
+             

+ Admissions ::= SEQUENCE + { + admissionAuthority [0] EXPLICIT GeneralName OPTIONAL + namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL + professionInfos SEQUENCE OF ProfessionInfo + } +

+ NamingAuthority ::= SEQUENCE + { + namingAuthorityId OBJECT IDENTIFIER OPTIONAL, + namingAuthorityUrl IA5String OPTIONAL, + namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL + } +

+ ProfessionInfo ::= SEQUENCE + { + namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL, + professionItems SEQUENCE OF DirectoryString (SIZE(1..128)), + professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL, + registrationNumber PrintableString(SIZE(1..128)) OPTIONAL, + addProfessionInfo OCTET STRING OPTIONAL + } +

+

+

+ ISIS-MTT PROFILE: The relatively complex structure of AdmissionSyntax + supports the following concepts and requirements: +

    +
  • External institutions (e.g. professional associations, chambers, unions, + administrative bodies, companies, etc.), which are responsible for granting + and verifying professional admissions, are indicated by means of the data + field admissionAuthority. An admission authority is indicated by a + GeneralName object. Here an X.501 directory name (distinguished name) can be + indicated in the field directoryName, a URL address can be indicated in the + field uniformResourceIdentifier, and an object identifier can be indicated in + the field registeredId.
  • +
  • The names of authorities which are responsible for the administration of + title registers are indicated in the data field namingAuthority. The name of + the authority can be identified by an object identifier in the field + namingAuthorityId, by means of a text string in the field + namingAuthorityText, by means of a URL address in the field + namingAuthorityUrl, or by a combination of them. For example, the text string + can contain the name of the authority, the country and the name of the title + register. The URL-option refers to a web page which contains lists with + �officially� registered professions (text and possibly OID) as well as + further information on these professions. Object identifiers for the + component namingAuthorityId are grouped under the OID-branch + id-isis-at-namingAuthorities and must be applied for.
  • +
  • See http://www.teletrust.de/anwend.asp?Id=30200&Sprache=E_&HomePG=0 + for an application form and http://www.teletrust.de/links.asp?id=30220,11 + for an overview of registered naming authorities.
  • +
  • By means of the data type ProfessionInfo certain professions, + specializations, disciplines, fields of activity, etc. are identified. A + profession is represented by one or more text strings, resp. profession OIDs + in the fields professionItems and professionOIDs and by a registration number + in the field registrationNumber. An indication in text form must always be + present, whereas the other indications are optional. The component + addProfessionInfo may contain additional applicationspecific information in + DER-encoded form.
  • +
+

+ By means of different namingAuthority-OIDs or profession OIDs hierarchies of + professions, specializations, disciplines, fields of activity, etc. can be + expressed. The issuing admission authority should always be indicated (field + admissionAuthority), whenever a registration number is presented. Still, + information on admissions can be given without indicating an admission or a + naming authority by the exclusive use of the component professionItems. In + this case the certification authority is responsible for the verification of + the admission information. +

+

+

+ This attribute is single-valued. Still, several admissions can be captured in + the sequence structure of the component contentsOfAdmissions of + AdmissionSyntax or in the component professionInfos of Admissions. The + component admissionAuthority of AdmissionSyntax serves as default value for + the component admissionAuthority of Admissions. Within the latter component + the default value can be overwritten, in case that another authority is + responsible. The component namingAuthority of Admissions serves as a default + value for the component namingAuthority of ProfessionInfo. Within the latter + component the default value can be overwritten, in case that another naming + authority needs to be recorded. +

+ The length of the string objects is limited to 128 characters. It is + recommended to indicate a namingAuthorityURL in all issued attribute + certificates. If a namingAuthorityURL is indicated, the field professionItems + of ProfessionInfo should contain only registered titles. If the field + professionOIDs exists, it has to contain the OIDs of the professions listed + in professionItems in the same order. In general, the field professionInfos + should contain only one entry, unless the admissions that are to be listed + are logically connected (e.g. they have been issued under the same admission + number). + + @see Org.BouncyCastle.Asn1.IsisMtt.X509.Admissions + @see Org.BouncyCastle.Asn1.IsisMtt.X509.ProfessionInfo + @see Org.BouncyCastle.Asn1.IsisMtt.X509.NamingAuthority + + + Constructor from Asn1Sequence. +

+ The sequence is of type ProcurationSyntax: +

+

+                 AdmissionSyntax ::= SEQUENCE
+                 {
+                   admissionAuthority GeneralName OPTIONAL,
+                   contentsOfAdmissions SEQUENCE OF Admissions
+                 }
+             

+ Admissions ::= SEQUENCE + { + admissionAuthority [0] EXPLICIT GeneralName OPTIONAL + namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL + professionInfos SEQUENCE OF ProfessionInfo + } +

+ NamingAuthority ::= SEQUENCE + { + namingAuthorityId OBJECT IDENTIFIER OPTIONAL, + namingAuthorityUrl IA5String OPTIONAL, + namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL + } +

+ ProfessionInfo ::= SEQUENCE + { + namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL, + professionItems SEQUENCE OF DirectoryString (SIZE(1..128)), + professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL, + registrationNumber PrintableString(SIZE(1..128)) OPTIONAL, + addProfessionInfo OCTET STRING OPTIONAL + } +

+ + @param seq The ASN.1 sequence. +
+ + Constructor from given details. + + @param admissionAuthority The admission authority. + @param contentsOfAdmissions The admissions. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                 AdmissionSyntax ::= SEQUENCE
+                 {
+                   admissionAuthority GeneralName OPTIONAL,
+                   contentsOfAdmissions SEQUENCE OF Admissions
+                 }
+             

+ Admissions ::= SEQUENCE + { + admissionAuthority [0] EXPLICIT GeneralName OPTIONAL + namingAuthority [1] EXPLICIT NamingAuthority OPTIONAL + professionInfos SEQUENCE OF ProfessionInfo + } +

+ NamingAuthority ::= SEQUENCE + { + namingAuthorityId OBJECT IDENTIFIER OPTIONAL, + namingAuthorityUrl IA5String OPTIONAL, + namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL + } +

+ ProfessionInfo ::= SEQUENCE + { + namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL, + professionItems SEQUENCE OF DirectoryString (SIZE(1..128)), + professionOIDs SEQUENCE OF OBJECT IDENTIFIER OPTIONAL, + registrationNumber PrintableString(SIZE(1..128)) OPTIONAL, + addProfessionInfo OCTET STRING OPTIONAL + } +

+ + @return an Asn1Object +
+ + @return Returns the admissionAuthority if present, null otherwise. + + + @return Returns the contentsOfAdmissions. + + + A declaration of majority. +

+

+                      DeclarationOfMajoritySyntax ::= CHOICE
+                      {
+                        notYoungerThan [0] IMPLICIT INTEGER,
+                        fullAgeAtCountry [1] IMPLICIT SEQUENCE
+                        {
+                          fullAge BOOLEAN DEFAULT TRUE,
+                          country PrintableString (SIZE(2))
+                        }
+                        dateOfBirth [2] IMPLICIT GeneralizedTime
+                      }
+            
+

+ fullAgeAtCountry indicates the majority of the owner with respect to the laws + of a specific country. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                       DeclarationOfMajoritySyntax ::= CHOICE
+                       {
+                         notYoungerThan [0] IMPLICIT INTEGER,
+                         fullAgeAtCountry [1] IMPLICIT SEQUENCE
+                         {
+                           fullAge BOOLEAN DEFAULT TRUE,
+                           country PrintableString (SIZE(2))
+                         }
+                         dateOfBirth [2] IMPLICIT GeneralizedTime
+                       }
+             
+ + @return an Asn1Object +
+ + @return notYoungerThan if that's what we are, -1 otherwise + + + Monetary limit for transactions. The QcEuMonetaryLimit QC statement MUST be + used in new certificates in place of the extension/attribute MonetaryLimit + since January 1, 2004. For the sake of backward compatibility with + certificates already in use, components SHOULD support MonetaryLimit (as well + as QcEuLimitValue). +

+ Indicates a monetary limit within which the certificate holder is authorized + to act. (This value DOES NOT express a limit on the liability of the + certification authority). +

+

+               MonetaryLimitSyntax ::= SEQUENCE
+               {
+                 currency PrintableString (SIZE(3)),
+                 amount INTEGER,
+                 exponent INTEGER
+               }
+            
+

+ currency must be the ISO code. +

+ value = amount�10*exponent + + + Constructor from a given details. +

+

+ value = amount�10^exponent + + @param currency The currency. Must be the ISO code. + @param amount The amount + @param exponent The exponent + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                MonetaryLimitSyntax ::= SEQUENCE
+                {
+                  currency PrintableString (SIZE(3)),
+                  amount INTEGER,
+                  exponent INTEGER
+                }
+             
+ + @return an Asn1Object +
+ + Names of authorities which are responsible for the administration of title + registers. + +
+                        NamingAuthority ::= SEQUENCE 
+                        {
+                          namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+                          namingAuthorityUrl IA5String OPTIONAL,
+                          namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+                        }
+            
+ @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax + +
+ + Profession OIDs should always be defined under the OID branch of the + responsible naming authority. At the time of this writing, the work group + �Recht, Wirtschaft, Steuern� (�Law, Economy, Taxes�) is registered as the + first naming authority under the OID id-isismtt-at-namingAuthorities. + + + Constructor from Asn1Sequence. +

+

+

+                         NamingAuthority ::= SEQUENCE
+                         {
+                           namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+                           namingAuthorityUrl IA5String OPTIONAL,
+                           namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+                         }
+             
+ + @param seq The ASN.1 sequence. +
+ + @return Returns the namingAuthorityID. + + + @return Returns the namingAuthorityText. + + + @return Returns the namingAuthorityUrl. + + + Constructor from given details. +

+ All parameters can be combined. + + @param namingAuthorityID ObjectIdentifier for naming authority. + @param namingAuthorityUrl URL for naming authority. + @param namingAuthorityText Textual representation of naming authority. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                         NamingAuthority ::= SEQUENCE
+                         {
+                           namingAuthorityID OBJECT IDENTIFIER OPTIONAL,
+                           namingAuthorityUrl IA5String OPTIONAL,
+                           namingAuthorityText DirectoryString(SIZE(1..128)) OPTIONAL
+                         }
+             
+ + @return an Asn1Object +
+ + Attribute to indicate that the certificate holder may sign in the name of a + third person. +

+ ISIS-MTT PROFILE: The corresponding ProcurationSyntax contains either the + name of the person who is represented (subcomponent thirdPerson) or a + reference to his/her base certificate (in the component signingFor, + subcomponent certRef), furthermore the optional components country and + typeSubstitution to indicate the country whose laws apply, and respectively + the type of procuration (e.g. manager, procuration, custody). +

+

+ ISIS-MTT PROFILE: The GeneralName MUST be of type directoryName and MAY only + contain: - RFC3039 attributes, except pseudonym (countryName, commonName, + surname, givenName, serialNumber, organizationName, organizationalUnitName, + stateOrProvincename, localityName, postalAddress) and - SubjectDirectoryName + attributes (title, dateOfBirth, placeOfBirth, gender, countryOfCitizenship, + countryOfResidence and NameAtBirth). +

+
+                          ProcurationSyntax ::= SEQUENCE {
+                            country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+                            typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+                            signingFor [3] EXPLICIT SigningFor 
+                          }
+                          
+                          SigningFor ::= CHOICE 
+                          { 
+                            thirdPerson GeneralName,
+                            certRef IssuerSerial 
+                          }
+            
+ +
+ + Constructor from Asn1Sequence. +

+ The sequence is of type ProcurationSyntax: +

+

+                           ProcurationSyntax ::= SEQUENCE {
+                             country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+                             typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+                             signingFor [3] EXPLICIT SigningFor
+                           }
+             

+ SigningFor ::= CHOICE + { + thirdPerson GeneralName, + certRef IssuerSerial + } +

+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. +

+

+ Either generalName or certRef MUST be + null. + + @param country The country code whose laws apply. + @param typeOfSubstitution The type of procuration. + @param certRef Reference to certificate of the person who is represented. + + + Constructor from a given details. +

+

+ Either generalName or certRef MUST be + null. + + @param country The country code whose laws apply. + @param typeOfSubstitution The type of procuration. + @param thirdPerson The GeneralName of the person who is represented. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                           ProcurationSyntax ::= SEQUENCE {
+                             country [1] EXPLICIT PrintableString(SIZE(2)) OPTIONAL,
+                             typeOfSubstitution [2] EXPLICIT DirectoryString (SIZE(1..128)) OPTIONAL,
+                             signingFor [3] EXPLICIT SigningFor
+                           }
+             

+ SigningFor ::= CHOICE + { + thirdPerson GeneralName, + certRef IssuerSerial + } +

+ + @return an Asn1Object +
+ + Professions, specializations, disciplines, fields of activity, etc. + +
+                          ProfessionInfo ::= SEQUENCE 
+                          {
+                            namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+                            professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+                            professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+                            registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+                            addProfessionInfo OCTET STRING OPTIONAL 
+                          }
+            
+ + @see Org.BouncyCastle.Asn1.IsisMtt.X509.AdmissionSyntax +
+ + Rechtsanw�ltin + + + Rechtsanwalt + + + Rechtsbeistand + + + Steuerberaterin + + + Steuerberater + + + Steuerbevollm�chtigte + + + Steuerbevollm�chtigter + + + Notarin + + + Notar + + + Notarvertreterin + + + Notarvertreter + + + Notariatsverwalterin + + + Notariatsverwalter + + + Wirtschaftspr�ferin + + + Wirtschaftspr�fer + + + Vereidigte Buchpr�ferin + + + Vereidigter Buchpr�fer + + + Patentanw�ltin + + + Patentanwalt + + + Constructor from Asn1Sequence. +

+

+

+                           ProfessionInfo ::= SEQUENCE
+                           {
+                             namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+                             professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+                             professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+                             registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+                             addProfessionInfo OCTET STRING OPTIONAL
+                           }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from given details. +

+ professionItems is mandatory, all other parameters are + optional. + + @param namingAuthority The naming authority. + @param professionItems Directory strings of the profession. + @param professionOids DERObjectIdentfier objects for the + profession. + @param registrationNumber Registration number. + @param addProfessionInfo Additional infos in encoded form. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                           ProfessionInfo ::= SEQUENCE
+                           {
+                             namingAuthority [0] EXPLICIT NamingAuthority OPTIONAL,
+                             professionItems SEQUENCE OF DirectoryString (SIZE(1..128)),
+                             professionOids SEQUENCE OF OBJECT IDENTIFIER OPTIONAL,
+                             registrationNumber PrintableString(SIZE(1..128)) OPTIONAL,
+                             addProfessionInfo OCTET STRING OPTIONAL
+                           }
+             
+ + @return an Asn1Object +
+ + @return Returns the addProfessionInfo. + + + @return Returns the namingAuthority. + + + @return Returns the professionItems. + + + @return Returns the professionOids. + + + @return Returns the registrationNumber. + + + Some other restriction regarding the usage of this certificate. +

+

+             RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+            
+
+ + Constructor from DirectoryString. +

+ The DirectoryString is of type RestrictionSyntax: +

+

+                  RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+             
+ + @param restriction A IAsn1String. +
+ + Constructor from a given details. + + @param restriction The description of the restriction. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                  RestrictionSyntax ::= DirectoryString (SIZE(1..1024))
+             

+

+ + @return an Asn1Object +
+ + Produce an object suitable for an Asn1OutputStream. +
+            cast5CBCParameters ::= Sequence {
+                                      iv         OCTET STRING DEFAULT 0,
+                                             -- Initialization vector
+                                      keyLength  Integer
+                                             -- Key length, in bits
+                                 }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            IDEA-CBCPar ::= Sequence {
+                                 iv    OCTET STRING OPTIONAL -- exactly 8 octets
+                             }
+            
+
+ + The NetscapeCertType object. +
+               NetscapeCertType ::= BIT STRING {
+                    SSLClient               (0),
+                    SSLServer               (1),
+                    S/MIME                  (2),
+                    Object Signing          (3),
+                    Reserved                (4),
+                    SSL CA                  (5),
+                    S/MIME CA               (6),
+                    Object Signing CA       (7) }
+            
+
+ + Basic constructor. + + @param usage - the bitwise OR of the Key Usage flags giving the + allowed uses for the key. + e.g. (X509NetscapeCertType.sslCA | X509NetscapeCertType.smimeCA) + + + This is designed to parse + the PublicKeyAndChallenge created by the KEYGEN tag included by + Mozilla based browsers. +
+              PublicKeyAndChallenge ::= SEQUENCE {
+                spki SubjectPublicKeyInfo,
+                challenge IA5STRING
+              }
+            
+              
+
+ + Utility class for fetching curves using their NIST names as published in FIPS-PUB 186-2 + + + return the X9ECParameters object for the named curve represented by + the passed in object identifier. Null if the curve isn't present. + + @param oid an object identifier representing a named curve, if present. + + + return the object identifier signified by the passed in name. Null + if there is no object identifier associated with name. + + @return the object identifier associated with name, if present. + + + return the named curve name represented by the given object identifier. + + + returns an enumeration containing the name strings for curves + contained in this structure. + + + From RFC 3657 + + + Produce an object suitable for an Asn1OutputStream. +
+            BasicOcspResponse       ::= Sequence {
+                 tbsResponseData      ResponseData,
+                 signatureAlgorithm   AlgorithmIdentifier,
+                 signature            BIT STRING,
+                 certs                [0] EXPLICIT Sequence OF Certificate OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            CertID          ::=     Sequence {
+                hashAlgorithm       AlgorithmIdentifier,
+                issuerNameHash      OCTET STRING, -- Hash of Issuer's DN
+                issuerKeyHash       OCTET STRING, -- Hash of Issuers public key
+                serialNumber        CertificateSerialNumber }
+            
+
+ + create a CertStatus object with a tag of zero. + + + Produce an object suitable for an Asn1OutputStream. +
+             CertStatus ::= CHOICE {
+                             good        [0]     IMPLICIT Null,
+                             revoked     [1]     IMPLICIT RevokedInfo,
+                             unknown     [2]     IMPLICIT UnknownInfo }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            CrlID ::= Sequence {
+                crlUrl               [0]     EXPLICIT IA5String OPTIONAL,
+                crlNum               [1]     EXPLICIT Integer OPTIONAL,
+                crlTime              [2]     EXPLICIT GeneralizedTime OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            OcspRequest     ::=     Sequence {
+                tbsRequest                  TBSRequest,
+                optionalSignature   [0]     EXPLICIT Signature OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            OcspResponse ::= Sequence {
+                responseStatus         OcspResponseStatus,
+                responseBytes          [0] EXPLICIT ResponseBytes OPTIONAL }
+            
+
+ + The OcspResponseStatus enumeration. +
+            OcspResponseStatus ::= Enumerated {
+                successful            (0),  --Response has valid confirmations
+                malformedRequest      (1),  --Illegal confirmation request
+                internalError         (2),  --Internal error in issuer
+                tryLater              (3),  --Try again later
+                                            --(4) is not used
+                sigRequired           (5),  --Must sign the request
+                unauthorized          (6)   --Request unauthorized
+            }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            Request         ::=     Sequence {
+                reqCert                     CertID,
+                singleRequestExtensions     [0] EXPLICIT Extensions OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ResponderID ::= CHOICE {
+                 byName          [1] Name,
+                 byKey           [2] KeyHash }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ResponseBytes ::=       Sequence {
+                responseType   OBJECT IDENTIFIER,
+                response       OCTET STRING }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ResponseData ::= Sequence {
+                version              [0] EXPLICIT Version DEFAULT v1,
+                responderID              ResponderID,
+                producedAt               GeneralizedTime,
+                responses                Sequence OF SingleResponse,
+                responseExtensions   [1] EXPLICIT Extensions OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            RevokedInfo ::= Sequence {
+                 revocationTime              GeneralizedTime,
+                 revocationReason    [0]     EXPLICIT CRLReason OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ServiceLocator ::= Sequence {
+                issuer    Name,
+                locator   AuthorityInfoAccessSyntax OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            Signature       ::=     Sequence {
+                signatureAlgorithm      AlgorithmIdentifier,
+                signature               BIT STRING,
+                certs               [0] EXPLICIT Sequence OF Certificate OPTIONAL}
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+             SingleResponse ::= Sequence {
+                     certID                       CertID,
+                     certStatus                   CertStatus,
+                     thisUpdate                   GeneralizedTime,
+                     nextUpdate         [0]       EXPLICIT GeneralizedTime OPTIONAL,
+                     singleExtensions   [1]       EXPLICIT Extensions OPTIONAL }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            TBSRequest      ::=     Sequence {
+                version             [0]     EXPLICIT Version DEFAULT v1,
+                requestorName       [1]     EXPLICIT GeneralName OPTIONAL,
+                requestList                 Sequence OF Request,
+                requestExtensions   [2]     EXPLICIT Extensions OPTIONAL }
+            
+
+ + class for breaking up an Oid into it's component tokens, ala + java.util.StringTokenizer. We need this class as some of the + lightweight Java environment don't support classes like + StringTokenizer. + + + return an Attribute object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            Attr ::= Sequence {
+                attrType OBJECT IDENTIFIER,
+                attrValues Set OF AttributeValue
+            }
+            
+
+ + Pkcs10 Certfication request object. +
+            CertificationRequest ::= Sequence {
+              certificationRequestInfo  CertificationRequestInfo,
+              signatureAlgorithm        AlgorithmIdentifier{{ SignatureAlgorithms }},
+              signature                 BIT STRING
+            }
+            
+
+ + Pkcs10 CertificationRequestInfo object. +
+              CertificationRequestInfo ::= Sequence {
+               version             Integer { v1(0) } (v1,...),
+               subject             Name,
+               subjectPKInfo   SubjectPublicKeyInfo{{ PKInfoAlgorithms }},
+               attributes          [0] Attributes{{ CRIAttributes }}
+              }
+            
+              Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }}
+            
+              Attr { ATTRIBUTE:IOSet } ::= Sequence {
+                type    ATTRIBUTE.&id({IOSet}),
+                values  Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type})
+              }
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+            ContentInfo ::= Sequence {
+                     contentType ContentType,
+                     content
+                     [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL }
+            
+
+ + The EncryptedData object. +
+                  EncryptedData ::= Sequence {
+                       version Version,
+                       encryptedContentInfo EncryptedContentInfo
+                  }
+            
+            
+                  EncryptedContentInfo ::= Sequence {
+                      contentType ContentType,
+                      contentEncryptionAlgorithm  ContentEncryptionAlgorithmIdentifier,
+                      encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL
+                }
+            
+                EncryptedContent ::= OCTET STRING
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+             EncryptedPrivateKeyInfo ::= Sequence {
+                  encryptionAlgorithm AlgorithmIdentifier {{KeyEncryptionAlgorithms}},
+                  encryptedData EncryptedData
+             }
+            
+             EncryptedData ::= OCTET STRING
+            
+             KeyEncryptionAlgorithms ALGORITHM-IDENTIFIER ::= {
+                      ... -- For local profiles
+             }
+             
+
+ +
+            MacData ::= SEQUENCE {
+                mac      DigestInfo,
+                macSalt  OCTET STRING,
+                iterations INTEGER DEFAULT 1
+                -- Note: The default is for historic reasons and its use is deprecated. A
+                -- higher value, like 1024 is recommended.
+            
+ @return the basic DERObject construction. +
+ + the infamous Pfx from Pkcs12 + + + write out an RSA private key with its associated information + as described in Pkcs8. +
+                  PrivateKeyInfo ::= Sequence {
+                                          version Version,
+                                          privateKeyAlgorithm AlgorithmIdentifier {{PrivateKeyAlgorithms}},
+                                          privateKey PrivateKey,
+                                          attributes [0] IMPLICIT Attributes OPTIONAL
+                                      }
+                  Version ::= Integer {v1(0)} (v1,...)
+            
+                  PrivateKey ::= OCTET STRING
+            
+                  Attributes ::= Set OF Attr
+             
+
+ + The default version + + +
+              RSAES-OAEP-params ::= SEQUENCE {
+                 hashAlgorithm      [0] OAEP-PSSDigestAlgorithms     DEFAULT sha1,
+                 maskGenAlgorithm   [1] PKCS1MGFAlgorithms  DEFAULT mgf1SHA1,
+                 pSourceAlgorithm   [2] PKCS1PSourceAlgorithms  DEFAULT pSpecifiedEmpty
+               }
+            
+               OAEP-PSSDigestAlgorithms    ALGORITHM-IDENTIFIER ::= {
+                 { OID id-sha1 PARAMETERS NULL   }|
+                 { OID id-sha256 PARAMETERS NULL }|
+                 { OID id-sha384 PARAMETERS NULL }|
+                 { OID id-sha512 PARAMETERS NULL },
+                 ...  -- Allows for future expansion --
+               }
+               PKCS1MGFAlgorithms    ALGORITHM-IDENTIFIER ::= {
+                 { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+                ...  -- Allows for future expansion --
+               }
+               PKCS1PSourceAlgorithms    ALGORITHM-IDENTIFIER ::= {
+                 { OID id-pSpecified PARAMETERS OCTET STRING },
+                 ...  -- Allows for future expansion --
+              }
+             
+ @return the asn1 primitive representing the parameters. +
+ + This outputs the key in Pkcs1v2 format. +
+                  RsaPrivateKey ::= Sequence {
+                                      version Version,
+                                      modulus Integer, -- n
+                                      publicExponent Integer, -- e
+                                      privateExponent Integer, -- d
+                                      prime1 Integer, -- p
+                                      prime2 Integer, -- q
+                                      exponent1 Integer, -- d mod (p-1)
+                                      exponent2 Integer, -- d mod (q-1)
+                                      coefficient Integer -- (inverse of q) mod p
+                                  }
+            
+                  Version ::= Integer
+             
+

This routine is written to output Pkcs1 version 0, private keys.

+
+ + The default version + + +
+             RSASSA-PSS-params ::= SEQUENCE {
+               hashAlgorithm      [0] OAEP-PSSDigestAlgorithms  DEFAULT sha1,
+                maskGenAlgorithm   [1] PKCS1MGFAlgorithms  DEFAULT mgf1SHA1,
+                saltLength         [2] INTEGER  DEFAULT 20,
+                trailerField       [3] TrailerField  DEFAULT trailerFieldBC
+              }
+            
+             OAEP-PSSDigestAlgorithms    ALGORITHM-IDENTIFIER ::= {
+                { OID id-sha1 PARAMETERS NULL   }|
+                { OID id-sha256 PARAMETERS NULL }|
+                { OID id-sha384 PARAMETERS NULL }|
+                { OID id-sha512 PARAMETERS NULL },
+                ...  -- Allows for future expansion --
+             }
+            
+             PKCS1MGFAlgorithms    ALGORITHM-IDENTIFIER ::= {
+               { OID id-mgf1 PARAMETERS OAEP-PSSDigestAlgorithms },
+                ...  -- Allows for future expansion --
+             }
+            
+             TrailerField ::= INTEGER { trailerFieldBC(1) }
+             
+ @return the asn1 primitive representing the parameters. +
+ + a Pkcs#7 signed data object. + + + Produce an object suitable for an Asn1OutputStream. +
+             SignedData ::= Sequence {
+                 version Version,
+                 digestAlgorithms DigestAlgorithmIdentifiers,
+                 contentInfo ContentInfo,
+                 certificates
+                     [0] IMPLICIT ExtendedCertificatesAndCertificates
+                              OPTIONAL,
+                 crls
+                     [1] IMPLICIT CertificateRevocationLists OPTIONAL,
+                 signerInfos SignerInfos }
+            
+
+ + a Pkcs#7 signer info object. + + + Produce an object suitable for an Asn1OutputStream. +
+              SignerInfo ::= Sequence {
+                  version Version,
+                  issuerAndSerialNumber IssuerAndSerialNumber,
+                  digestAlgorithm DigestAlgorithmIdentifier,
+                  authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,
+                  digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,
+                  encryptedDigest EncryptedDigest,
+                  unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL
+              }
+            
+              EncryptedDigest ::= OCTET STRING
+            
+              DigestAlgorithmIdentifier ::= AlgorithmIdentifier
+            
+              DigestEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier
+             
+
+ + the elliptic curve private key object from SEC 1 + + + ECPrivateKey ::= SEQUENCE { + version INTEGER { ecPrivkeyVer1(1) } (ecPrivkeyVer1), + privateKey OCTET STRING, + parameters [0] Parameters OPTIONAL, + publicKey [1] BIT STRING OPTIONAL } + + + return the X9ECParameters object for the named curve represented by + the passed in object identifier. Null if the curve isn't present. + + @param oid an object identifier representing a named curve, if present. + + + return the object identifier signified by the passed in name. Null + if there is no object identifier associated with name. + + @return the object identifier associated with name, if present. + + + return the named curve name represented by the given object identifier. + + + returns an enumeration containing the name strings for curves + contained in this structure. + + + EllipticCurve OBJECT IDENTIFIER ::= { + iso(1) identified-organization(3) certicom(132) curve(0) + } + + + Handler class for dealing with S/MIME Capabilities + + + general preferences + + + encryption algorithms preferences + + + return an Attr object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + returns an ArrayList with 0 or more objects of all the capabilities + matching the passed in capability Oid. If the Oid passed is null the + entire set is returned. + + + Produce an object suitable for an Asn1OutputStream. +
+            SMIMECapabilities ::= Sequence OF SMIMECapability
+            
+
+ + general preferences + + + encryption algorithms preferences + + + Produce an object suitable for an Asn1OutputStream. +
+            SMIMECapability ::= Sequence {
+                capabilityID OBJECT IDENTIFIER,
+                parameters ANY DEFINED BY capabilityID OPTIONAL
+            }
+            
+
+ + Handler for creating a vector S/MIME Capabilities + + + The SmimeEncryptionKeyPreference object. +
+            SmimeEncryptionKeyPreference ::= CHOICE {
+                issuerAndSerialNumber   [0] IssuerAndSerialNumber,
+                receipentKeyId          [1] RecipientKeyIdentifier,
+                subjectAltKeyIdentifier [2] SubjectKeyIdentifier
+            }
+            
+
+ + @param sKeyId the subjectKeyIdentifier value (normally the X.509 one) + + + elliptic curves defined in "ECC Brainpool Standard Curves and Curve Generation" + http://www.ecc-brainpool.org/download/draft_pkix_additional_ecc_dp.txt + + + return the X9ECParameters object for the named curve represented by + the passed in object identifier. Null if the curve isn't present. + + @param oid an object identifier representing a named curve, if present. + + + return the object identifier signified by the passed in name. Null + if there is no object identifier associated with name. + + @return the object identifier associated with name, if present. + + + return the named curve name represented by the given object identifier. + + + returns an enumeration containing the name strings for curves + contained in this structure. + + +
+            Accuracy ::= SEQUENCE {
+                        seconds        INTEGER              OPTIONAL,
+                        millis     [0] INTEGER  (1..999)    OPTIONAL,
+                        micros     [1] INTEGER  (1..999)    OPTIONAL
+                        }
+            
+
+ + @param o + @return a MessageImprint object. + + +
+               MessageImprint ::= SEQUENCE  {
+                  hashAlgorithm                AlgorithmIdentifier,
+                  hashedMessage                OCTET STRING  }
+            
+
+ +
+            TimeStampReq ::= SEQUENCE  {
+             version                      INTEGER  { v1(1) },
+             messageImprint               MessageImprint,
+               --a hash algorithm OID and the hash value of the data to be
+               --time-stamped
+             reqPolicy             TSAPolicyId              OPTIONAL,
+             nonce                 INTEGER                  OPTIONAL,
+             certReq               BOOLEAN                  DEFAULT FALSE,
+             extensions            [0] IMPLICIT Extensions  OPTIONAL
+            }
+            
+
+ +
+            TimeStampResp ::= SEQUENCE  {
+              status                  PkiStatusInfo,
+              timeStampToken          TimeStampToken     OPTIONAL  }
+            
+
+ +
+            
+                 TstInfo ::= SEQUENCE  {
+                    version                      INTEGER  { v1(1) },
+                    policy                       TSAPolicyId,
+                    messageImprint               MessageImprint,
+                      -- MUST have the same value as the similar field in
+                      -- TimeStampReq
+                    serialNumber                 INTEGER,
+                     -- Time-Stamping users MUST be ready to accommodate integers
+                     -- up to 160 bits.
+                    genTime                      GeneralizedTime,
+                    accuracy                     Accuracy                 OPTIONAL,
+                    ordering                     BOOLEAN             DEFAULT FALSE,
+                    nonce                        INTEGER                  OPTIONAL,
+                      -- MUST be present if the similar field was present
+                      -- in TimeStampReq.  In that case it MUST have the same value.
+                    tsa                          [0] GeneralName          OPTIONAL,
+                    extensions                   [1] IMPLICIT Extensions   OPTIONAL  }
+            
+             
+
+ + dump a Der object as a formatted string with indentation + + @param obj the Asn1Object to be dumped out. + + + dump out a DER object as a formatted string, in non-verbose mode + + @param obj the Asn1Encodable to be dumped out. + @return the resulting string. + + + Dump out the object as a string + + @param obj the Asn1Encodable to be dumped out. + @param verbose if true, dump out the contents of octet and bit strings. + @return the resulting string. + + +
+             DirectoryString ::= CHOICE {
+               teletexString               TeletexString (SIZE (1..MAX)),
+               printableString             PrintableString (SIZE (1..MAX)),
+               universalString             UniversalString (SIZE (1..MAX)),
+               utf8String                  UTF8String (SIZE (1..MAX)),
+               bmpString                   BMPString (SIZE (1..MAX))  }
+            
+
+ + The AccessDescription object. +
+            AccessDescription  ::=  SEQUENCE {
+                  accessMethod          OBJECT IDENTIFIER,
+                  accessLocation        GeneralName  }
+            
+
+ + create an AccessDescription with the oid and location provided. + + + + @return the access method. + + + + @return the access location + + + Produce an object suitable for an Asn1OutputStream. +
+                 AlgorithmIdentifier ::= Sequence {
+                                       algorithm OBJECT IDENTIFIER,
+                                       parameters ANY DEFINED BY algorithm OPTIONAL }
+            
+
+ + + Don't use this one if you are trying to be RFC 3281 compliant. + Use it for v1 attribute certificates only. + + Our GeneralNames structure + + + Produce an object suitable for an Asn1OutputStream. +
+             AttCertIssuer ::= CHOICE {
+                  v1Form   GeneralNames,  -- MUST NOT be used in this
+                                          -- profile
+                  v2Form   [0] V2Form     -- v2 only
+             }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+             AttCertValidityPeriod  ::= Sequence {
+                  notBeforeTime  GeneralizedTime,
+                  notAfterTime   GeneralizedTime
+             }
+            
+
+ + return an Attr object from the given object. + + @param o the object we want converted. + @exception ArgumentException if the object cannot be converted. + + + Produce an object suitable for an Asn1OutputStream. +
+            Attr ::= Sequence {
+                attrType OBJECT IDENTIFIER,
+                attrValues Set OF AttributeValue
+            }
+            
+
+ + @param obj + @return + + + Produce an object suitable for an Asn1OutputStream. +
+             AttributeCertificate ::= Sequence {
+                  acinfo               AttributeCertificateInfo,
+                  signatureAlgorithm   AlgorithmIdentifier,
+                  signatureValue       BIT STRING
+             }
+            
+
+ + Produce an object suitable for an Asn1OutputStream. +
+              AttributeCertificateInfo ::= Sequence {
+                   version              AttCertVersion -- version is v2,
+                   holder               Holder,
+                   issuer               AttCertIssuer,
+                   signature            AlgorithmIdentifier,
+                   serialNumber         CertificateSerialNumber,
+                   attrCertValidityPeriod   AttCertValidityPeriod,
+                   attributes           Sequence OF Attr,
+                   issuerUniqueID       UniqueIdentifier OPTIONAL,
+                   extensions           Extensions OPTIONAL
+              }
+            
+              AttCertVersion ::= Integer { v2(1) }
+             
+
+ + The AuthorityInformationAccess object. +
+             id-pe-authorityInfoAccess OBJECT IDENTIFIER ::= { id-pe 1 }
+            
+             AuthorityInfoAccessSyntax  ::=
+                  Sequence SIZE (1..MAX) OF AccessDescription
+             AccessDescription  ::=  Sequence {
+                   accessMethod          OBJECT IDENTIFIER,
+                   accessLocation        GeneralName  }
+            
+             id-ad OBJECT IDENTIFIER ::= { id-pkix 48 }
+             id-ad-caIssuers OBJECT IDENTIFIER ::= { id-ad 2 }
+             id-ad-ocsp OBJECT IDENTIFIER ::= { id-ad 1 }
+             
+
+ + create an AuthorityInformationAccess with the oid and location provided. + + + The AuthorityKeyIdentifier object. +
+             id-ce-authorityKeyIdentifier OBJECT IDENTIFIER ::=  { id-ce 35 }
+            
+               AuthorityKeyIdentifier ::= Sequence {
+                  keyIdentifier             [0] IMPLICIT KeyIdentifier           OPTIONAL,
+                  authorityCertIssuer       [1] IMPLICIT GeneralNames            OPTIONAL,
+                  authorityCertSerialNumber [2] IMPLICIT CertificateSerialNumber OPTIONAL  }
+            
+               KeyIdentifier ::= OCTET STRING
+             
+ +
+ + * + * Calulates the keyidentifier using a SHA1 hash over the BIT STRING + * from SubjectPublicKeyInfo as defined in RFC2459. + * + * Example of making a AuthorityKeyIdentifier: + *
+            	     *   SubjectPublicKeyInfo apki = new SubjectPublicKeyInfo((ASN1Sequence)new ASN1InputStream(
+            		 *       publicKey.getEncoded()).readObject());
+                     *   AuthorityKeyIdentifier aki = new AuthorityKeyIdentifier(apki);
+                     * 
+ * + * +
+ + create an AuthorityKeyIdentifier with the GeneralNames tag and + the serial number provided as well. + + + create an AuthorityKeyIdentifier with the GeneralNames tag and + the serial number provided. + + + create an AuthorityKeyIdentifier with a precomputed key identifier + + + create an AuthorityKeyIdentifier with a precomupted key identifier + and the GeneralNames tag and the serial number provided as well. + + + Produce an object suitable for an Asn1OutputStream. + + + create a cA=true object for the given path length constraint. + + @param pathLenConstraint + + + Produce an object suitable for an Asn1OutputStream. +
+            BasicConstraints := Sequence {
+               cA                  Boolean DEFAULT FALSE,
+               pathLenConstraint   Integer (0..MAX) OPTIONAL
+            }
+            
+
+ + PKIX RFC-2459 + + The X.509 v2 CRL syntax is as follows. For signature calculation, + the data that is to be signed is ASN.1 Der encoded. + +
+             CertificateList  ::=  Sequence  {
+                  tbsCertList          TbsCertList,
+                  signatureAlgorithm   AlgorithmIdentifier,
+                  signatureValue       BIT STRING  }
+             
+
+ + This class helps to support crossCerfificatePairs in a LDAP directory + according RFC 2587 + +
+                 crossCertificatePairATTRIBUTE::={
+                   WITH SYNTAX   CertificatePair
+                   EQUALITY MATCHING RULE certificatePairExactMatch
+                   ID joint-iso-ccitt(2) ds(5) attributeType(4) crossCertificatePair(40)}
+             
+ +
The forward elements of the crossCertificatePair attribute of a + CA's directory entry shall be used to store all, except self-issued + certificates issued to this CA. Optionally, the reverse elements of the + crossCertificatePair attribute, of a CA's directory entry may contain a + subset of certificates issued by this CA to other CAs. When both the forward + and the reverse elements are present in a single attribute value, issuer name + in one certificate shall match the subject name in the other and vice versa, + and the subject public key in one certificate shall be capable of verifying + the digital signature on the other certificate and vice versa. + + When a reverse element is present, the forward element value and the reverse + element value need not be stored in the same attribute value; in other words, + they can be stored in either a single attribute value or two attribute + values.
+ +
+                   CertificatePair ::= SEQUENCE {
+                     forward		[0]	Certificate OPTIONAL,
+                     reverse		[1]	Certificate OPTIONAL,
+                     -- at least one of the pair shall be present -- }
+             
+
+ + Constructor from Asn1Sequence. +

+ The sequence is of type CertificatePair: +

+

+                   CertificatePair ::= SEQUENCE {
+                     forward		[0]	Certificate OPTIONAL,
+                     reverse		[1]	Certificate OPTIONAL,
+                     -- at least one of the pair shall be present -- }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. + + @param forward Certificates issued to this CA. + @param reverse Certificates issued by this CA to other CAs. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                   CertificatePair ::= SEQUENCE {
+                     forward		[0]	Certificate OPTIONAL,
+                     reverse		[1]	Certificate OPTIONAL,
+                     -- at least one of the pair shall be present -- }
+             
+ + @return a DERObject +
+ + @return Returns the forward. + + + @return Returns the reverse. + + + CertPolicyId, used in the CertificatePolicies and PolicyMappings + X509V3 Extensions. + +
+                 CertPolicyId ::= OBJECT IDENTIFIER
+             
+
+ + Return the distribution points making up the sequence. + + @return DistributionPoint[] + + + Produce an object suitable for an Asn1OutputStream. +
+            CrlDistPoint ::= Sequence SIZE {1..MAX} OF DistributionPoint
+            
+
+ + The CRLNumber object. +
+            CRLNumber::= Integer(0..MAX)
+            
+
+ + The CRLReason enumeration. +
+            CRLReason ::= Enumerated {
+             unspecified             (0),
+             keyCompromise           (1),
+             cACompromise            (2),
+             affiliationChanged      (3),
+             superseded              (4),
+             cessationOfOperation    (5),
+             certificateHold         (6),
+             removeFromCRL           (8),
+             privilegeWithdrawn      (9),
+             aACompromise           (10)
+            }
+            
+
+ + The DigestInfo object. +
+            DigestInfo::=Sequence{
+                     digestAlgorithm  AlgorithmIdentifier,
+                     digest OCTET STRING }
+            
+
+ + DisplayText class, used in + CertificatePolicies X509 V3 extensions (in policy qualifiers). + +

It stores a string in a chosen encoding. +

+             DisplayText ::= CHOICE {
+                  ia5String        IA5String      (SIZE (1..200)),
+                  visibleString    VisibleString  (SIZE (1..200)),
+                  bmpString        BMPString      (SIZE (1..200)),
+                  utf8String       UTF8String     (SIZE (1..200)) }
+             

+ @see PolicyQualifierInfo + @see PolicyInformation +
+ + Constant corresponding to ia5String encoding. + + + + Constant corresponding to bmpString encoding. + + + + Constant corresponding to utf8String encoding. + + + + Constant corresponding to visibleString encoding. + + + + Describe constant DisplayTextMaximumSize here. + + + + Creates a new DisplayText instance. + + @param type the desired encoding type for the text. + @param text the text to store. Strings longer than 200 + characters are truncated. + + + Creates a new DisplayText instance. + + @param text the text to encapsulate. Strings longer than 200 + characters are truncated. + + + Creates a new DisplayText instance. +

Useful when reading back a DisplayText class + from it's Asn1Encodable form.

+ + @param contents an Asn1Encodable instance. +
+ + Returns the stored string object. + + @return the stored text as a string. + + + The DistributionPoint object. +
+            DistributionPoint ::= Sequence {
+                 distributionPoint [0] DistributionPointName OPTIONAL,
+                 reasons           [1] ReasonFlags OPTIONAL,
+                 cRLIssuer         [2] GeneralNames OPTIONAL
+            }
+            
+
+ + The DistributionPointName object. +
+            DistributionPointName ::= CHOICE {
+                fullName                 [0] GeneralNames,
+                nameRelativeToCRLIssuer  [1] RDN
+            }
+            
+
+ + The extendedKeyUsage object. +
+                 extendedKeyUsage ::= Sequence SIZE (1..MAX) OF KeyPurposeId
+            
+
+ + Returns all extended key usages. + The returned ArrayList contains DerObjectIdentifier instances. + @return An ArrayList with all key purposes. + + + The GeneralName object. +
+             GeneralName ::= CHOICE {
+                  otherName                       [0]     OtherName,
+                  rfc822Name                      [1]     IA5String,
+                  dNSName                         [2]     IA5String,
+                  x400Address                     [3]     ORAddress,
+                  directoryName                   [4]     Name,
+                  ediPartyName                    [5]     EDIPartyName,
+                  uniformResourceIdentifier       [6]     IA5String,
+                  iPAddress                       [7]     OCTET STRING,
+                  registeredID                    [8]     OBJECT IDENTIFIER}
+            
+             OtherName ::= Sequence {
+                  type-id    OBJECT IDENTIFIER,
+                  value      [0] EXPLICIT ANY DEFINED BY type-id }
+            
+             EDIPartyName ::= Sequence {
+                  nameAssigner            [0]     DirectoryString OPTIONAL,
+                  partyName               [1]     DirectoryString }
+             
+
+ + When the subjectAltName extension contains an Internet mail address, + the address MUST be included as an rfc822Name. The format of an + rfc822Name is an "addr-spec" as defined in RFC 822 [RFC 822]. + + When the subjectAltName extension contains a domain name service + label, the domain name MUST be stored in the dNSName (an IA5String). + The name MUST be in the "preferred name syntax," as specified by RFC + 1034 [RFC 1034]. + + When the subjectAltName extension contains a URI, the name MUST be + stored in the uniformResourceIdentifier (an IA5String). The name MUST + be a non-relative URL, and MUST follow the URL syntax and encoding + rules specified in [RFC 1738]. The name must include both a scheme + (e.g., "http" or "ftp") and a scheme-specific-part. The scheme- + specific-part must include a fully qualified domain name or IP + address as the host. + + When the subjectAltName extension contains a iPAddress, the address + MUST be stored in the octet string in "network byte order," as + specified in RFC 791 [RFC 791]. The least significant bit (LSB) of + each octet is the LSB of the corresponding byte in the network + address. For IP Version 4, as specified in RFC 791, the octet string + MUST contain exactly four octets. For IP Version 6, as specified in + RFC 1883, the octet string MUST contain exactly sixteen octets [RFC + 1883]. + + + Create a GeneralName for the given tag from the passed in string. +

+ This constructor can handle: +

    +
  • rfc822Name
  • +
  • iPAddress
  • +
  • directoryName
  • +
  • dNSName
  • +
  • uniformResourceIdentifier
  • +
  • registeredID
  • +
+ For x400Address, otherName and ediPartyName there is no common string + format defined. +

+ Note: A directory name can be encoded in different ways into a byte + representation. Be aware of this if the byte representation is used for + comparing results. +

+ + @param tag tag number + @param name string representation of name + @throws ArgumentException if the string encoding is not correct or + not supported. +
+ + Construct a GeneralNames object containing one GeneralName. + The name to be contained. + + + Produce an object suitable for an Asn1OutputStream. +
+            GeneralNames ::= Sequence SIZE {1..MAX} OF GeneralName
+            
+
+ + Class for containing a restriction object subtrees in NameConstraints. See + RFC 3280. + +
+            
+                   GeneralSubtree ::= SEQUENCE
+                   {
+                     baseName                    GeneralName,
+                     minimum         [0]     BaseDistance DEFAULT 0,
+                     maximum         [1]     BaseDistance OPTIONAL
+                   }
+             
+ + @see org.bouncycastle.asn1.x509.NameConstraints + +
+ + Constructor from a given details. + + According RFC 3280, the minimum and maximum fields are not used with any + name forms, thus minimum MUST be zero, and maximum MUST be absent. +

+ If minimum is null, zero is assumed, if + maximum is null, maximum is absent.

+ + @param baseName + A restriction. + @param minimum + Minimum + + @param maximum + Maximum +
+ + Produce an object suitable for an Asn1OutputStream. + + Returns: + +
+                   GeneralSubtree ::= SEQUENCE
+                   {
+                     baseName                    GeneralName,
+                     minimum         [0]     BaseDistance DEFAULT 0,
+                     maximum         [1]     BaseDistance OPTIONAL
+                   }
+             
+ + @return a DERObject +
+ + The Holder object. +

+ For an v2 attribute certificate this is: + +

+                       Holder ::= SEQUENCE {
+                             baseCertificateID   [0] IssuerSerial OPTIONAL,
+                                      -- the issuer and serial number of
+                                      -- the holder's Public Key Certificate
+                             entityName          [1] GeneralNames OPTIONAL,
+                                      -- the name of the claimant or role
+                             objectDigestInfo    [2] ObjectDigestInfo OPTIONAL
+                                      -- used to directly authenticate the holder,
+                                      -- for example, an executable
+                       }
+            
+

+

+ For an v1 attribute certificate this is: + +

+                    subject CHOICE {
+                     baseCertificateID [0] IssuerSerial,
+                     -- associated with a Public Key Certificate
+                     subjectName [1] GeneralNames },
+                     -- associated with a name
+            
+

+
+ + Constructor for a holder for an v1 attribute certificate. + + @param tagObj The ASN.1 tagged holder object. + + + Constructor for a holder for an v2 attribute certificate. * + + @param seq The ASN.1 sequence. + + + Constructs a holder from a IssuerSerial. + @param baseCertificateID The IssuerSerial. + @param version The version of the attribute certificate. + + + Returns 1 for v2 attribute certificates or 0 for v1 attribute + certificates. + @return The version of the attribute certificate. + + + Constructs a holder with an entityName for v2 attribute certificates or + with a subjectName for v1 attribute certificates. + + @param entityName The entity or subject name. + + + Constructs a holder with an entityName for v2 attribute certificates or + with a subjectName for v1 attribute certificates. + + @param entityName The entity or subject name. + @param version The version of the attribute certificate. + + + Constructs a holder from an object digest info. + + @param objectDigestInfo The object digest info object. + + + Returns the entityName for an v2 attribute certificate or the subjectName + for an v1 attribute certificate. + + @return The entityname or subjectname. + + + The Holder object. +
+             Holder ::= Sequence {
+                   baseCertificateID   [0] IssuerSerial OPTIONAL,
+                            -- the issuer and serial number of
+                            -- the holder's Public Key Certificate
+                   entityName          [1] GeneralNames OPTIONAL,
+                            -- the name of the claimant or role
+                   objectDigestInfo    [2] ObjectDigestInfo OPTIONAL
+                            -- used to directly authenticate the holder,
+                            -- for example, an executable
+             }
+            
+
+ + Implementation of IetfAttrSyntax as specified by RFC3281. + + + + + + +
+            
+              IetfAttrSyntax ::= Sequence {
+                policyAuthority [0] GeneralNames OPTIONAL,
+                values Sequence OF CHOICE {
+                  octets OCTET STRING,
+                  oid OBJECT IDENTIFIER,
+                  string UTF8String
+                }
+              }
+            
+             
+
+ + Produce an object suitable for an Asn1OutputStream. +
+             IssuerSerial  ::=  Sequence {
+                  issuer         GeneralNames,
+                  serial         CertificateSerialNumber,
+                  issuerUid      UniqueIdentifier OPTIONAL
+             }
+            
+
+ +
+            IssuingDistributionPoint ::= SEQUENCE { 
+              distributionPoint          [0] DistributionPointName OPTIONAL, 
+              onlyContainsUserCerts      [1] BOOLEAN DEFAULT FALSE, 
+              onlyContainsCACerts        [2] BOOLEAN DEFAULT FALSE, 
+              onlySomeReasons            [3] ReasonFlags OPTIONAL, 
+              indirectCRL                [4] BOOLEAN DEFAULT FALSE,
+              onlyContainsAttributeCerts [5] BOOLEAN DEFAULT FALSE }
+            
+
+ + Constructor from given details. + + @param distributionPoint + May contain an URI as pointer to most current CRL. + @param onlyContainsUserCerts Covers revocation information for end certificates. + @param onlyContainsCACerts Covers revocation information for CA certificates. + + @param onlySomeReasons + Which revocation reasons does this point cover. + @param indirectCRL + If true then the CRL contains revocation + information about certificates ssued by other CAs. + @param onlyContainsAttributeCerts Covers revocation information for attribute certificates. + + + Constructor from Asn1Sequence + + + @return Returns the distributionPoint. + + + @return Returns the onlySomeReasons. + + + The KeyPurposeID object. +
+                KeyPurposeID ::= OBJECT IDENTIFIER
+            
+
+ + The KeyUsage object. +
+                id-ce-keyUsage OBJECT IDENTIFIER ::=  { id-ce 15 }
+            
+                KeyUsage ::= BIT STRING {
+                     digitalSignature        (0),
+                     nonRepudiation          (1),
+                     keyEncipherment         (2),
+                     dataEncipherment        (3),
+                     keyAgreement            (4),
+                     keyCertSign             (5),
+                     cRLSign                 (6),
+                     encipherOnly            (7),
+                     decipherOnly            (8) }
+             
+
+ + Basic constructor. + + @param usage - the bitwise OR of the Key Usage flags giving the + allowed uses for the key. + e.g. (KeyUsage.keyEncipherment | KeyUsage.dataEncipherment) + + + Constructor from a given details. + +

permitted and excluded are Vectors of GeneralSubtree objects.

+ + @param permitted Permitted subtrees + @param excluded Excluded subtrees +
+ + NoticeReference class, used in + CertificatePolicies X509 V3 extensions + (in policy qualifiers). + +
+              NoticeReference ::= Sequence {
+                  organization     DisplayText,
+                  noticeNumbers    Sequence OF Integer }
+            
+             
+ + @see PolicyQualifierInfo + @see PolicyInformation +
+ + Creates a new NoticeReference instance. + + @param orgName a string value + @param numbers a ArrayList value + + + Creates a new NoticeReference instance. + + @param orgName a string value + @param numbers an Asn1Sequence value + + + Creates a new NoticeReference instance. + + @param displayTextType an int value + @param orgName a string value + @param numbers an Asn1Sequence value + + + Creates a new NoticeReference instance. +

Useful for reconstructing a NoticeReference + instance from its encodable/encoded form.

+ + @param as an Asn1Sequence value obtained from either + calling @{link ToAsn1Object()} for a NoticeReference + instance or from parsing it from a Der-encoded stream. +
+ + Describe ToAsn1Object method here. + + @return a Asn1Object value + + + ObjectDigestInfo ASN.1 structure used in v2 attribute certificates. + +
+             
+               ObjectDigestInfo ::= SEQUENCE {
+                    digestedObjectType  ENUMERATED {
+                            publicKey            (0),
+                            publicKeyCert        (1),
+                            otherObjectTypes     (2) },
+                                    -- otherObjectTypes MUST NOT
+                                    -- be used in this profile
+                    otherObjectTypeID   OBJECT IDENTIFIER OPTIONAL,
+                    digestAlgorithm     AlgorithmIdentifier,
+                    objectDigest        BIT STRING
+               }
+              
+            
+ +
+ + The public key is hashed. + + + The public key certificate is hashed. + + + An other object is hashed. + + + Constructor from given details. +

+ If digestedObjectType is not {@link #publicKeyCert} or + {@link #publicKey} otherObjectTypeID must be given, + otherwise it is ignored.

+ + @param digestedObjectType The digest object type. + @param otherObjectTypeID The object type ID for + otherObjectDigest. + @param digestAlgorithm The algorithm identifier for the hash. + @param objectDigest The hash value. +
+ + Produce an object suitable for an Asn1OutputStream. + +
+             
+               ObjectDigestInfo ::= SEQUENCE {
+                    digestedObjectType  ENUMERATED {
+                            publicKey            (0),
+                            publicKeyCert        (1),
+                            otherObjectTypes     (2) },
+                                    -- otherObjectTypes MUST NOT
+                                    -- be used in this profile
+                    otherObjectTypeID   OBJECT IDENTIFIER OPTIONAL,
+                    digestAlgorithm     AlgorithmIdentifier,
+                    objectDigest        BIT STRING
+               }
+              
+            
+
+ + PolicyMappings V3 extension, described in RFC3280. +
+                PolicyMappings ::= Sequence SIZE (1..MAX) OF Sequence {
+                  issuerDomainPolicy      CertPolicyId,
+                  subjectDomainPolicy     CertPolicyId }
+             
+ + @see RFC 3280, section 4.2.1.6 +
+ + Creates a new PolicyMappings instance. + + @param seq an Asn1Sequence constructed as specified + in RFC 3280 + + + Creates a new PolicyMappings instance. + + @param mappings a HashMap value that maps + string oids + to other string oids. + + + PolicyQualifierId, used in the CertificatePolicies + X509V3 extension. + +
+                id-qt          OBJECT IDENTIFIER ::=  { id-pkix 2 }
+                id-qt-cps      OBJECT IDENTIFIER ::=  { id-qt 1 }
+                id-qt-unotice  OBJECT IDENTIFIER ::=  { id-qt 2 }
+              PolicyQualifierId ::=
+                   OBJECT IDENTIFIER ( id-qt-cps | id-qt-unotice )
+             
+
+ + Policy qualifiers, used in the X509V3 CertificatePolicies + extension. + +
+               PolicyQualifierInfo ::= Sequence {
+                   policyQualifierId  PolicyQualifierId,
+                   qualifier          ANY DEFINED BY policyQualifierId }
+             
+
+ + Creates a new PolicyQualifierInfo instance. + + @param policyQualifierId a PolicyQualifierId value + @param qualifier the qualifier, defined by the above field. + + + Creates a new PolicyQualifierInfo containing a + cPSuri qualifier. + + @param cps the CPS (certification practice statement) uri as a + string. + + + Creates a new PolicyQualifierInfo instance. + + @param as PolicyQualifierInfo X509 structure + encoded as an Asn1Sequence. + + + Returns a Der-encodable representation of this instance. + + @return a Asn1Object value + + + +
+            PrivateKeyUsagePeriod ::= SEQUENCE
+            {
+            notBefore       [0]     GeneralizedTime OPTIONAL,
+            notAfter        [1]     GeneralizedTime OPTIONAL }
+            
+
+
+ + The BiometricData object. +
+            BiometricData  ::=  SEQUENCE {
+                  typeOfBiometricData  TypeOfBiometricData,
+                  hashAlgorithm        AlgorithmIdentifier,
+                  biometricDataHash    OCTET STRING,
+                  sourceDataUri        IA5String OPTIONAL  }
+            
+
+ + The Iso4217CurrencyCode object. +
+            Iso4217CurrencyCode  ::=  CHOICE {
+                  alphabetic              PrintableString (SIZE 3), --Recommended
+                  numeric              INTEGER (1..999) }
+            -- Alphabetic or numeric currency code as defined in ISO 4217
+            -- It is recommended that the Alphabetic form is used
+            
+
+ + The MonetaryValue object. +
+            MonetaryValue  ::=  SEQUENCE {
+                  currency              Iso4217CurrencyCode,
+                  amount               INTEGER,
+                  exponent             INTEGER }
+            -- value = amount * 10^exponent
+            
+
+ + The QCStatement object. +
+            QCStatement ::= SEQUENCE {
+              statementId        OBJECT IDENTIFIER,
+              statementInfo      ANY DEFINED BY statementId OPTIONAL}
+            
+
+ + The SemanticsInformation object. +
+                   SemanticsInformation ::= SEQUENCE {
+                     semanticsIdentifier        OBJECT IDENTIFIER   OPTIONAL,
+                     nameRegistrationAuthorities NameRegistrationAuthorities
+                                                                     OPTIONAL }
+                     (WITH COMPONENTS {..., semanticsIdentifier PRESENT}|
+                      WITH COMPONENTS {..., nameRegistrationAuthorities PRESENT})
+            
+                 NameRegistrationAuthorities ::=  SEQUENCE SIZE (1..MAX) OF
+                     GeneralName
+             
+
+ + The TypeOfBiometricData object. +
+             TypeOfBiometricData ::= CHOICE {
+               predefinedBiometricType   PredefinedBiometricType,
+               biometricDataOid          OBJECT IDENTIFIER }
+            
+             PredefinedBiometricType ::= INTEGER {
+               picture(0),handwritten-signature(1)}
+               (picture|handwritten-signature)
+             
+
+ + The ReasonFlags object. +
+            ReasonFlags ::= BIT STRING {
+               unused(0),
+               keyCompromise(1),
+               cACompromise(2),
+               affiliationChanged(3),
+               superseded(4),
+               cessationOfOperation(5),
+               certficateHold(6)
+            }
+            
+
+ + @param reasons - the bitwise OR of the Key Reason flags giving the + allowed uses for the key. + + + Implementation of the RoleSyntax object as specified by the RFC3281. + +
+             RoleSyntax ::= SEQUENCE {
+                             roleAuthority  [0] GeneralNames OPTIONAL,
+                             roleName       [1] GeneralName
+                       }
+             
+
+ + RoleSyntax factory method. + @param obj the object used to construct an instance of + RoleSyntax. It must be an instance of RoleSyntax + or Asn1Sequence. + @return the instance of RoleSyntax built from the + supplied object. + @throws java.lang.ArgumentException if the object passed + to the factory is not an instance of RoleSyntax or + Asn1Sequence. + + + Constructor. + @param roleAuthority the role authority of this RoleSyntax. + @param roleName the role name of this RoleSyntax. + + + Constructor. Invoking this constructor is the same as invoking + new RoleSyntax(null, roleName). + @param roleName the role name of this RoleSyntax. + + + Utility constructor. Takes a string argument representing + the role name, builds a GeneralName to hold the role name + and calls the constructor that takes a GeneralName. + @param roleName + + + Constructor that builds an instance of RoleSyntax by + extracting the encoded elements from the Asn1Sequence + object supplied. + @param seq an instance of Asn1Sequence that holds + the encoded elements used to build this RoleSyntax. + + + Gets the role authority of this RoleSyntax. + @return an instance of GeneralNames holding the + role authority of this RoleSyntax. + + + Gets the role name of this RoleSyntax. + @return an instance of GeneralName holding the + role name of this RoleSyntax. + + + Gets the role name as a java.lang.string object. + @return the role name of this RoleSyntax represented as a + string object. + + + Gets the role authority as a string[] object. + @return the role authority of this RoleSyntax represented as a + string[] array. + + + Implementation of the method ToAsn1Object as + required by the superclass ASN1Encodable. + +
+             RoleSyntax ::= SEQUENCE {
+                             roleAuthority  [0] GeneralNames OPTIONAL,
+                             roleName       [1] GeneralName
+                       }
+             
+
+ + This outputs the key in Pkcs1v2 format. +
+                 RSAPublicKey ::= Sequence {
+                                     modulus Integer, -- n
+                                     publicExponent Integer, -- e
+                                 }
+            
+
+ + Structure for a name or pseudonym. + +
+                  NameOrPseudonym ::= CHOICE {
+                	   surAndGivenName SEQUENCE {
+                	     surName DirectoryString,
+                	     givenName SEQUENCE OF DirectoryString 
+                    },
+                	   pseudonym DirectoryString 
+                  }
+            
+ + @see org.bouncycastle.asn1.x509.sigi.PersonalData + +
+ + Constructor from DERString. +

+ The sequence is of type NameOrPseudonym: +

+

+                  NameOrPseudonym ::= CHOICE {
+                	   surAndGivenName SEQUENCE {
+                	     surName DirectoryString,
+                	     givenName SEQUENCE OF DirectoryString
+                    },
+                	   pseudonym DirectoryString
+                  }
+            
+ @param pseudonym pseudonym value to use. +
+ + Constructor from Asn1Sequence. +

+ The sequence is of type NameOrPseudonym: +

+

+                   NameOrPseudonym ::= CHOICE {
+                 	   surAndGivenName SEQUENCE {
+                 	     surName DirectoryString,
+                 	     givenName SEQUENCE OF DirectoryString
+                     },
+                 	   pseudonym DirectoryString
+                   }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. + + @param pseudonym The pseudonym. + + + Constructor from a given details. + + @param surname The surname. + @param givenName A sequence of directory strings making up the givenName + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                   NameOrPseudonym ::= CHOICE {
+                 	   surAndGivenName SEQUENCE {
+                 	     surName DirectoryString,
+                 	     givenName SEQUENCE OF DirectoryString
+                     },
+                 	   pseudonym DirectoryString
+                   }
+             
+ + @return an Asn1Object +
+ + Contains personal data for the otherName field in the subjectAltNames + extension. +

+

+                 PersonalData ::= SEQUENCE {
+                   nameOrPseudonym NameOrPseudonym,
+                   nameDistinguisher [0] INTEGER OPTIONAL,
+                   dateOfBirth [1] GeneralizedTime OPTIONAL,
+                   placeOfBirth [2] DirectoryString OPTIONAL,
+                   gender [3] PrintableString OPTIONAL,
+                   postalAddress [4] DirectoryString OPTIONAL
+                   }
+             
+ + @see org.bouncycastle.asn1.x509.sigi.NameOrPseudonym + @see org.bouncycastle.asn1.x509.sigi.SigIObjectIdentifiers +
+ + Constructor from Asn1Sequence. +

+ The sequence is of type NameOrPseudonym: +

+

+                 PersonalData ::= SEQUENCE {
+                   nameOrPseudonym NameOrPseudonym,
+                   nameDistinguisher [0] INTEGER OPTIONAL,
+                   dateOfBirth [1] GeneralizedTime OPTIONAL,
+                   placeOfBirth [2] DirectoryString OPTIONAL,
+                   gender [3] PrintableString OPTIONAL,
+                   postalAddress [4] DirectoryString OPTIONAL
+                   }
+             
+ + @param seq The ASN.1 sequence. +
+ + Constructor from a given details. + + @param nameOrPseudonym Name or pseudonym. + @param nameDistinguisher Name distinguisher. + @param dateOfBirth Date of birth. + @param placeOfBirth Place of birth. + @param gender Gender. + @param postalAddress Postal Address. + + + Produce an object suitable for an Asn1OutputStream. +

+ Returns: +

+

+                 PersonalData ::= SEQUENCE {
+                   nameOrPseudonym NameOrPseudonym,
+                   nameDistinguisher [0] INTEGER OPTIONAL,
+                   dateOfBirth [1] GeneralizedTime OPTIONAL,
+                   placeOfBirth [2] DirectoryString OPTIONAL,
+                   gender [3] PrintableString OPTIONAL,
+                   postalAddress [4] DirectoryString OPTIONAL
+                   }
+             
+ + @return an Asn1Object +
+ + Object Identifiers of SigI specifciation (German Signature Law + Interoperability specification). + + + Key purpose IDs for German SigI (Signature Interoperability + Specification) + + + Certificate policy IDs for German SigI (Signature Interoperability + Specification) + + + Other Name IDs for German SigI (Signature Interoperability Specification) + + + To be used for for the generation of directory service certificates. + + + ID for PersonalData + + + Certificate is conform to german signature law. + + + This extension may contain further X.500 attributes of the subject. See also + RFC 3039. + +
+                 SubjectDirectoryAttributes ::= Attributes
+                 Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+                 Attribute ::= SEQUENCE
+                 {
+                   type AttributeType
+                   values SET OF AttributeValue
+                 }
+            
+                 AttributeType ::= OBJECT IDENTIFIER
+                 AttributeValue ::= ANY DEFINED BY AttributeType
+             
+ + @see org.bouncycastle.asn1.x509.X509Name for AttributeType ObjectIdentifiers. +
+ + Constructor from Asn1Sequence. + + The sequence is of type SubjectDirectoryAttributes: + +
+                  SubjectDirectoryAttributes ::= Attributes
+                  Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+                  Attribute ::= SEQUENCE
+                  {
+                    type AttributeType
+                    values SET OF AttributeValue
+                  }
+            
+                  AttributeType ::= OBJECT IDENTIFIER
+                  AttributeValue ::= ANY DEFINED BY AttributeType
+             
+ + @param seq + The ASN.1 sequence. +
+ + Constructor from an ArrayList of attributes. + + The ArrayList consists of attributes of type {@link Attribute Attribute} + + @param attributes The attributes. + + + + Produce an object suitable for an Asn1OutputStream. + + Returns: + +
+                  SubjectDirectoryAttributes ::= Attributes
+                  Attributes ::= SEQUENCE SIZE (1..MAX) OF Attribute
+                  Attribute ::= SEQUENCE
+                  {
+                    type AttributeType
+                    values SET OF AttributeValue
+                  }
+            
+                  AttributeType ::= OBJECT IDENTIFIER
+                  AttributeValue ::= ANY DEFINED BY AttributeType
+             
+ + @return a DERObject +
+ + @return Returns the attributes. + + + The SubjectKeyIdentifier object. +
+            SubjectKeyIdentifier::= OCTET STRING
+            
+
+ + Calculates the keyIdentifier using a SHA1 hash over the BIT STRING + from SubjectPublicKeyInfo as defined in RFC3280. + + @param spki the subject public key info. + + + Return a RFC 3280 type 1 key identifier. As in: +
+            (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the
+            value of the BIT STRING subjectPublicKey (excluding the tag,
+            length, and number of unused bits).
+            
+ @param keyInfo the key info object containing the subjectPublicKey field. + @return the key identifier. +
+ + Return a RFC 3280 type 2 key identifier. As in: +
+            (2) The keyIdentifier is composed of a four bit type field with
+            the value 0100 followed by the least significant 60 bits of the
+            SHA-1 hash of the value of the BIT STRING subjectPublicKey.
+            
+ @param keyInfo the key info object containing the subjectPublicKey field. + @return the key identifier. +
+ + The object that contains the public key stored in a certficate. +

+ The GetEncoded() method in the public keys in the JCE produces a DER + encoded one of these.

+
+ + for when the public key is an encoded object - if the bitstring + can't be decoded this routine raises an IOException. + + @exception IOException - if the bit string doesn't represent a Der + encoded object. + + + for when the public key is raw bits... + + + Produce an object suitable for an Asn1OutputStream. +
+            SubjectPublicKeyInfo ::= Sequence {
+                                     algorithm AlgorithmIdentifier,
+                                     publicKey BIT STRING }
+            
+
+ + Target structure used in target information extension for attribute + certificates from RFC 3281. + +
+                Target  ::= CHOICE {
+                  targetName          [0] GeneralName,
+                  targetGroup         [1] GeneralName,
+                  targetCert          [2] TargetCert
+                }
+            
+ +

+ The targetCert field is currently not supported and must not be used + according to RFC 3281.

+
+ + Creates an instance of a Target from the given object. +

+ obj can be a Target or a {@link Asn1TaggedObject}

+ + @param obj The object. + @return A Target instance. + @throws ArgumentException if the given object cannot be + interpreted as Target. +
+ + Constructor from Asn1TaggedObject. + + @param tagObj The tagged object. + @throws ArgumentException if the encoding is wrong. + + + Constructor from given details. +

+ Exactly one of the parameters must be not null.

+ + @param type the choice type to apply to the name. + @param name the general name. + @throws ArgumentException if type is invalid. +
+ + @return Returns the targetGroup. + + + @return Returns the targetName. + + + Produce an object suitable for an Asn1OutputStream. + + Returns: + +
+                Target  ::= CHOICE {
+                  targetName          [0] GeneralName,
+                  targetGroup         [1] GeneralName,
+                  targetCert          [2] TargetCert
+                }
+            
+ + @return an Asn1Object +
+ + Target information extension for attributes certificates according to RFC + 3281. + +
+                      SEQUENCE OF Targets
+            
+ +
+ + Creates an instance of a TargetInformation from the given object. +

+ obj can be a TargetInformation or a {@link Asn1Sequence}

+ + @param obj The object. + @return A TargetInformation instance. + @throws ArgumentException if the given object cannot be interpreted as TargetInformation. +
+ + Constructor from a Asn1Sequence. + + @param seq The Asn1Sequence. + @throws ArgumentException if the sequence does not contain + correctly encoded Targets elements. + + + Returns the targets in this target information extension. +

+ The ArrayList is cloned before it is returned.

+ + @return Returns the targets. +
+ + Constructs a target information from a single targets element. + According to RFC 3281 only one targets element must be produced. + + @param targets A Targets instance. + + + According to RFC 3281 only one targets element must be produced. If + multiple targets are given they must be merged in + into one targets element. + + @param targets An array with {@link Targets}. + + + Produce an object suitable for an Asn1OutputStream. + + Returns: + +
+                     SEQUENCE OF Targets
+            
+ +

+ According to RFC 3281 only one targets element must be produced. If + multiple targets are given in the constructor they are merged into one + targets element. If this was produced from a + {@link Org.BouncyCastle.Asn1.Asn1Sequence} the encoding is kept.

+ + @return an Asn1Object +
+ + Targets structure used in target information extension for attribute + certificates from RFC 3281. + +
+                       Targets ::= SEQUENCE OF Target
+                      
+                       Target  ::= CHOICE {
+                         targetName          [0] GeneralName,
+                         targetGroup         [1] GeneralName,
+                         targetCert          [2] TargetCert
+                       }
+                      
+                       TargetCert  ::= SEQUENCE {
+                         targetCertificate    IssuerSerial,
+                         targetName           GeneralName OPTIONAL,
+                         certDigestInfo       ObjectDigestInfo OPTIONAL
+                       }
+            
+ + @see org.bouncycastle.asn1.x509.Target + @see org.bouncycastle.asn1.x509.TargetInformation +
+ + Creates an instance of a Targets from the given object. +

+ obj can be a Targets or a {@link Asn1Sequence}

+ + @param obj The object. + @return A Targets instance. + @throws ArgumentException if the given object cannot be interpreted as Target. +
+ + Constructor from Asn1Sequence. + + @param targets The ASN.1 SEQUENCE. + @throws ArgumentException if the contents of the sequence are + invalid. + + + Constructor from given targets. +

+ The ArrayList is copied.

+ + @param targets An ArrayList of {@link Target}s. + @see Target + @throws ArgumentException if the ArrayList contains not only Targets. +
+ + Returns the targets in an ArrayList. +

+ The ArrayList is cloned before it is returned.

+ + @return Returns the targets. +
+ + Produce an object suitable for an Asn1OutputStream. + + Returns: + +
+                       Targets ::= SEQUENCE OF Target
+            
+ + @return an Asn1Object +
+ + The TbsCertificate object. +
+            TbsCertificate ::= Sequence {
+                 version          [ 0 ]  Version DEFAULT v1(0),
+                 serialNumber            CertificateSerialNumber,
+                 signature               AlgorithmIdentifier,
+                 issuer                  Name,
+                 validity                Validity,
+                 subject                 Name,
+                 subjectPublicKeyInfo    SubjectPublicKeyInfo,
+                 issuerUniqueID    [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+                 subjectUniqueID   [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+                 extensions        [ 3 ] Extensions OPTIONAL
+                 }
+            
+

+ Note: issuerUniqueID and subjectUniqueID are both deprecated by the IETF. This class + will parse them, but you really shouldn't be creating new ones.

+
+ + PKIX RFC-2459 - TbsCertList object. +
+            TbsCertList  ::=  Sequence  {
+                 version                 Version OPTIONAL,
+                                              -- if present, shall be v2
+                 signature               AlgorithmIdentifier,
+                 issuer                  Name,
+                 thisUpdate              Time,
+                 nextUpdate              Time OPTIONAL,
+                 revokedCertificates     Sequence OF Sequence  {
+                      userCertificate         CertificateSerialNumber,
+                      revocationDate          Time,
+                      crlEntryExtensions      Extensions OPTIONAL
+                                                    -- if present, shall be v2
+                                           }  OPTIONAL,
+                 crlExtensions           [0]  EXPLICIT Extensions OPTIONAL
+                                                    -- if present, shall be v2
+                                           }
+            
+
+ + creates a time object from a given date - if the date is between 1950 + and 2049 a UTCTime object is Generated, otherwise a GeneralizedTime + is used. + + + + Return our time as DateTime. + + A date time. + + + Produce an object suitable for an Asn1OutputStream. +
+            Time ::= CHOICE {
+                        utcTime        UTCTime,
+                        generalTime    GeneralizedTime }
+            
+
+ + UserNotice class, used in + CertificatePolicies X509 extensions (in policy + qualifiers). +
+             UserNotice ::= Sequence {
+                  noticeRef        NoticeReference OPTIONAL,
+                  explicitText     DisplayText OPTIONAL}
+            
+             
+ + @see PolicyQualifierId + @see PolicyInformation +
+ + Creates a new UserNotice instance. + + @param noticeRef a NoticeReference value + @param explicitText a DisplayText value + + + Creates a new UserNotice instance. + + @param noticeRef a NoticeReference value + @param str the explicitText field as a string. + + + Creates a new UserNotice instance. +

Useful from reconstructing a UserNotice instance + from its encodable/encoded form. + + @param as an ASN1Sequence value obtained from either + calling @{link toASN1Object()} for a UserNotice + instance or from parsing it from a DER-encoded stream.

+
+ + Generator for Version 1 TbsCertificateStructures. +
+             TbsCertificate ::= Sequence {
+                  version          [ 0 ]  Version DEFAULT v1(0),
+                  serialNumber            CertificateSerialNumber,
+                  signature               AlgorithmIdentifier,
+                  issuer                  Name,
+                  validity                Validity,
+                  subject                 Name,
+                  subjectPublicKeyInfo    SubjectPublicKeyInfo,
+                  }
+             
+ +
+ + Generator for Version 2 AttributeCertificateInfo +
+             AttributeCertificateInfo ::= Sequence {
+                   version              AttCertVersion -- version is v2,
+                   holder               Holder,
+                   issuer               AttCertIssuer,
+                   signature            AlgorithmIdentifier,
+                   serialNumber         CertificateSerialNumber,
+                   attrCertValidityPeriod   AttCertValidityPeriod,
+                   attributes           Sequence OF Attr,
+                   issuerUniqueID       UniqueIdentifier OPTIONAL,
+                   extensions           Extensions OPTIONAL
+             }
+             
+ +
+ + @param attribute + + + Produce an object suitable for an Asn1OutputStream. +
+             V2Form ::= Sequence {
+                  issuerName            GeneralNames  OPTIONAL,
+                  baseCertificateID     [0] IssuerSerial  OPTIONAL,
+                  objectDigestInfo      [1] ObjectDigestInfo  OPTIONAL
+                    -- issuerName MUST be present in this profile
+                    -- baseCertificateID and objectDigestInfo MUST NOT
+                    -- be present in this profile
+             }
+            
+
+ + Generator for Version 2 TbsCertList structures. +
+              TbsCertList  ::=  Sequence  {
+                   version                 Version OPTIONAL,
+                                                -- if present, shall be v2
+                   signature               AlgorithmIdentifier,
+                   issuer                  Name,
+                   thisUpdate              Time,
+                   nextUpdate              Time OPTIONAL,
+                   revokedCertificates     Sequence OF Sequence  {
+                        userCertificate         CertificateSerialNumber,
+                        revocationDate          Time,
+                        crlEntryExtensions      Extensions OPTIONAL
+                                                      -- if present, shall be v2
+                                             }  OPTIONAL,
+                   crlExtensions           [0]  EXPLICIT Extensions OPTIONAL
+                                                      -- if present, shall be v2
+                                             }
+             
+ + Note: This class may be subject to change +
+ + Generator for Version 3 TbsCertificateStructures. +
+             TbsCertificate ::= Sequence {
+                  version          [ 0 ]  Version DEFAULT v1(0),
+                  serialNumber            CertificateSerialNumber,
+                  signature               AlgorithmIdentifier,
+                  issuer                  Name,
+                  validity                Validity,
+                  subject                 Name,
+                  subjectPublicKeyInfo    SubjectPublicKeyInfo,
+                  issuerUniqueID    [ 1 ] IMPLICIT UniqueIdentifier OPTIONAL,
+                  subjectUniqueID   [ 2 ] IMPLICIT UniqueIdentifier OPTIONAL,
+                  extensions        [ 3 ] Extensions OPTIONAL
+                  }
+             
+ +
+ + an X509Certificate structure. +
+             Certificate ::= Sequence {
+                 tbsCertificate          TbsCertificate,
+                 signatureAlgorithm      AlgorithmIdentifier,
+                 signature               BIT STRING
+             }
+            
+
+ + The default converter for X509 DN entries when going from their + string value to ASN.1 strings. + + + Apply default conversion for the given value depending on the oid + and the character range of the value. + + @param oid the object identifier for the DN entry + @param value the value associated with it + @return the ASN.1 equivalent for the string value. + + + an object for the elements in the X.509 V3 extension block. + + + Convert the value of the passed in extension to an object. + The extension to parse. + The object the value string contains. + If conversion is not possible. + + + Subject Directory Attributes + + + Subject Key Identifier + + + Key Usage + + + Private Key Usage Period + + + Subject Alternative Name + + + Issuer Alternative Name + + + Basic Constraints + + + CRL Number + + + Reason code + + + Hold Instruction Code + + + Invalidity Date + + + Delta CRL indicator + + + Issuing Distribution Point + + + Certificate Issuer + + + Name Constraints + + + CRL Distribution Points + + + Certificate Policies + + + Policy Mappings + + + Authority Key Identifier + + + Policy Constraints + + + Extended Key Usage + + + Freshest CRL + + + Inhibit Any Policy + + + Authority Info Access + + + Subject Info Access + + + Logo Type + + + BiometricInfo + + + QCStatements + + + Audit identity extension in attribute certificates. + + + NoRevAvail extension in attribute certificates. + + + TargetInformation extension in attribute certificates. + + + Constructor from Asn1Sequence. + + the extensions are a list of constructed sequences, either with (Oid, OctetString) or (Oid, Boolean, OctetString) + + + constructor from a table of extensions. +

+ it's is assumed the table contains Oid/string pairs.

+
+ + Constructor from a table of extensions with ordering. +

+ It's is assumed the table contains Oid/string pairs.

+
+ + Constructor from two vectors + + @param objectIDs an ArrayList of the object identifiers. + @param values an ArrayList of the extension values. + + + return an Enumeration of the extension field's object ids. + + + return the extension represented by the object identifier + passed in. + + @return the extension if it's present, null otherwise. + + +
+                 Extensions        ::=   SEQUENCE SIZE (1..MAX) OF Extension
+            
+                 Extension         ::=   SEQUENCE {
+                    extnId            EXTENSION.&id ({ExtensionSet}),
+                    critical          BOOLEAN DEFAULT FALSE,
+                    extnValue         OCTET STRING }
+             
+
+ + Generator for X.509 extensions + + + Reset the generator + + + + Add an extension with the given oid and the passed in value to be included + in the OCTET STRING associated with the extension. + + OID for the extension. + True if critical, false otherwise. + The ASN.1 object to be included in the extension. + + + + Add an extension with the given oid and the passed in byte array to be wrapped + in the OCTET STRING associated with the extension. + + OID for the extension. + True if critical, false otherwise. + The byte array to be wrapped. + + + Return true if there are no extension present in this generator. + True if empty, false otherwise + + + Generate an X509Extensions object based on the current state of the generator. + An X509Extensions object + + +
+                 RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
+            
+                 RelativeDistinguishedName ::= SET SIZE (1..MAX) OF AttributeTypeAndValue
+            
+                 AttributeTypeAndValue ::= SEQUENCE {
+                                               type  OBJECT IDENTIFIER,
+                                               value ANY }
+             
+
+ + country code - StringType(SIZE(2)) + + + organization - StringType(SIZE(1..64)) + + + organizational unit name - StringType(SIZE(1..64)) + + + Title + + + common name - StringType(SIZE(1..64)) + + + street - StringType(SIZE(1..64)) + + + device serial number name - StringType(SIZE(1..64)) + + + locality name - StringType(SIZE(1..64)) + + + state, or province name - StringType(SIZE(1..64)) + + + Naming attributes of type X520name + + + businessCategory - DirectoryString(SIZE(1..128) + + + postalCode - DirectoryString(SIZE(1..40) + + + dnQualifier - DirectoryString(SIZE(1..64) + + + RFC 3039 Pseudonym - DirectoryString(SIZE(1..64) + + + RFC 3039 DateOfBirth - GeneralizedTime - YYYYMMDD000000Z + + + RFC 3039 PlaceOfBirth - DirectoryString(SIZE(1..128) + + + RFC 3039 DateOfBirth - PrintableString (SIZE(1)) -- "M", "F", "m" or "f" + + + RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166 + codes only + + + RFC 3039 CountryOfCitizenship - PrintableString (SIZE (2)) -- ISO 3166 + codes only + + + ISIS-MTT NameAtBirth - DirectoryString(SIZE(1..64) + + + RFC 3039 PostalAddress - SEQUENCE SIZE (1..6) OF + DirectoryString(SIZE(1..30)) + + + RFC 2256 dmdName + + + id-at-telephoneNumber + + + id-at-name + + + Email address (RSA PKCS#9 extension) - IA5String. +

Note: if you're trying to be ultra orthodox, don't use this! It shouldn't be in here.

+
+ + more from PKCS#9 + + + email address in Verisign certificates + + + LDAP User id. + + + determines whether or not strings should be processed and printed + from back to front. + + + default look up table translating OID values into their common symbols following + the convention in RFC 2253 with a few extras + + + look up table translating OID values into their common symbols following the convention in RFC 2253 + + + look up table translating OID values into their common symbols following the convention in RFC 1779 + + + + look up table translating common symbols into their OIDS. + + + Return a X509Name based on the passed in tagged object. + + @param obj tag object holding name. + @param explicitly true if explicitly tagged false otherwise. + @return the X509Name + + + Constructor from Asn1Sequence + + the principal will be a list of constructed sets, each containing an (OID, string) pair. + + + Constructor from a table of attributes with ordering. +

+ it's is assumed the table contains OID/string pairs, and the contents + of the table are copied into an internal table as part of the + construction process. The ordering ArrayList should contain the OIDs + in the order they are meant to be encoded or printed in ToString.

+
+ + Constructor from a table of attributes with ordering. +

+ it's is assumed the table contains OID/string pairs, and the contents + of the table are copied into an internal table as part of the + construction process. The ordering ArrayList should contain the OIDs + in the order they are meant to be encoded or printed in ToString.

+

+ The passed in converter will be used to convert the strings into their + ASN.1 counterparts.

+
+ + Takes two vectors one of the oids and the other of the values. + + + Takes two vectors one of the oids and the other of the values. +

+ The passed in converter will be used to convert the strings into their + ASN.1 counterparts.

+
+ + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes. + + + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes with each + string value being converted to its associated ASN.1 type using the passed + in converter. + + + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes. If reverse + is true, create the encoded version of the sequence starting from the + last element in the string. + + + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes with each + string value being converted to its associated ASN.1 type using the passed + in converter. If reverse is true the ASN.1 sequence representing the DN will + be built by starting at the end of the string, rather than the start. + + + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes. lookUp + should provide a table of lookups, indexed by lowercase only strings and + yielding a DerObjectIdentifier, other than that OID. and numeric oids + will be processed automatically. +
+ If reverse is true, create the encoded version of the sequence + starting from the last element in the string. + @param reverse true if we should start scanning from the end (RFC 2553). + @param lookUp table of names and their oids. + @param dirName the X.500 string to be parsed. +
+ + Takes an X509 dir name as a string of the format "C=AU, ST=Victoria", or + some such, converting it into an ordered set of name attributes. lookUp + should provide a table of lookups, indexed by lowercase only strings and + yielding a DerObjectIdentifier, other than that OID. and numeric oids + will be processed automatically. The passed in converter is used to convert the + string values to the right of each equals sign to their ASN.1 counterparts. +
+ @param reverse true if we should start scanning from the end, false otherwise. + @param lookUp table of names and oids. + @param dirName the string dirName + @param converter the converter to convert string values into their ASN.1 equivalents +
+ + return an IList of the oids in the name, in the order they were found. + + + return an IList of the values found in the name, in the order they + were found. + + + return an IList of the values found in the name, in the order they + were found, with the DN label corresponding to passed in oid. + + + The X509Name object to test equivalency against. + If true, the order of elements must be the same, + as well as the values associated with each element. + + + test for equivalence - note: case is ignored. + + + convert the structure to a string - if reverse is true the + oids and values are listed out starting with the last element + in the sequence (ala RFC 2253), otherwise the string will begin + with the first element of the structure. If no string definition + for the oid is found in oidSymbols the string value of the oid is + added. Two standard symbol tables are provided DefaultSymbols, and + RFC2253Symbols as part of this class. + + @param reverse if true start at the end of the sequence and work back. + @param oidSymbols look up table strings for oids. + + + * It turns out that the number of standard ways the fields in a DN should be + * encoded into their ASN.1 counterparts is rapidly approaching the + * number of machines on the internet. By default the X509Name class + * will produce UTF8Strings in line with the current recommendations (RFC 3280). + *

+ * An example of an encoder look like below: + *

+                 * public class X509DirEntryConverter
+                 *     : X509NameEntryConverter
+                 * {
+                 *     public Asn1Object GetConvertedValue(
+                 *         DerObjectIdentifier  oid,
+                 *         string               value)
+                 *     {
+                 *         if (str.Length() != 0 && str.charAt(0) == '#')
+                 *         {
+                 *             return ConvertHexEncoded(str, 1);
+                 *         }
+                 *         if (oid.Equals(EmailAddress))
+                 *         {
+                 *             return new DerIA5String(str);
+                 *         }
+                 *         else if (CanBePrintable(str))
+                 *         {
+                 *             return new DerPrintableString(str);
+                 *         }
+                 *         else if (CanBeUTF8(str))
+                 *         {
+                 *             return new DerUtf8String(str);
+                 *         }
+                 *         else
+                 *         {
+                 *             return new DerBmpString(str);
+                 *         }
+                 *     }
+                 * }
+            	 * 
+ *

+
+ + Convert an inline encoded hex string rendition of an ASN.1 + object back into its corresponding ASN.1 object. + + @param str the hex encoded object + @param off the index at which the encoding starts + @return the decoded object + + + return true if the passed in string can be represented without + loss as a PrintableString, false otherwise. + + + Convert the passed in string value into the appropriate ASN.1 + encoded object. + + @param oid the oid associated with the value in the DN. + @param value the value of the particular DN component. + @return the ASN.1 equivalent for the value. + + + class for breaking up an X500 Name into it's component tokens, ala + java.util.StringTokenizer. We need this class as some of the + lightweight Java environment don't support classes like + StringTokenizer. + + + ASN.1 def for Diffie-Hellman key exchange KeySpecificInfo structure. See + RFC 2631, or X9.42, for further details. + + + Produce an object suitable for an Asn1OutputStream. +
+             KeySpecificInfo ::= Sequence {
+                 algorithm OBJECT IDENTIFIER,
+                 counter OCTET STRING SIZE (4..4)
+             }
+            
+
+ + ANS.1 def for Diffie-Hellman key exchange OtherInfo structure. See + RFC 2631, or X9.42, for further details. + + + Produce an object suitable for an Asn1OutputStream. +
+             OtherInfo ::= Sequence {
+                 keyInfo KeySpecificInfo,
+                 partyAInfo [0] OCTET STRING OPTIONAL,
+                 suppPubInfo [2] OCTET STRING
+             }
+            
+
+ + table of the current named curves defined in X.962 EC-DSA. + + + return the X9ECParameters object for the named curve represented by + the passed in object identifier. Null if the curve isn't present. + + @param oid an object identifier representing a named curve, if present. + + + return the object identifier signified by the passed in name. Null + if there is no object identifier associated with name. + + @return the object identifier associated with name, if present. + + + return the named curve name represented by the given object identifier. + + + returns an enumeration containing the name strings for curves + contained in this structure. + + + Produce an object suitable for an Asn1OutputStream. +
+            Parameters ::= CHOICE {
+               ecParameters ECParameters,
+               namedCurve   CURVES.&id({CurveNames}),
+               implicitlyCA Null
+            }
+            
+
+ + ASN.1 def for Elliptic-Curve Curve structure. See + X9.62, for further details. + + + Produce an object suitable for an Asn1OutputStream. +
+             Curve ::= Sequence {
+                 a               FieldElement,
+                 b               FieldElement,
+                 seed            BIT STRING      OPTIONAL
+             }
+            
+
+ + ASN.1 def for Elliptic-Curve ECParameters structure. See + X9.62, for further details. + + + Produce an object suitable for an Asn1OutputStream. +
+             ECParameters ::= Sequence {
+                 version         Integer { ecpVer1(1) } (ecpVer1),
+                 fieldID         FieldID {{FieldTypes}},
+                 curve           X9Curve,
+                 base            X9ECPoint,
+                 order           Integer,
+                 cofactor        Integer OPTIONAL
+             }
+            
+
+ + class for describing an ECPoint as a Der object. + + + Produce an object suitable for an Asn1OutputStream. +
+             ECPoint ::= OCTET STRING
+            
+

+ Octet string produced using ECPoint.GetEncoded().

+
+ + Class for processing an ECFieldElement as a DER object. + + + Produce an object suitable for an Asn1OutputStream. +
+             FieldElement ::= OCTET STRING
+            
+

+

    +
  1. if q is an odd prime then the field element is + processed as an Integer and converted to an octet string + according to x 9.62 4.3.1.
  2. +
  3. if q is 2m then the bit string + contained in the field element is converted into an octet + string with the same ordering padded at the front if necessary. +
  4. +
+

+
+ + ASN.1 def for Elliptic-Curve Field ID structure. See + X9.62, for further details. + + + Constructor for elliptic curves over prime fields + F2. + @param primeP The prime p defining the prime field. + + + Constructor for elliptic curves over binary fields + F2m. + @param m The exponent m of + F2m. + @param k1 The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k2 The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k3 The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).. + + + Produce a Der encoding of the following structure. +
+             FieldID ::= Sequence {
+                 fieldType       FIELD-ID.&id({IOSet}),
+                 parameters      FIELD-ID.&Type({IOSet}{@fieldType})
+             }
+            
+
+ + id-dsa-with-sha1 OBJECT IDENTIFIER ::= { iso(1) member-body(2) + us(840) x9-57 (10040) x9cm(4) 3 } + + + X9.63 + + + X9.42 + + + reader for Base64 armored objects - read the headers and then start returning + bytes when the data is reached. An IOException is thrown if the CRC check + fails. + + + decode the base 64 encoded input data. + + @return the offset the data starts in out. + + + Create a stream for reading a PGP armoured message, parsing up to a header + and then reading the data that follows. + + @param input + + + Create an armoured input stream which will assume the data starts + straight away, or parse for headers first depending on the value of + hasHeaders. + + @param input + @param hasHeaders true if headers are to be looked for, false otherwise. + + + @return true if we are inside the clear text section of a PGP + signed message. + + + @return true if the stream is actually at end of file. + + + Return the armor header line (if there is one) + @return the armor header line, null if none present. + + + Return the armor headers (the lines after the armor header line), + @return an array of armor headers, null if there aren't any. + + + Basic output stream. + + + encode the input data producing a base 64 encoded byte array. + + + Set an additional header entry. + + @param name the name of the header entry. + @param v the value of the header entry. + + + Reset the headers to only contain a Version string. + + + Start a clear text signed message. + @param hashAlgorithm + + + Note: Dispose does nor Dispose the underlying stream. So it is possible to write + multiple objects using armoring to a single stream. + + + Basic type for a image attribute packet. + + + Reader for PGP objects. + + + Returns the next packet tag in the stream. + + + + A stream that overlays our input stream, allowing the user to only read a segment of it. + NB: dataLength will be negative if the segment length is in the upper range above 2**31. + + + + Base class for a PGP object. + + + Basic output stream. + + + Create a stream representing a general packet. + Output stream to write to. + + + Create a stream representing an old style partial object. + Output stream to write to. + The packet tag for the object. + + + Create a stream representing a general packet. + Output stream to write to. + Packet tag. + Size of chunks making up the packet. + If true, the header is written out in old format. + + + Create a new style partial input stream buffered into chunks. + Output stream to write to. + Packet tag. + Size of chunks making up the packet. + + + Create a new style partial input stream buffered into chunks. + Output stream to write to. + Packet tag. + Buffer to use for collecting chunks. + + + Flush the underlying stream. + + + Finish writing out the current packet without closing the underlying stream. + + + Generic compressed data object. + + + The algorithm tag value. + + + Basic tags for compression algorithms. + + + Basic type for a PGP packet. + + + Base class for a DSA public key. + + + The stream to read the packet from. + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + Base class for a DSA secret key. + + + @param in + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + @return x + + + Base class for an ElGamal public key. + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + Base class for an ElGamal secret key. + + + @param in + + + @param x + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + Basic packet for an experimental packet. + + + Basic tags for hash algorithms. + + + Base interface for a PGP key. + + + + The base format for this key - in the case of the symmetric keys it will generally + be raw indicating that the key is just a straight byte representation, for an asymmetric + key the format will be PGP, indicating the key is a string of MPIs encoded in PGP format. + + "RAW" or "PGP". + + + Note: you can only read from this once... + + + Generic literal data packet. + + + The format tag value. + + + The modification time of the file in milli-seconds (since Jan 1, 1970 UTC) + + + Basic type for a marker packet. + + + Basic packet for a modification detection code packet. + + + A multiple precision integer + + + Generic signature object + + + The encryption algorithm tag. + + + The hash algorithm tag. + + + Basic PGP packet tag types. + + + Public Key Algorithm tag numbers. + + + Basic packet for a PGP public key. + + + Basic packet for a PGP public key. + + + Construct a version 4 public key packet. + + + Basic packet for a PGP public subkey + + + Construct a version 4 public subkey packet. + + + Base class for an RSA public key. + + + Construct an RSA public key from the passed in stream. + + + The modulus. + The public exponent. + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + Base class for an RSA secret (or priate) key. + + + The format, as a string, always "PGP". + + + Return the standard PGP encoding of the key. + + + The string to key specifier class. + + + The hash algorithm. + + + The IV for the key generation algorithm. + + + The iteration count + + + The protection mode - only if GnuDummyS2K + + + Basic packet for a PGP secret key. + + + Basic packet for a PGP secret key. + + + Generic signature packet. + + + Generate a version 4 signature packet. + + @param signatureType + @param keyAlgorithm + @param hashAlgorithm + @param hashedData + @param unhashedData + @param fingerprint + @param signature + + + Generate a version 2/3 signature packet. + + @param signatureType + @param keyAlgorithm + @param hashAlgorithm + @param fingerprint + @param signature + + + return the keyId + @return the keyId that created the signature. + + + return the signature trailer that must be included with the data + to reconstruct the signature + + @return byte[] + + + * return the signature as a set of integers - note this is normalised to be the + * ASN.1 encoding of what appears in the signature packet. + + + Return the byte encoding of the signature section. + @return uninterpreted signature bytes. + + + Return the creation time in milliseconds since 1 Jan., 1970 UTC. + + + Basic type for a PGP Signature sub-packet. + + + Return the generic data making up the packet. + + + reader for signature sub-packets + + + Basic PGP signature sub-packet tag types. + + + Packet embedded signature + + + packet giving signature creation time. + + + packet giving signature creation time. + + + packet giving time after creation at which the key expires. + + + Return the number of seconds after creation time a key is valid for. + + @return second count for key validity. + + + Packet holding the key flag values. + + + + Return the flag values contained in the first 4 octets (note: at the moment + the standard only uses the first one). + + + + Class provided a NotationData object according to + RFC2440, Chapter 5.2.3.15. Notation Data + + + packet giving signature creation time. + + + packet giving whether or not the signature is signed using the primary user ID for the key. + + + packet giving whether or not is revocable. + + + packet giving signature creation time. + + + packet giving signature expiration time. + + + return time in seconds before signature expires after creation time. + + + packet giving the User ID of the signer. + + + packet giving trust. + + + + Represents revocation key OpenPGP signature sub packet. + + + + + Represents revocation reason OpenPGP signature sub packet. + + + + Basic type for a symmetric key encrypted packet. + + + Basic tags for symmetric key algorithms + + + Basic type for a symmetric encrypted session key packet + + + @return int + + + @return S2k + + + @return byte[] + + + @return int + + + Basic type for a trust packet. + + + Basic type for a user attribute packet. + + + Basic type for a user attribute sub-packet. + + + return the generic data making up the packet. + + + reader for user attribute sub-packets + + + Basic PGP user attribute sub-packet tag types. + + + Basic type for a user ID packet. + + + Compressed data objects + + + The algorithm used for compression + + + Get the raw input stream contained in the object. + + + Return an uncompressed input stream which allows reading of the compressed data. + + + Class for producing compressed data packets. + + + +

+ Return an output stream which will save the data being written to + the compressed object. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+
+ Stream to be used for output. + A Stream for output of the compressed data. + + + +
+ + +

+ Return an output stream which will compress the data as it is written to it. + The stream will be written out in chunks according to the size of the passed in buffer. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+

+ Note: if the buffer is not a power of 2 in length only the largest power of 2 + bytes worth of the buffer will be used. +

+

+ Note: using this may break compatibility with RFC 1991 compliant tools. + Only recent OpenPGP implementations are capable of accepting these streams. +

+
+ Stream to be used for output. + The buffer to use. + A Stream for output of the compressed data. + + + + +
+ + Close the compressed object.summary> + + + + Thrown if the IV at the start of a data stream indicates the wrong key is being used. + + + + Return the raw input stream for the data stream. + + + Return true if the message is integrity protected. + True, if there is a modification detection code namespace associated + with this stream. + + + Note: This can only be called after the message has been read. + True, if the message verifies, false otherwise + + + Generator for encrypted objects. + + + Existing SecureRandom constructor. + The symmetric algorithm to use. + Source of randomness. + + + Creates a cipher stream which will have an integrity packet associated with it. + + + Base constructor. + The symmetric algorithm to use. + Source of randomness. + PGP 2.6.x compatibility required. + + + + Add a PBE encryption method to the encrypted object using the default algorithm (S2K_SHA1). + + + + Add a PBE encryption method to the encrypted object. + + + Add a public key encrypted session key to the encrypted object. + + + +

+ If buffer is non null stream assumed to be partial, otherwise the length will be used + to output a fixed length packet. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+
+
+ + +

+ Return an output stream which will encrypt the data as it is written to it. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+
+
+ + +

+ Return an output stream which will encrypt the data as it is written to it. + The stream will be written out in chunks according to the size of the passed in buffer. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+

+ Note: if the buffer is not a power of 2 in length only the largest power of 2 + bytes worth of the buffer will be used. +

+
+
+ + +

+ Close off the encrypted object - this is equivalent to calling Close() on the stream + returned by the Open() method. +

+

+ Note: This does not close the underlying output stream, only the stream on top of + it created by the Open() method. +

+
+
+ + A holder for a list of PGP encryption method packets. + + + Generic exception class for PGP encoding/decoding problems. + + + Key flag values for the KeyFlags subpacket. + + + + General class to handle JCA key pairs and convert them into OpenPGP ones. +

+ A word for the unwary, the KeyId for an OpenPGP public key is calculated from + a hash that includes the time of creation, if you pass a different date to the + constructor below with the same public private key pair the KeyIs will not be the + same as for previous generations of the key, so ideally you only want to do + this once. +

+
+
+ + Create a key pair from a PgpPrivateKey and a PgpPublicKey. + The public key. + The private key. + + + The keyId associated with this key pair. + + + + Generator for a PGP master and subkey ring. + This class will generate both the secret and public key rings + + + + + Create a new key ring generator using old style checksumming. It is recommended to use + SHA1 checksumming where possible. + + The certification level for keys on this ring. + The master key pair. + The id to be associated with the ring. + The algorithm to be used to protect secret keys. + The passPhrase to be used to protect secret keys. + Packets to be included in the certification hash. + Packets to be attached unhashed to the certification. + input secured random. + + + + Create a new key ring generator. + + The certification level for keys on this ring. + The master key pair. + The id to be associated with the ring. + The algorithm to be used to protect secret keys. + The passPhrase to be used to protect secret keys. + Checksum the secret keys with SHA1 rather than the older 16 bit checksum. + Packets to be included in the certification hash. + Packets to be attached unhashed to the certification. + input secured random. + + + Add a subkey to the key ring to be generated with default certification. + + + + Add a subkey with specific hashed and unhashed packets associated with it and + default certification. + + Public/private key pair. + Hashed packet values to be included in certification. + Unhashed packets values to be included in certification. + + + + Return the secret key ring. + + + Return the public key ring that corresponds to the secret key ring. + + + + Thrown if the key checksum is invalid. + + + + Class for processing literal data objects. + + + The special name indicating a "for your eyes only" packet. + + + The format of the data stream - Binary or Text + + + The file name that's associated with the data stream. + + + Return the file name as an unintrepreted byte array. + + + The modification time for the file. + + + The raw input stream for the data stream. + + + The input stream representing the data stream. + + + Class for producing literal data packets. + + + The special name indicating a "for your eyes only" packet. + + + + Generates literal data objects in the old format. + This is important if you need compatibility with PGP 2.6.x. + + If true, uses old format. + + + +

+ Open a literal data packet, returning a stream to store the data inside the packet. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+
+ The stream we want the packet in. + The format we are using. + The name of the 'file'. + The length of the data we will write. + The time of last modification we want stored. +
+ + +

+ Open a literal data packet, returning a stream to store the data inside the packet, + as an indefinite length stream. The stream is written out as a series of partial + packets with a chunk size determined by the size of the passed in buffer. +

+

+ The stream created can be closed off by either calling Close() + on the stream or Close() on the generator. Closing the returned + stream does not close off the Stream parameter outStr. +

+

+ Note: if the buffer is not a power of 2 in length only the largest power of 2 + bytes worth of the buffer will be used.

+
+ The stream we want the packet in. + The format we are using. + The name of the 'file'. + The time of last modification we want stored. + The buffer to use for collecting data to put into chunks. +
+ + + Close the literal data packet - this is equivalent to calling Close() + on the stream returned by the Open() method. + + + + + A PGP marker packet - in general these should be ignored other than where + the idea is to preserve the original input stream. + + + + + General class for reading a PGP object stream. +

+ Note: if this class finds a PgpPublicKey or a PgpSecretKey it + will create a PgpPublicKeyRing, or a PgpSecretKeyRing for each + key found. If all you are trying to do is read a key ring file use + either PgpPublicKeyRingBundle or PgpSecretKeyRingBundle.

+
+
+ + Return the next object in the stream, or null if the end is reached. + On a parse error + + + + Return all available objects in a list. + + An IList containing all objects from this factory, in order. + + + A one pass signature object. + + + Initialise the signature object for verification. + + + Verify the calculated signature against the passed in PgpSignature. + + + Holder for a list of PgpOnePassSignature objects. + + + A password based encryption object. + + + Return the raw input stream for the data stream. + + + Return the decrypted input stream, using the passed in passphrase. + + + General class to contain a private key for use with other OpenPGP objects. + + + + Create a PgpPrivateKey from a regular private key and the ID of its + associated public key. + + Private key to use. + ID of the corresponding public key. + + + The keyId associated with the contained private key. + + + The contained private key. + + + General class to handle a PGP public key object. + + + + Create a PgpPublicKey from the passed in lightweight one. + + + Note: the time passed in affects the value of the key's keyId, so you probably only want + to do this once for a lightweight key, or make sure you keep track of the time you used. + + Asymmetric algorithm type representing the public key. + Actual public key to associate. + Date of creation. + If pubKey is not public. + On key creation problem. + + + Constructor for a sub-key. + + + Copy constructor. + The public key to copy. + + + The version of this key. + + + The creation time of this key. + + + The number of valid days from creation time - zero means no expiry. + + + Return the trust data associated with the public key, if present. + A byte array with trust data, null otherwise. + + + The number of valid seconds from creation time - zero means no expiry. + + + The keyId associated with the public key. + + + The fingerprint of the key + + + + Check if this key has an algorithm type that makes it suitable to use for encryption. + + + Note: with version 4 keys KeyFlags subpackets should also be considered when present for + determining the preferred use of the key. + + + true if this key algorithm is suitable for encryption. + + + + True, if this is a master key. + + + The algorithm code associated with the public key. + + + The strength of the key in bits. + + + The public key contained in the object. + A lightweight public key. + If the key algorithm is not recognised. + + + Allows enumeration of any user IDs associated with the key. + An IEnumerable of string objects. + + + Allows enumeration of any user attribute vectors associated with the key. + An IEnumerable of PgpUserAttributeSubpacketVector objects. + + + Allows enumeration of any signatures associated with the passed in id. + The ID to be matched. + An IEnumerable of PgpSignature objects. + + + Allows enumeration of signatures associated with the passed in user attributes. + The vector of user attributes to be matched. + An IEnumerable of PgpSignature objects. + + + Allows enumeration of signatures of the passed in type that are on this key. + The type of the signature to be returned. + An IEnumerable of PgpSignature objects. + + + Allows enumeration of all signatures/certifications associated with this key. + An IEnumerable with all signatures/certifications. + + + Check whether this (sub)key has a revocation signature on it. + True, if this (sub)key has been revoked. + + + Add a certification for an id to the given public key. + The key the certification is to be added to. + The ID the certification is associated with. + The new certification. + The re-certified key. + + + Add a certification for the given UserAttributeSubpackets to the given public key. + The key the certification is to be added to. + The attributes the certification is associated with. + The new certification. + The re-certified key. + + + + Remove any certifications associated with a user attribute subpacket on a key. + + The key the certifications are to be removed from. + The attributes to be removed. + + The re-certified key, or null if the user attribute subpacket was not found on the key. + + + + Remove any certifications associated with a given ID on a key. + The key the certifications are to be removed from. + The ID that is to be removed. + The re-certified key, or null if the ID was not found on the key. + + + Remove a certification associated with a given ID on a key. + The key the certifications are to be removed from. + The ID that the certfication is to be removed from. + The certfication to be removed. + The re-certified key, or null if the certification was not found. + + + Remove a certification associated with a given user attributes on a key. + The key the certifications are to be removed from. + The user attributes that the certfication is to be removed from. + The certification to be removed. + The re-certified key, or null if the certification was not found. + + + Add a revocation or some other key certification to a key. + The key the revocation is to be added to. + The key signature to be added. + The new changed public key object. + + + Remove a certification from the key. + The key the certifications are to be removed from. + The certfication to be removed. + The modified key, null if the certification was not found. + + + A public key encrypted data object. + + + The key ID for the key used to encrypt the data. + + + + Return the algorithm code for the symmetric algorithm used to encrypt the data. + + + + Return the decrypted data stream for the packet. + + + + Class to hold a single master public key and its subkeys. +

+ Often PGP keyring files consist of multiple master keys, if you are trying to process + or construct one of these you should use the PgpPublicKeyRingBundle class. +

+
+
+ + Return the first public key in the ring. + + + Return the public key referred to by the passed in key ID if it is present. + + + Allows enumeration of all the public keys. + An IEnumerable of PgpPublicKey objects. + + + + Returns a new key ring with the public key passed in either added or + replacing an existing one. + + The public key ring to be modified. + The public key to be inserted. + A new PgpPublicKeyRing + + + Returns a new key ring with the public key passed in removed from the key ring. + The public key ring to be modified. + The public key to be removed. + A new PgpPublicKeyRing, or null if pubKey is not found. + + + + Often a PGP key ring file is made up of a succession of master/sub-key key rings. + If you want to read an entire public key file in one hit this is the class for you. + + + + Build a PgpPublicKeyRingBundle from the passed in input stream. + Input stream containing data. + If a problem parsing the stream occurs. + If an object is encountered which isn't a PgpPublicKeyRing. + + + Return the number of key rings in this collection. + + + Allow enumeration of the public key rings making up this collection. + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + An IEnumerable of key rings which matched (possibly none). + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + If true, userId need only be a substring of an actual ID string to match. + An IEnumerable of key rings which matched (possibly none). + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + If true, userId need only be a substring of an actual ID string to match. + If true, case is ignored in user ID comparisons. + An IEnumerable of key rings which matched (possibly none). + + + Return the PGP public key associated with the given key id. + The ID of the public key to return. + + + Return the public key ring which contains the key referred to by keyId + key ID to match against + + + + Return true if a key matching the passed in key ID is present, false otherwise. + + key ID to look for. + + + + Return a new bundle containing the contents of the passed in bundle and + the passed in public key ring. + + The PgpPublicKeyRingBundle the key ring is to be added to. + The key ring to be added. + A new PgpPublicKeyRingBundle merging the current one with the passed in key ring. + If the keyId for the passed in key ring is already present. + + + + Return a new bundle containing the contents of the passed in bundle with + the passed in public key ring removed. + + The PgpPublicKeyRingBundle the key ring is to be removed from. + The key ring to be removed. + A new PgpPublicKeyRingBundle not containing the passed in key ring. + If the keyId for the passed in key ring is not present. + + + General class to handle a PGP secret key object. + + + + Check if this key has an algorithm type that makes it suitable to use for signing. + + + Note: with version 4 keys KeyFlags subpackets should also be considered when present for + determining the preferred use of the key. + + + true if this key algorithm is suitable for use with signing. + + + + True, if this is a master key. + + + The algorithm the key is encrypted with. + + + The key ID of the public key associated with this key. + + + The public key associated with this key. + + + Allows enumeration of any user IDs associated with the key. + An IEnumerable of string objects. + + + Allows enumeration of any user attribute vectors associated with the key. + An IEnumerable of string objects. + + + Extract a PgpPrivateKey from this secret key's encrypted contents. + + + + Return a copy of the passed in secret key, encrypted using a new password + and the passed in algorithm. + + The PgpSecretKey to be copied. + The current password for the key. + The new password for the key. + The algorithm to be used for the encryption. + Source of randomness. + + + Replace the passed the public key on the passed in secret key. + Secret key to change. + New public key. + A new secret key. + If KeyId's do not match. + + + + Class to hold a single master secret key and its subkeys. +

+ Often PGP keyring files consist of multiple master keys, if you are trying to process + or construct one of these you should use the PgpSecretKeyRingBundle class. +

+
+
+ + Return the public key for the master key. + + + Return the master private key. + + + Allows enumeration of the secret keys. + An IEnumerable of PgpSecretKey objects. + + + + Return an iterator of the public keys in the secret key ring that + have no matching private key. At the moment only personal certificate data + appears in this fashion. + + An IEnumerable of unattached, or extra, public keys. + + + + Replace the public key set on the secret ring with the corresponding key off the public ring. + + Secret ring to be changed. + Public ring containing the new public key set. + + + + Return a copy of the passed in secret key ring, with the master key and sub keys encrypted + using a new password and the passed in algorithm. + + The PgpSecretKeyRing to be copied. + The current password for key. + The new password for the key. + The algorithm to be used for the encryption. + Source of randomness. + + + + Returns a new key ring with the secret key passed in either added or + replacing an existing one with the same key ID. + + The secret key ring to be modified. + The secret key to be inserted. + A new PgpSecretKeyRing + + + Returns a new key ring with the secret key passed in removed from the key ring. + The secret key ring to be modified. + The secret key to be removed. + A new PgpSecretKeyRing, or null if secKey is not found. + + + + Often a PGP key ring file is made up of a succession of master/sub-key key rings. + If you want to read an entire secret key file in one hit this is the class for you. + + + + Build a PgpSecretKeyRingBundle from the passed in input stream. + Input stream containing data. + If a problem parsing the stream occurs. + If an object is encountered which isn't a PgpSecretKeyRing. + + + Return the number of rings in this collection. + + + Allow enumeration of the secret key rings making up this collection. + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + An IEnumerable of key rings which matched (possibly none). + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + If true, userId need only be a substring of an actual ID string to match. + An IEnumerable of key rings which matched (possibly none). + + + Allow enumeration of the key rings associated with the passed in userId. + The user ID to be matched. + If true, userId need only be a substring of an actual ID string to match. + If true, case is ignored in user ID comparisons. + An IEnumerable of key rings which matched (possibly none). + + + Return the PGP secret key associated with the given key id. + The ID of the secret key to return. + + + Return the secret key ring which contains the key referred to by keyId + The ID of the secret key + + + + Return true if a key matching the passed in key ID is present, false otherwise. + + key ID to look for. + + + + Return a new bundle containing the contents of the passed in bundle and + the passed in secret key ring. + + The PgpSecretKeyRingBundle the key ring is to be added to. + The key ring to be added. + A new PgpSecretKeyRingBundle merging the current one with the passed in key ring. + If the keyId for the passed in key ring is already present. + + + + Return a new bundle containing the contents of the passed in bundle with + the passed in secret key ring removed. + + The PgpSecretKeyRingBundle the key ring is to be removed from. + The key ring to be removed. + A new PgpSecretKeyRingBundle not containing the passed in key ring. + If the keyId for the passed in key ring is not present. + + + A PGP signature object. + + + The OpenPGP version number for this signature. + + + The key algorithm associated with this signature. + + + The hash algorithm associated with this signature. + + + + Verify the signature as certifying the passed in public key as associated + with the passed in user attributes. + + User attributes the key was stored under. + The key to be verified. + True, if the signature matches, false otherwise. + + + + Verify the signature as certifying the passed in public key as associated + with the passed in ID. + + ID the key was stored under. + The key to be verified. + True, if the signature matches, false otherwise. + + + Verify a certification for the passed in key against the passed in master key. + The key we are verifying against. + The key we are verifying. + True, if the certification is valid, false otherwise. + + + Verify a key certification, such as revocation, for the passed in key. + The key we are checking. + True, if the certification is valid, false otherwise. + + + The ID of the key that created the signature. + + + The creation time of this signature. + + + + Return true if the signature has either hashed or unhashed subpackets. + + + + Generator for PGP signatures. + + + Create a generator for the passed in keyAlgorithm and hashAlgorithm codes. + + + Initialise the generator for signing. + + + Initialise the generator for signing. + + + Return the one pass header associated with the current signature. + + + Return a signature object containing the current signature state. + + + Generate a certification for the passed in ID and key. + The ID we are certifying against the public key. + The key we are certifying against the ID. + The certification. + + + Generate a certification for the passed in userAttributes. + The ID we are certifying against the public key. + The key we are certifying against the ID. + The certification. + + + Generate a certification for the passed in key against the passed in master key. + The key we are certifying against. + The key we are certifying. + The certification. + + + Generate a certification, such as a revocation, for the passed in key. + The key we are certifying. + The certification. + + + A list of PGP signatures - normally in the signature block after literal data. + + + Generator for signature subpackets. + + + + Add a TrustSignature packet to the signature. The values for depth and trust are largely + installation dependent but there are some guidelines in RFC 4880 - 5.2.3.13. + + true if the packet is critical. + depth level. + trust amount. + + + + Set the number of seconds a key is valid for after the time of its creation. + A value of zero means the key never expires. + + True, if should be treated as critical, false otherwise. + The number of seconds the key is valid, or zero if no expiry. + + + + Set the number of seconds a signature is valid for after the time of its creation. + A value of zero means the signature never expires. + + True, if should be treated as critical, false otherwise. + The number of seconds the signature is valid, or zero if no expiry. + + + + Set the creation time for the signature. +

+ Note: this overrides the generation of a creation time when the signature + is generated.

+
+
+ + + Sets revocation reason sub packet + + + + + Sets revocation key sub packet + + + + + Sets issuer key sub packet + + + + Container for a list of signature subpackets. + + + Return true if a particular subpacket type exists. + + @param type type to look for. + @return true if present, false otherwise. + + + Return all signature subpackets of the passed in type. + @param type subpacket type code + @return an array of zero or more matching subpackets. + + + + Return the number of seconds a signature is valid for after its creation date. + A value of zero means the signature never expires. + + Seconds a signature is valid for. + + + + Return the number of seconds a key is valid for after its creation date. + A value of zero means the key never expires. + + Seconds a signature is valid for. + + + Return the number of packets this vector contains. + + + Container for a list of user attribute subpackets. + + + Basic utility class. + + + + Return either an ArmoredInputStream or a BcpgInputStream based on whether + the initial characters of the stream are binary PGP encodings or not. + + + + Generator for old style PGP V3 Signatures. + + + Create a generator for the passed in keyAlgorithm and hashAlgorithm codes. + + + Initialise the generator for signing. + + + Initialise the generator for signing. + + + Return the one pass header associated with the current signature. + + + Return a V3 signature object containing the current signature state. + + + + The 'Signature' parameter is only available when generating unsigned attributes. + + + + containing class for an CMS Authenticated Data object + + + return the object identifier for the content MAC algorithm. + + + return a store of the intended recipients for this message + + + return the ContentInfo + + + return a table of the digested attributes indexed by + the OID of the attribute. + + + return a table of the undigested attributes indexed by + the OID of the attribute. + + + return the ASN.1 encoded representation of this object. + + + General class for generating a CMS authenticated-data message. + + A simple example of usage. + +
+                  CMSAuthenticatedDataGenerator  fact = new CMSAuthenticatedDataGenerator();
+            
+                  fact.addKeyTransRecipient(cert);
+            
+                  CMSAuthenticatedData         data = fact.generate(content, algorithm, "BC");
+             
+
+ + base constructor + + + constructor allowing specific source of randomness + @param rand instance of SecureRandom to use + + + generate an enveloped object that contains an CMS Enveloped Data + object using the given provider and the passed in key generator. + + + generate an authenticated object that contains an CMS Authenticated Data object + + + Parsing class for an CMS Authenticated Data object from an input stream. +

+ Note: that because we are in a streaming mode only one recipient can be tried and it is important + that the methods on the parser are called in the appropriate order. +

+

+ Example of use - assuming the first recipient matches the private key we have. +

+                  CMSAuthenticatedDataParser     ad = new CMSAuthenticatedDataParser(inputStream);
+            
+                  RecipientInformationStore  recipients = ad.getRecipientInfos();
+            
+                  Collection  c = recipients.getRecipients();
+                  Iterator    it = c.iterator();
+            
+                  if (it.hasNext())
+                  {
+                      RecipientInformation   recipient = (RecipientInformation)it.next();
+            
+                      CMSTypedStream recData = recipient.getContentStream(privateKey, "BC");
+            
+                      processDataStream(recData.getContentStream());
+            
+                      if (!Arrays.equals(ad.getMac(), recipient.getMac())
+                      {
+                          System.err.println("Data corrupted!!!!");
+                      }
+                  }
+              
+ Note: this class does not introduce buffering - if you are processing large files you should create + the parser with: +
+                      CMSAuthenticatedDataParser     ep = new CMSAuthenticatedDataParser(new BufferedInputStream(inputStream, bufSize));
+              
+ where bufSize is a suitably large buffer size. +

+
+ + return the object identifier for the mac algorithm. + + + return the ASN.1 encoded encryption algorithm parameters, or null if + there aren't any. + + + return a store of the intended recipients for this message + + + return a table of the unauthenticated attributes indexed by + the OID of the attribute. + @exception java.io.IOException + + + return a table of the unauthenticated attributes indexed by + the OID of the attribute. + @exception java.io.IOException + + + General class for generating a CMS authenticated-data message stream. +

+ A simple example of usage. +

+                  CMSAuthenticatedDataStreamGenerator edGen = new CMSAuthenticatedDataStreamGenerator();
+            
+                  edGen.addKeyTransRecipient(cert);
+            
+                  ByteArrayOutputStream  bOut = new ByteArrayOutputStream();
+            
+                  OutputStream out = edGen.open(
+                                          bOut, CMSAuthenticatedDataGenerator.AES128_CBC, "BC");*
+                  out.write(data);
+            
+                  out.close();
+             
+

+
+ + base constructor + + + constructor allowing specific source of randomness + @param rand instance of SecureRandom to use + + + Set the underlying string size for encapsulated data + + @param bufferSize length of octet strings to buffer the data. + + + Use a BER Set to store the recipient information + + + generate an enveloped object that contains an CMS Enveloped Data + object using the given provider and the passed in key generator. + @throws java.io.IOException + + + generate an enveloped object that contains an CMS Enveloped Data object + + + generate an enveloped object that contains an CMS Enveloped Data object + + + base constructor + + + constructor allowing specific source of randomness + + @param rand instance of SecureRandom to use + + + containing class for an CMS AuthEnveloped Data object + + + containing class for an CMS Compressed Data object + + + Return the uncompressed content. + + @return the uncompressed content + @throws CmsException if there is an exception uncompressing the data. + + + Return the uncompressed content, throwing an exception if the data size + is greater than the passed in limit. If the content is exceeded getCause() + on the CMSException will contain a StreamOverflowException + + @param limit maximum number of bytes to read + @return the content read + @throws CMSException if there is an exception uncompressing the data. + + + return the ContentInfo + + + return the ASN.1 encoded representation of this object. + + + * General class for generating a compressed CMS message. + *

+ * A simple example of usage.

+ *

+ *

+                *      CMSCompressedDataGenerator fact = new CMSCompressedDataGenerator();
+                *      CMSCompressedData data = fact.Generate(content, algorithm);
+                * 
+ *

+
+ + Generate an object that contains an CMS Compressed Data + + + Class for reading a CMS Compressed Data stream. +
+                 CMSCompressedDataParser cp = new CMSCompressedDataParser(inputStream);
+            
+                 process(cp.GetContent().GetContentStream());
+             
+ Note: this class does not introduce buffering - if you are processing large files you should create + the parser with: +
+                  CMSCompressedDataParser     ep = new CMSCompressedDataParser(new BufferedInputStream(inputStream, bufSize));
+              
+ where bufSize is a suitably large buffer size. +
+ + General class for generating a compressed CMS message stream. +

+ A simple example of usage. +

+
+                  CMSCompressedDataStreamGenerator gen = new CMSCompressedDataStreamGenerator();
+            
+                  Stream cOut = gen.Open(outputStream, CMSCompressedDataStreamGenerator.ZLIB);
+            
+                  cOut.Write(data);
+            
+                  cOut.Close();
+             
+
+ + base constructor + + + Set the underlying string size for encapsulated data + + @param bufferSize length of octet strings to buffer the data. + + + Close the underlying data stream. + @throws IOException if the close fails. + + + containing class for an CMS Enveloped Data object + + + return the object identifier for the content encryption algorithm. + + + return a store of the intended recipients for this message + + + return the ContentInfo + + + return a table of the unprotected attributes indexed by + the OID of the attribute. + + + return the ASN.1 encoded representation of this object. + + + + General class for generating a CMS enveloped-data message. + + A simple example of usage. + +
+                  CmsEnvelopedDataGenerator  fact = new CmsEnvelopedDataGenerator();
+            
+                  fact.AddKeyTransRecipient(cert);
+            
+                  CmsEnvelopedData         data = fact.Generate(content, algorithm);
+             
+
+
+ + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + + Generate an enveloped object that contains a CMS Enveloped Data + object using the passed in key generator. + + + + Generate an enveloped object that contains an CMS Enveloped Data object. + + + Generate an enveloped object that contains an CMS Enveloped Data object. + + + Parsing class for an CMS Enveloped Data object from an input stream. +

+ Note: that because we are in a streaming mode only one recipient can be tried and it is important + that the methods on the parser are called in the appropriate order. +

+

+ Example of use - assuming the first recipient matches the private key we have. +

+                  CmsEnvelopedDataParser     ep = new CmsEnvelopedDataParser(inputStream);
+            
+                  RecipientInformationStore  recipients = ep.GetRecipientInfos();
+            
+                  Collection  c = recipients.getRecipients();
+                  Iterator    it = c.iterator();
+            
+                  if (it.hasNext())
+                  {
+                      RecipientInformation   recipient = (RecipientInformation)it.next();
+            
+                      CMSTypedStream recData = recipient.getContentStream(privateKey);
+            
+                      processDataStream(recData.getContentStream());
+                  }
+              
+ Note: this class does not introduce buffering - if you are processing large files you should create + the parser with: +
+                      CmsEnvelopedDataParser     ep = new CmsEnvelopedDataParser(new BufferedInputStream(inputStream, bufSize));
+              
+ where bufSize is a suitably large buffer size. +

+
+ + return the object identifier for the content encryption algorithm. + + + return the ASN.1 encoded encryption algorithm parameters, or null if + there aren't any. + + + return a store of the intended recipients for this message + + + return a table of the unprotected attributes indexed by + the OID of the attribute. + @throws IOException + + + General class for generating a CMS enveloped-data message stream. +

+ A simple example of usage. +

+                  CmsEnvelopedDataStreamGenerator edGen = new CmsEnvelopedDataStreamGenerator();
+            
+                  edGen.AddKeyTransRecipient(cert);
+            
+                  MemoryStream  bOut = new MemoryStream();
+            
+                  Stream out = edGen.Open(
+                                          bOut, CMSEnvelopedDataGenerator.AES128_CBC);*
+                  out.Write(data);
+            
+                  out.Close();
+             
+

+
+ + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + Set the underlying string size for encapsulated data. + Length of octet strings to buffer the data. + + + Use a BER Set to store the recipient information. + + + + Generate an enveloped object that contains an CMS Enveloped Data + object using the passed in key generator. + + + + generate an enveloped object that contains an CMS Enveloped Data object + @throws IOException + + + generate an enveloped object that contains an CMS Enveloped Data object + @throws IOException + + + General class for generating a CMS enveloped-data message. + + A simple example of usage. + +
+                  CMSEnvelopedDataGenerator  fact = new CMSEnvelopedDataGenerator();
+            
+                  fact.addKeyTransRecipient(cert);
+            
+                  CMSEnvelopedData         data = fact.generate(content, algorithm, "BC");
+             
+
+ + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + add a recipient. + + @param cert recipient's public key certificate + @exception ArgumentException if there is a problem with the certificate + + + add a recipient + + @param key the public key used by the recipient + @param subKeyId the identifier for the recipient's public key + @exception ArgumentException if there is a problem with the key + + + add a KEK recipient. + @param key the secret key to use for wrapping + @param keyIdentifier the byte string that identifies the key + + + add a KEK recipient. + @param key the secret key to use for wrapping + @param keyIdentifier the byte string that identifies the key + + + Add a key agreement based recipient. + + @param agreementAlgorithm key agreement algorithm to use. + @param senderPrivateKey private key to initialise sender side of agreement with. + @param senderPublicKey sender public key to include with message. + @param recipientCert recipient's public key certificate. + @param cekWrapAlgorithm OID for key wrapping algorithm to use. + @exception SecurityUtilityException if the algorithm requested cannot be found + @exception InvalidKeyException if the keys are inappropriate for the algorithm specified + + + Add multiple key agreement based recipients (sharing a single KeyAgreeRecipientInfo structure). + + @param agreementAlgorithm key agreement algorithm to use. + @param senderPrivateKey private key to initialise sender side of agreement with. + @param senderPublicKey sender public key to include with message. + @param recipientCerts recipients' public key certificates. + @param cekWrapAlgorithm OID for key wrapping algorithm to use. + @exception SecurityUtilityException if the algorithm requested cannot be found + @exception InvalidKeyException if the keys are inappropriate for the algorithm specified + + + + Generic routine to copy out the data we want processed. + + + This routine may be called multiple times. + + + + a holding class for a byte array of data to be processed. + + + A clone of the byte array + + + general class for handling a pkcs7-signature message. + + A simple example of usage - note, in the example below the validity of + the certificate isn't verified, just the fact that one of the certs + matches the given signer... + +
+              IX509Store              certs = s.GetCertificates();
+              SignerInformationStore  signers = s.GetSignerInfos();
+            
+              foreach (SignerInformation signer in signers.GetSigners())
+              {
+                  ArrayList       certList = new ArrayList(certs.GetMatches(signer.SignerID));
+                  X509Certificate cert = (X509Certificate) certList[0];
+            
+                  if (signer.Verify(cert.GetPublicKey()))
+                  {
+                      verified++;
+                  }
+              }
+             
+
+ + Content with detached signature, digests precomputed + + @param hashes a map of precomputed digests for content indexed by name of hash. + @param sigBlock the signature object. + + + base constructor - content with detached signature. + + @param signedContent the content that was signed. + @param sigData the signature object. + + + base constructor - with encapsulated content + + + Return the version number for this object. + + + return the collection of signers that are associated with the + signatures for the message. + + + return a X509Store containing the attribute certificates, if any, contained + in this message. + + @param type type of store to create + @return a store of attribute certificates + @exception NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + return a X509Store containing the public key certificates, if any, contained + in this message. + + @param type type of store to create + @return a store of public key certificates + @exception NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + return a X509Store containing CRLs, if any, contained + in this message. + + @param type type of store to create + @return a store of CRLs + @exception NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + + Return the DerObjectIdentifier associated with the encapsulated + content info structure carried in the signed data. + + + + return the ContentInfo + + + return the ASN.1 encoded representation of this object. + + + Replace the signerinformation store associated with this + CmsSignedData object with the new one passed in. You would + probably only want to do this if you wanted to change the unsigned + attributes associated with a signer, or perhaps delete one. + + @param signedData the signed data object to be used as a base. + @param signerInformationStore the new signer information store to use. + @return a new signed data object. + + + Replace the certificate and CRL information associated with this + CmsSignedData object with the new one passed in. + + @param signedData the signed data object to be used as a base. + @param x509Certs the new certificates to be used. + @param x509Crls the new CRLs to be used. + @return a new signed data object. + @exception CmsException if there is an error processing the stores + + + * general class for generating a pkcs7-signature message. + *

+ * A simple example of usage. + * + *

+                 *      IX509Store certs...
+                 *      IX509Store crls...
+                 *      CmsSignedDataGenerator gen = new CmsSignedDataGenerator();
+                 *
+                 *      gen.AddSigner(privKey, cert, CmsSignedGenerator.DigestSha1);
+                 *      gen.AddCertificates(certs);
+                 *      gen.AddCrls(crls);
+                 *
+                 *      CmsSignedData data = gen.Generate(content);
+                 * 
+ *

+
+ + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + * add a signer - no attributes other than the default ones will be + * provided here. + * + * @param key signing key to use + * @param cert certificate containing corresponding public key + * @param digestOID digest algorithm OID + + + add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be + provided here. + + @param key signing key to use + @param cert certificate containing corresponding public key + @param encryptionOID digest encryption algorithm OID + @param digestOID digest algorithm OID + + + add a signer - no attributes other than the default ones will be + provided here. + + + add a signer, specifying the digest encryption algorithm to use - no attributes other than the default ones will be + provided here. + + + * add a signer with extra signed/unsigned attributes. + * + * @param key signing key to use + * @param cert certificate containing corresponding public key + * @param digestOID digest algorithm OID + * @param signedAttr table of attributes to be included in signature + * @param unsignedAttr table of attributes to be included as unsigned + + + add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes. + + @param key signing key to use + @param cert certificate containing corresponding public key + @param encryptionOID digest encryption algorithm OID + @param digestOID digest algorithm OID + @param signedAttr table of attributes to be included in signature + @param unsignedAttr table of attributes to be included as unsigned + + + * add a signer with extra signed/unsigned attributes. + * + * @param key signing key to use + * @param subjectKeyID subjectKeyID of corresponding public key + * @param digestOID digest algorithm OID + * @param signedAttr table of attributes to be included in signature + * @param unsignedAttr table of attributes to be included as unsigned + + + add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes. + + @param key signing key to use + @param subjectKeyID subjectKeyID of corresponding public key + @param encryptionOID digest encryption algorithm OID + @param digestOID digest algorithm OID + @param signedAttr table of attributes to be included in signature + @param unsignedAttr table of attributes to be included as unsigned + + + add a signer with extra signed/unsigned attributes based on generators. + + + add a signer, specifying the digest encryption algorithm, with extra signed/unsigned attributes based on generators. + + + add a signer with extra signed/unsigned attributes based on generators. + + + add a signer, including digest encryption algorithm, with extra signed/unsigned attributes based on generators. + + + generate a signed object that for a CMS Signed Data object + + + generate a signed object that for a CMS Signed Data + object - if encapsulate is true a copy + of the message will be included in the signature. The content type + is set according to the OID represented by the string signedContentType. + + + generate a signed object that for a CMS Signed Data + object - if encapsulate is true a copy + of the message will be included in the signature with the + default content type "data". + + + generate a set of one or more SignerInformation objects representing counter signatures on + the passed in SignerInformation object. + + @param signer the signer to be countersigned + @param sigProvider the provider to be used for counter signing. + @return a store containing the signers. + + + Parsing class for an CMS Signed Data object from an input stream. +

+ Note: that because we are in a streaming mode only one signer can be tried and it is important + that the methods on the parser are called in the appropriate order. +

+

+ A simple example of usage for an encapsulated signature. +

+

+ Two notes: first, in the example below the validity of + the certificate isn't verified, just the fact that one of the certs + matches the given signer, and, second, because we are in a streaming + mode the order of the operations is important. +

+
+                  CmsSignedDataParser     sp = new CmsSignedDataParser(encapSigData);
+            
+                  sp.GetSignedContent().Drain();
+            
+                  IX509Store              certs = sp.GetCertificates();
+                  SignerInformationStore  signers = sp.GetSignerInfos();
+            
+                  foreach (SignerInformation signer in signers.GetSigners())
+                  {
+                      ArrayList       certList = new ArrayList(certs.GetMatches(signer.SignerID));
+                      X509Certificate cert = (X509Certificate) certList[0];
+            
+                      Console.WriteLine("verify returns: " + signer.Verify(cert));
+                  }
+             
+ Note also: this class does not introduce buffering - if you are processing large files you should create + the parser with: +
+                      CmsSignedDataParser     ep = new CmsSignedDataParser(new BufferedInputStream(encapSigData, bufSize));
+              
+ where bufSize is a suitably large buffer size. +
+ + base constructor - with encapsulated content + + + base constructor + + @param signedContent the content that was signed. + @param sigData the signature object. + + + Return the version number for the SignedData object + + @return the version number + + + return the collection of signers that are associated with the + signatures for the message. + @throws CmsException + + + return a X509Store containing the attribute certificates, if any, contained + in this message. + + @param type type of store to create + @return a store of attribute certificates + @exception org.bouncycastle.x509.NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + return a X509Store containing the public key certificates, if any, contained + in this message. + + @param type type of store to create + @return a store of public key certificates + @exception NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + return a X509Store containing CRLs, if any, contained + in this message. + + @param type type of store to create + @return a store of CRLs + @exception NoSuchStoreException if the store type isn't available. + @exception CmsException if a general exception prevents creation of the X509Store + + + + Return the DerObjectIdentifier associated with the encapsulated + content info structure carried in the signed data. + + + + Replace the signerinformation store associated with the passed + in message contained in the stream original with the new one passed in. + You would probably only want to do this if you wanted to change the unsigned + attributes associated with a signer, or perhaps delete one. +

+ The output stream is returned unclosed. +

+ @param original the signed data stream to be used as a base. + @param signerInformationStore the new signer information store to use. + @param out the stream to Write the new signed data object to. + @return out. +
+ + Replace the certificate and CRL information associated with this + CMSSignedData object with the new one passed in. +

+ The output stream is returned unclosed. +

+ @param original the signed data stream to be used as a base. + @param certsAndCrls the new certificates and CRLs to be used. + @param out the stream to Write the new signed data object to. + @return out. + @exception CmsException if there is an error processing the CertStore +
+ + General class for generating a pkcs7-signature message stream. +

+ A simple example of usage. +

+
+                  IX509Store                   certs...
+                  CmsSignedDataStreamGenerator gen = new CmsSignedDataStreamGenerator();
+            
+                  gen.AddSigner(privateKey, cert, CmsSignedDataStreamGenerator.DIGEST_SHA1);
+            
+                  gen.AddCertificates(certs);
+            
+                  Stream sigOut = gen.Open(bOut);
+            
+                  sigOut.Write(Encoding.UTF8.GetBytes("Hello World!"));
+            
+                  sigOut.Close();
+             
+
+ + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + Set the underlying string size for encapsulated data + + @param bufferSize length of octet strings to buffer the data. + + + add a signer - no attributes other than the default ones will be + provided here. + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer, specifying the digest encryption algorithm - no attributes other than the default ones will be + provided here. + @throws NoSuchProviderException + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer with extra signed/unsigned attributes. + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer with extra signed/unsigned attributes - specifying digest + encryption algorithm. + @throws NoSuchProviderException + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer - no attributes other than the default ones will be + provided here. + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer - no attributes other than the default ones will be + provided here. + @throws NoSuchProviderException + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + add a signer with extra signed/unsigned attributes. + @throws NoSuchAlgorithmException + @throws InvalidKeyException + + + generate a signed object that for a CMS Signed Data object + + + generate a signed object that for a CMS Signed Data + object - if encapsulate is true a copy + of the message will be included in the signature with the + default content type "data". + + + generate a signed object that for a CMS Signed Data + object using the given provider - if encapsulate is true a copy + of the message will be included in the signature with the + default content type "data". If dataOutputStream is non null the data + being signed will be written to the stream as it is processed. + @param out stream the CMS object is to be written to. + @param encapsulate true if data should be encapsulated. + @param dataOutputStream output stream to copy the data being signed to. + + + generate a signed object that for a CMS Signed Data + object - if encapsulate is true a copy + of the message will be included in the signature. The content type + is set according to the OID represented by the string signedContentType. + + + generate a signed object that for a CMS Signed Data + object using the given provider - if encapsulate is true a copy + of the message will be included in the signature. The content type + is set according to the OID represented by the string signedContentType. + @param out stream the CMS object is to be written to. + @param signedContentType OID for data to be signed. + @param encapsulate true if data should be encapsulated. + @param dataOutputStream output stream to copy the data being signed to. + + + Default type for the signed data. + + + Constructor allowing specific source of randomness + Instance of SecureRandom to use. + + + Add the attribute certificates contained in the passed in store to the + generator. + + @param store a store of Version 2 attribute certificates + @throws CmsException if an error occurse processing the store. + + + Add a store of precalculated signers to the generator. + + @param signerStore store of signers + + + Return a map of oids and byte arrays representing the digests calculated on the content during + the last generate. + + @return a map of oids (as String objects) and byte[] representing digests. + + + Return the digest algorithm using one of the standard JCA string + representations rather than the algorithm identifier (if possible). + + + Return the digest encryption algorithm using one of the standard + JCA string representations rather than the algorithm identifier (if + possible). + + + Default authenticated attributes generator. + + + Initialise to use all defaults + + + Initialise with some extra attributes or overrides. + + @param attributeTable initial attribute table to use. + + + Create a standard attribute table from the passed in parameters - this will + normally include contentType and messageDigest. If the constructor + using an AttributeTable was used, entries in it for contentType and + messageDigest will override the generated ones. + + @param parameters source parameters for table generation. + + @return a filled in IDictionary of attributes. + + + @param parameters source parameters + @return the populated attribute table + + + Default signed attributes generator. + + + Initialise to use all defaults + + + Initialise with some extra attributes or overrides. + + @param attributeTable initial attribute table to use. + + + Create a standard attribute table from the passed in parameters - this will + normally include contentType, signingTime, and messageDigest. If the constructor + using an AttributeTable was used, entries in it for contentType, signingTime, and + messageDigest will override the generated ones. + + @param parameters source parameters for table generation. + + @return a filled in Hashtable of attributes. + + + @param parameters source parameters + @return the populated attribute table + + + the RecipientInfo class for a recipient who has been sent a message + encrypted using a secret key known to the other side. + + + decrypt the content and return an input stream. + + + the RecipientInfo class for a recipient who has been sent a message + encrypted using key agreement. + + + decrypt the content and return an input stream. + + + the KeyTransRecipientInformation class for a recipient who has been sent a secret + key encrypted using their public key that needs to be used to + extract the message. + + + decrypt the content and return it as a byte array. + + + a basic index for an originator. + + + the RecipientInfo class for a recipient who has been sent a message + encrypted using a password. + + + return the object identifier for the key derivation algorithm, or null + if there is none present. + + @return OID for key derivation algorithm, if present. + + + decrypt the content and return an input stream. + + + + PKCS5 scheme-2 - password converted to bytes assuming ASCII. + + + + PKCS5 scheme-2 - password converted to bytes using UTF-8. + + + + Generate a RecipientInfo object for the given key. + + + A + + + A + + + A + + + + + * return the object identifier for the key encryption algorithm. + * + * @return OID for key encryption algorithm. + + + * return the ASN.1 encoded key encryption algorithm parameters, or null if + * there aren't any. + * + * @return ASN.1 encoding of key encryption algorithm parameters. + + + Return the MAC calculated for the content stream. Note: this call is only meaningful once all + the content has been read. + + @return byte array containing the mac. + + + Return the first RecipientInformation object that matches the + passed in selector. Null if there are no matches. + + @param selector to identify a recipient + @return a single RecipientInformation object. Null if none matches. + + + Return the number of recipients in the collection. + + @return number of recipients identified. + + + Return all recipients in the collection + + @return a collection of recipients. + + + Return possible empty collection with recipients matching the passed in RecipientID + + @param selector a recipient id to select against. + @return a collection of RecipientInformation objects. + + + a basic index for a signer. + + + an expanded SignerInfo block from a CMS Signed message + + + return the version number for this objects underlying SignerInfo structure. + + + return the object identifier for the signature. + + + return the signature parameters, or null if there aren't any. + + + return the content digest that was calculated during verification. + + + return the object identifier for the signature. + + + return the signature/encryption algorithm parameters, or null if + there aren't any. + + + return a table of the signed attributes - indexed by + the OID of the attribute. + + + return a table of the unsigned attributes indexed by + the OID of the attribute. + + + return the encoded signature + + + Return a SignerInformationStore containing the counter signatures attached to this + signer. If no counter signatures are present an empty store is returned. + + + return the DER encoding of the signed attributes. + @throws IOException if an encoding error occurs. + + + verify that the given public key successfully handles and confirms the + signature associated with this signer. + + + verify that the given certificate successfully handles and confirms + the signature associated with this signer and, if a signingTime + attribute is available, that the certificate was valid at the time the + signature was generated. + + + Return the base ASN.1 CMS structure that this object contains. + + @return an object containing a CMS SignerInfo structure. + + + Return a signer information object with the passed in unsigned + attributes replacing the ones that are current associated with + the object passed in. + + @param signerInformation the signerInfo to be used as the basis. + @param unsignedAttributes the unsigned attributes to add. + @return a copy of the original SignerInformationObject with the changed attributes. + + + Return a signer information object with passed in SignerInformationStore representing counter + signatures attached as an unsigned attribute. + + @param signerInformation the signerInfo to be used as the basis. + @param counterSigners signer info objects carrying counter signature. + @return a copy of the original SignerInformationObject with the changed attributes. + + + Return the first SignerInformation object that matches the + passed in selector. Null if there are no matches. + + @param selector to identify a signer + @return a single SignerInformation object. Null if none matches. + + + The number of signers in the collection. + + + An ICollection of all signers in the collection + + + Return possible empty collection with signers matching the passed in SignerID + + @param selector a signer id to select against. + @return a collection of SignerInformation objects. + + + Basic generator that just returns a preconstructed attribute table + + + a Diffie-Hellman key exchange engine. +

+ note: This uses MTI/A0 key agreement in order to make the key agreement + secure against passive attacks. If you're doing Diffie-Hellman and both + parties have long term public keys you should look at using this. For + further information have a look at RFC 2631.

+

+ It's possible to extend this to more than two parties as well, for the moment + that is left as an exercise for the reader.

+
+ + calculate our initial message. + + + given a message from a given party and the corresponding public key + calculate the next message in the agreement sequence. In this case + this will represent the shared secret. + + + a Diffie-Hellman key agreement class. +

+ note: This is only the basic algorithm, it doesn't take advantage of + long term public keys if they are available. See the DHAgreement class + for a "better" implementation.

+
+ + given a short term public key from a given party calculate the next + message in the agreement sequence. + + + P1363 7.2.1 ECSVDP-DH + + ECSVDP-DH is Elliptic Curve Secret Value Derivation Primitive, + Diffie-Hellman version. It is based on the work of [DH76], [Mil86], + and [Kob87]. This primitive derives a shared secret value from one + party's private key and another party's public key, where both have + the same set of EC domain parameters. If two parties correctly + execute this primitive, they will produce the same output. This + primitive can be invoked by a scheme to derive a shared secret key; + specifically, it may be used with the schemes ECKAS-DH1 and + DL/ECKAS-DH2. It assumes that the input keys are valid (see also + Section 7.2.2). + + + P1363 7.2.2 ECSVDP-DHC + + ECSVDP-DHC is Elliptic Curve Secret Value Derivation Primitive, + Diffie-Hellman version with cofactor multiplication. It is based on + the work of [DH76], [Mil86], [Kob87], [LMQ98] and [Kal98a]. This + primitive derives a shared secret value from one party's private key + and another party's public key, where both have the same set of EC + domain parameters. If two parties correctly execute this primitive, + they will produce the same output. This primitive can be invoked by a + scheme to derive a shared secret key; specifically, it may be used + with the schemes ECKAS-DH1 and DL/ECKAS-DH2. It does not assume the + validity of the input public key (see also Section 7.2.1). +

+ Note: As stated P1363 compatibility mode with ECDH can be preset, and + in this case the implementation doesn't have a ECDH compatibility mode + (if you want that just use ECDHBasicAgreement and note they both implement + BasicAgreement!).

+
+ + RFC 2631 Diffie-hellman KEK derivation function. + + + X9.63 based key derivation function for ECDH CMS. + + + Implements the client side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe. + This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper + "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002" + + + Initialises the client to begin new authentication attempt + @param N The safe prime associated with the client's verifier + @param g The group parameter associated with the client's verifier + @param digest The digest algorithm associated with the client's verifier + @param random For key generation + + + Generates client's credentials given the client's salt, identity and password + @param salt The salt used in the client's verifier. + @param identity The user's identity (eg. username) + @param password The user's password + @return Client's public value to send to server + + + Generates client's verification message given the server's credentials + @param serverB The server's credentials + @return Client's verification message for the server + @throws CryptoException If server's credentials are invalid + + + Implements the server side SRP-6a protocol. Note that this class is stateful, and therefore NOT threadsafe. + This implementation of SRP is based on the optimized message sequence put forth by Thomas Wu in the paper + "SRP-6: Improvements and Refinements to the Secure Remote Password Protocol, 2002" + + + Initialises the server to accept a new client authentication attempt + @param N The safe prime associated with the client's verifier + @param g The group parameter associated with the client's verifier + @param v The client's verifier + @param digest The digest algorithm associated with the client's verifier + @param random For key generation + + + Generates the server's credentials that are to be sent to the client. + @return The server's public value to the client + + + Processes the client's credentials. If valid the shared secret is generated and returned. + @param clientA The client's credentials + @return A shared secret BigInteger + @throws CryptoException If client's credentials are invalid + + + Generates new SRP verifier for user + + + Initialises generator to create new verifiers + @param N The safe prime to use (see DHParametersGenerator) + @param g The group parameter to use (see DHParametersGenerator) + @param digest The digest to use. The same digest type will need to be used later for the actual authentication + attempt. Also note that the final session key size is dependent on the chosen digest. + + + Creates a new SRP verifier + @param salt The salt to use, generally should be large and random + @param identity The user's identifying information (eg. username) + @param password The user's password + @return A new verifier for use in future SRP authentication + + + a holding class for public/private parameter pairs. + + + basic constructor. + + @param publicParam a public key parameters object. + @param privateParam the corresponding private key parameters. + + + return the public key parameters. + + @return the public key parameters. + + + return the private key parameters. + + @return the private key parameters. + + + The AEAD block ciphers already handle buffering internally, so this class + just takes care of implementing IBufferedCipher methods. + + + initialise the cipher. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the blocksize for the underlying cipher. + + @return the blocksize for the underlying cipher. + + + return the size of the output buffer required for an update + an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update + with len bytes of input. + + + return the size of the output buffer required for an update plus a + doFinal with an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update and doFinal + with len bytes of input. + + + process a single byte, producing an output block if neccessary. + + @param in the input byte. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + process an array of bytes, producing output if necessary. + + @param in the input byte array. + @param inOff the offset at which the input data starts. + @param len the number of bytes to be copied out of the input array. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + Process the last block in the buffer. + + @param out the array the block currently being held is copied into. + @param outOff the offset at which the copying starts. + @return the number of output bytes copied to out. + @exception DataLengthException if there is insufficient space in out for + the output, or the input is not block size aligned and should be. + @exception InvalidOperationException if the underlying cipher is not + initialised. + @exception InvalidCipherTextException if padding is expected and not found. + @exception DataLengthException if the input is not block size + aligned. + + + Reset the buffer and cipher. After resetting the object is in the same + state as it was after the last init (if there was one). + + + a buffer wrapper for an asymmetric block cipher, allowing input + to be accumulated in a piecemeal fashion until final processing. + + + base constructor. + + @param cipher the cipher this buffering object wraps. + + + return the amount of data sitting in the buffer. + + @return the amount of data sitting in the buffer. + + + initialise the buffer and the underlying cipher. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + + + process the contents of the buffer using the underlying + cipher. + + @return the result of the encryption/decryption process on the + buffer. + @exception InvalidCipherTextException if we are given a garbage block. + + + Reset the buffer + + + A wrapper class that allows block ciphers to be used to process data in + a piecemeal fashion. The BufferedBlockCipher outputs a block only when the + buffer is full and more data is being added, or on a doFinal. +

+ Note: in the case where the underlying cipher is either a CFB cipher or an + OFB one the last block may not be a multiple of the block size. +

+
+ + constructor for subclasses + + + Create a buffered block cipher without padding. + + @param cipher the underlying block cipher this buffering object wraps. + false otherwise. + + + initialise the cipher. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the blocksize for the underlying cipher. + + @return the blocksize for the underlying cipher. + + + return the size of the output buffer required for an update + an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update + with len bytes of input. + + + return the size of the output buffer required for an update plus a + doFinal with an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update and doFinal + with len bytes of input. + + + process a single byte, producing an output block if neccessary. + + @param in the input byte. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + process an array of bytes, producing output if necessary. + + @param in the input byte array. + @param inOff the offset at which the input data starts. + @param len the number of bytes to be copied out of the input array. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + Process the last block in the buffer. + + @param out the array the block currently being held is copied into. + @param outOff the offset at which the copying starts. + @return the number of output bytes copied to out. + @exception DataLengthException if there is insufficient space in out for + the output, or the input is not block size aligned and should be. + @exception InvalidOperationException if the underlying cipher is not + initialised. + @exception InvalidCipherTextException if padding is expected and not found. + @exception DataLengthException if the input is not block size + aligned. + + + Reset the buffer and cipher. After resetting the object is in the same + state as it was after the last init (if there was one). + + + The base class for symmetric, or secret, cipher key generators. + + + initialise the key generator. + + @param param the parameters to be used for key generation + + + Generate a secret key. + + @return a byte array containing the key value. + + + this exception is thrown if a buffer that is meant to have output + copied into it turns out to be too short, or if we've been given + insufficient input. In general this exception will Get thrown rather + than an ArrayOutOfBounds exception. + + + base constructor. + + + create a DataLengthException with the given message. + + @param message the message to be carried with the exception. + + + base implementation of MD4 family style digest as outlined in + "Handbook of Applied Cryptography", pages 344 - 347. + + + implementation of GOST R 34.11-94 + + + Standard constructor + + + Constructor to allow use of a particular sbox with GOST28147 + @see GOST28147Engine#getSBox(String) + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables to the IV values. + + + Base class for SHA-384 and SHA-512. + + + Constructor for variable length word + + + Copy constructor. We are using copy constructors in place + of the object.Clone() interface as this interface is not + supported by J2ME. + + + adjust the byte counts so that byteCount2 represents the + upper long (less 3 bits) word of the byte count. + + + implementation of MD2 + as outlined in RFC1319 by B.Kaliski from RSA Laboratories April 1992 + + + return the algorithm name + + @return the algorithm name + + + Close the digest, producing the final digest value. The doFinal + call leaves the digest reset. + + @param out the array the digest is to be copied into. + @param outOff the offset into the out array the digest is to start at. + + + reset the digest back to it's initial state. + + + update the message digest with a single byte. + + @param in the input byte to be entered. + + + update the message digest with a block of bytes. + + @param in the byte array containing the data. + @param inOff the offset into the byte array where the data starts. + @param len the length of the data. + + + implementation of MD4 as RFC 1320 by R. Rivest, MIT Laboratory for + Computer Science and RSA Data Security, Inc. +

+ NOTE: This algorithm is only included for backwards compatibility + with legacy applications, it's not secure, don't use it for anything new!

+
+ + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables to the IV values. + + + implementation of MD5 as outlined in "Handbook of Applied Cryptography", pages 346 - 347. + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables to the IV values. + + + implementation of RipeMD128 + + + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables to the IV values. + + + implementation of RipeMD see, + http://www.esat.kuleuven.ac.be/~bosselae/ripemd160.html + + + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables to the IV values. + + + +

Implementation of RipeMD256.

+

Note: this algorithm offers the same level of security as RipeMD128.

+
+
+ + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + + reset the chaining variables to the IV values. + + + +

Implementation of RipeMD 320.

+

Note: this algorithm offers the same level of security as RipeMD160.

+
+
+ + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + + reset the chaining variables to the IV values. + + + implementation of SHA-1 as outlined in "Handbook of Applied Cryptography", pages 346 - 349. + + It is interesting to ponder why the, apart from the extra IV, the other difference here from MD5 + is the "endienness" of the word processing! + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + SHA-224 as described in RFC 3874 +
+                    block  word  digest
+            SHA-1   512    32    160
+            SHA-224 512    32    224
+            SHA-256 512    32    256
+            SHA-384 1024   64    384
+            SHA-512 1024   64    512
+            
+
+ + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + Draft FIPS 180-2 implementation of SHA-256. Note: As this is + based on a draft this implementation is subject to change. + +
+                     block  word  digest
+             SHA-1   512    32    160
+             SHA-256 512    32    256
+             SHA-384 1024   64    384
+             SHA-512 1024   64    512
+             
+
+ + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + Draft FIPS 180-2 implementation of SHA-384. Note: As this is + based on a draft this implementation is subject to change. + +
+                     block  word  digest
+             SHA-1   512    32    160
+             SHA-256 512    32    256
+             SHA-384 1024   64    384
+             SHA-512 1024   64    512
+             
+
+ + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + Draft FIPS 180-2 implementation of SHA-512. Note: As this is + based on a draft this implementation is subject to change. + +
+                     block  word  digest
+             SHA-1   512    32    160
+             SHA-256 512    32    256
+             SHA-384 1024   64    384
+             SHA-512 1024   64    512
+             
+
+ + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + Wrapper class that reduces the output length of a particular digest to + only the first n bytes of the digest function. + + + Base constructor. + + @param baseDigest underlying digest to use. + @param length length in bytes of the output of doFinal. + @exception ArgumentException if baseDigest is null, or length is greater than baseDigest.GetDigestSize(). + + + implementation of Tiger based on: + + http://www.cs.technion.ac.il/~biham/Reports/Tiger + + + Standard constructor + + + Copy constructor. This will copy the state of the provided + message digest. + + + reset the chaining variables + + + Implementation of WhirlpoolDigest, based on Java source published by Barreto + and Rijmen. + + + + Copy constructor. This will copy the state of the provided message + digest. + + + Reset the chaining variables + + + ISO 9796-1 padding. Note in the light of recent results you should + only use this with RSA (rather than the "simpler" Rabin keys) and you + should never use it with anything other than a hash (ie. even if the + message is small don't sign the message, sign it's hash) or some "random" + value. See your favorite search engine for details. + + + return the input block size. The largest message we can process + is (key_size_in_bits + 3)/16, which in our world comes to + key_size_in_bytes / 2. + + + return the maximum possible size for the output. + + + set the number of bits in the next message to be treated as + pad bits. + + + retrieve the number of pad bits in the last decoded message. + + + @exception InvalidCipherTextException if the decrypted block is not a valid ISO 9796 bit string + + + Optimal Asymmetric Encryption Padding (OAEP) - see PKCS 1 V 2. + + + @exception InvalidCipherTextException if the decrypted block turns out to + be badly formatted. + + + int to octet string. + + + mask generator function, as described in PKCS1v2. + + + this does your basic Pkcs 1 v1.5 padding - whether or not you should be using this + depends on your application - see Pkcs1 Version 2 for details. + + + some providers fail to include the leading zero in PKCS1 encoded blocks. If you need to + work with one of these set the system property Org.BouncyCastle.Pkcs1.Strict to false. + + + The same effect can be achieved by setting the static property directly +

+ The static property is checked during construction of the encoding object, it is set to + true by default. +

+
+ + Basic constructor. + @param cipher + + + @exception InvalidCipherTextException if the decrypted block is not in Pkcs1 format. + + + an implementation of the AES (Rijndael), from FIPS-197. +

+ For further details see: http://csrc.nist.gov/encryption/aes/. + + This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at + http://fp.gladman.plus.com/cryptography_technology/rijndael/ + + There are three levels of tradeoff of speed vs memory + Because java has no preprocessor, they are written as three separate classes from which to choose + + The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption + and 4 for decryption. + + The middle performance version uses only one 256 word table for each, for a total of 2Kbytes, + adding 12 rotate operations per round to compute the values contained in the other tables from + the contents of the first. + + The slowest version uses no static tables at all and computes the values in each round. +

+

+ This file contains the middle performance version with 2Kbytes of static tables for round precomputation. +

+
+ + Calculate the necessary round keys + The number of calculations depends on key size and block size + AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits + This code is written assuming those are the only possible values + + + default constructor - 128 bit block size. + + + initialise an AES cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + an implementation of the AES (Rijndael)), from FIPS-197. +

+ For further details see: http://csrc.nist.gov/encryption/aes/. + + This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at + http://fp.gladman.plus.com/cryptography_technology/rijndael/ + + There are three levels of tradeoff of speed vs memory + Because java has no preprocessor), they are written as three separate classes from which to choose + + The fastest uses 8Kbytes of static tables to precompute round calculations), 4 256 word tables for encryption + and 4 for decryption. + + The middle performance version uses only one 256 word table for each), for a total of 2Kbytes), + adding 12 rotate operations per round to compute the values contained in the other tables from + the contents of the first + + The slowest version uses no static tables at all and computes the values in each round +

+

+ This file contains the fast version with 8Kbytes of static tables for round precomputation +

+
+ + Calculate the necessary round keys + The number of calculations depends on key size and block size + AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits + This code is written assuming those are the only possible values + + + default constructor - 128 bit block size. + + + initialise an AES cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + an implementation of the AES (Rijndael), from FIPS-197. +

+ For further details see: http://csrc.nist.gov/encryption/aes/. + + This implementation is based on optimizations from Dr. Brian Gladman's paper and C code at + http://fp.gladman.plus.com/cryptography_technology/rijndael/ + + There are three levels of tradeoff of speed vs memory + Because java has no preprocessor, they are written as three separate classes from which to choose + + The fastest uses 8Kbytes of static tables to precompute round calculations, 4 256 word tables for encryption + and 4 for decryption. + + The middle performance version uses only one 256 word table for each, for a total of 2Kbytes, + adding 12 rotate operations per round to compute the values contained in the other tables from + the contents of the first + + The slowest version uses no static tables at all and computes the values + in each round. +

+

+ This file contains the slowest performance version with no static tables + for round precomputation, but it has the smallest foot print. +

+
+ + Calculate the necessary round keys + The number of calculations depends on key size and block size + AES specified a fixed block size of 128 bits and key sizes 128/192/256 bits + This code is written assuming those are the only possible values + + + default constructor - 128 bit block size. + + + initialise an AES cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + + An implementation of the AES Key Wrapper from the NIST Key Wrap Specification. +

+ For further details see: http://csrc.nist.gov/encryption/kms/key-wrap.pdf. + + + + A class that provides Blowfish key encryption operations, + such as encoding data and generating keys. + All the algorithms herein are from Applied Cryptography + and implement a simplified cryptography interface. + + + initialise a Blowfish cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + apply the encryption cycle to each value pair in the table. + + + Encrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + The input will be an exact multiple of our blocksize. + + + Decrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + The input will be an exact multiple of our blocksize. + + + Camellia - based on RFC 3713. + + + Camellia - based on RFC 3713, smaller implementation, about half the size of CamelliaEngine. + + + + An implementation of the Camellia key wrapper based on RFC 3657/RFC 3394. +

+ For further details see: http://www.ietf.org/rfc/rfc3657.txt. + + + + A class that provides CAST key encryption operations, + such as encoding data and generating keys. + + All the algorithms herein are from the Internet RFC's + + RFC2144 - Cast5 (64bit block, 40-128bit key) + RFC2612 - CAST6 (128bit block, 128-256bit key) + + and implement a simplified cryptography interface. + + + initialise a CAST cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Encrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param src The plaintext buffer + @param srcIndex An offset into src + @param dst The ciphertext buffer + @param dstIndex An offset into dst + + + Decrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param src The plaintext buffer + @param srcIndex An offset into src + @param dst The ciphertext buffer + @param dstIndex An offset into dst + + + The first of the three processing functions for the + encryption and decryption. + + @param D the input to be processed + @param Kmi the mask to be used from Km[n] + @param Kri the rotation value to be used + + + + The second of the three processing functions for the + encryption and decryption. + + @param D the input to be processed + @param Kmi the mask to be used from Km[n] + @param Kri the rotation value to be used + + + + The third of the three processing functions for the + encryption and decryption. + + @param D the input to be processed + @param Kmi the mask to be used from Km[n] + @param Kri the rotation value to be used + + + + Does the 16 rounds to encrypt the block. + + @param L0 the LH-32bits of the plaintext block + @param R0 the RH-32bits of the plaintext block + + + A class that provides CAST6 key encryption operations, + such as encoding data and generating keys. + + All the algorithms herein are from the Internet RFC + + RFC2612 - CAST6 (128bit block, 128-256bit key) + + and implement a simplified cryptography interface. + + + Encrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param src The plaintext buffer + @param srcIndex An offset into src + @param dst The ciphertext buffer + @param dstIndex An offset into dst + + + Decrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param src The plaintext buffer + @param srcIndex An offset into src + @param dst The ciphertext buffer + @param dstIndex An offset into dst + + + Does the 12 quad rounds rounds to encrypt the block. + + @param A the 00-31 bits of the plaintext block + @param B the 32-63 bits of the plaintext block + @param C the 64-95 bits of the plaintext block + @param D the 96-127 bits of the plaintext block + @param result the resulting ciphertext + + + Does the 12 quad rounds rounds to decrypt the block. + + @param A the 00-31 bits of the ciphertext block + @param B the 32-63 bits of the ciphertext block + @param C the 64-95 bits of the ciphertext block + @param D the 96-127 bits of the ciphertext block + @param result the resulting plaintext + + + A class that provides a basic DESede (or Triple DES) engine. + + + initialise a DESede cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + * Wrap keys according to + * + * draft-ietf-smime-key-wrap-01.txt. + *

+ * Note: + *

    + *
  • this is based on a draft, and as such is subject to change - don't use this class for anything requiring long term storage.
  • + *
  • if you are using this to wrap triple-des keys you need to set the + * parity bits on the key and, if it's a two-key triple-des key, pad it + * yourself.
  • + *
+ *

+
+ + Field engine + + + Field param + + + Field paramPlusIV + + + Field iv + + + Field forWrapping + + + Field IV2 + + + Method init + + @param forWrapping + @param param + + + Method GetAlgorithmName + + @return + + + Method wrap + + @param in + @param inOff + @param inLen + @return + + + Method unwrap + + @param in + @param inOff + @param inLen + @return + @throws InvalidCipherTextException + + + Some key wrap algorithms make use of the Key Checksum defined + in CMS [CMS-Algorithms]. This is used to provide an integrity + check value for the key being wrapped. The algorithm is + + - Compute the 20 octet SHA-1 hash on the key being wrapped. + - Use the first 8 octets of this hash as the checksum value. + + @param key + @return + @throws Exception + @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum + + + @param key + @param checksum + @return + @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum + + + A class that provides a basic DES engine. + + + initialise a DES cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + what follows is mainly taken from "Applied Cryptography", by + Bruce Schneier, however it also bears great resemblance to Richard + Outerbridge's D3DES... + + + Generate an integer based working key based on our secret key + and what we processing we are planning to do. + + Acknowledgements for this routine go to James Gillogly and Phil Karn. + (whoever, and wherever they are!). + + + the DES engine. + + + this does your basic ElGamal algorithm. + + + initialise the ElGamal engine. + + @param forEncryption true if we are encrypting, false otherwise. + @param param the necessary ElGamal key parameters. + + + Return the maximum size for an input block to this engine. + For ElGamal this is always one byte less than the size of P on + encryption, and twice the length as the size of P on decryption. + + @return maximum size for an input block. + + + Return the maximum size for an output block to this engine. + For ElGamal this is always one byte less than the size of P on + decryption, and twice the length as the size of P on encryption. + + @return maximum size for an output block. + + + Process a single block using the basic ElGamal algorithm. + + @param in the input array. + @param inOff the offset into the input buffer where the data starts. + @param length the length of the data to be processed. + @return the result of the ElGamal process. + @exception DataLengthException the input block is too large. + + + implementation of GOST 28147-89 + + + standard constructor. + + + initialise an Gost28147 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is inappropriate. + + + Return the S-Box associated with SBoxName + @param sBoxName name of the S-Box + @return byte array representing the S-Box + + + HC-128 is a software-efficient stream cipher created by Hongjun Wu. It + generates keystream from a 128-bit secret key and a 128-bit initialization + vector. +

+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc128_p3.pdf +

+ It is a third phase candidate in the eStream contest, and is patent-free. + No attacks are known as of today (April 2007). See + + http://www.ecrypt.eu.org/stream/hcp3.html +

+
+ + Initialise a HC-128 cipher. + + @param forEncryption whether or not we are for encryption. Irrelevant, as + encryption and decryption are the same. + @param params the parameters required to set up the cipher. + @throws ArgumentException if the params argument is + inappropriate (ie. the key is not 128 bit long). + + + HC-256 is a software-efficient stream cipher created by Hongjun Wu. It + generates keystream from a 256-bit secret key and a 256-bit initialization + vector. +

+ http://www.ecrypt.eu.org/stream/p3ciphers/hc/hc256_p3.pdf +

+ Its brother, HC-128, is a third phase candidate in the eStream contest. + The algorithm is patent-free. No attacks are known as of today (April 2007). + See + + http://www.ecrypt.eu.org/stream/hcp3.html +

+
+ + Initialise a HC-256 cipher. + + @param forEncryption whether or not we are for encryption. Irrelevant, as + encryption and decryption are the same. + @param params the parameters required to set up the cipher. + @throws ArgumentException if the params argument is + inappropriate (ie. the key is not 256 bit long). + + + support class for constructing intergrated encryption ciphers + for doing basic message exchanges on top of key agreement ciphers + + + set up for use with stream mode, where the key derivation function + is used to provide a stream of bytes to xor with the message. + + @param agree the key agreement used as the basis for the encryption + @param kdf the key derivation function used for byte generation + @param mac the message authentication code generator for the message + + + set up for use in conjunction with a block cipher to handle the + message. + + @param agree the key agreement used as the basis for the encryption + @param kdf the key derivation function used for byte generation + @param mac the message authentication code generator for the message + @param cipher the cipher to used for encrypting the message + + + Initialise the encryptor. + + @param forEncryption whether or not this is encryption/decryption. + @param privParam our private key parameters + @param pubParam the recipient's/sender's public key parameters + @param param encoding and derivation parameters. + + + Implementation of Bob Jenkin's ISAAC (Indirection Shift Accumulate Add and Count). + see: http://www.burtleburtle.net/bob/rand/isaacafa.html + + + initialise an ISAAC cipher. + + @param forEncryption whether or not we are for encryption. + @param params the parameters required to set up the cipher. + @exception ArgumentException if the params argument is + inappropriate. + + + NaccacheStern Engine. For details on this cipher, please see + http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf + + + Initializes this algorithm. Must be called before all other Functions. + + @see org.bouncycastle.crypto.AsymmetricBlockCipher#init(bool, + org.bouncycastle.crypto.CipherParameters) + + + Returns the input block size of this algorithm. + + @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetInputBlockSize() + + + Returns the output block size of this algorithm. + + @see org.bouncycastle.crypto.AsymmetricBlockCipher#GetOutputBlockSize() + + + Process a single Block using the Naccache-Stern algorithm. + + @see org.bouncycastle.crypto.AsymmetricBlockCipher#ProcessBlock(byte[], + int, int) + + + Encrypts a BigInteger aka Plaintext with the public key. + + @param plain + The BigInteger to encrypt + @return The byte[] representation of the encrypted BigInteger (i.e. + crypted.toByteArray()) + + + Adds the contents of two encrypted blocks mod sigma + + @param block1 + the first encrypted block + @param block2 + the second encrypted block + @return encrypt((block1 + block2) mod sigma) + @throws InvalidCipherTextException + + + Convenience Method for data exchange with the cipher. + + Determines blocksize and splits data to blocksize. + + @param data the data to be processed + @return the data after it went through the NaccacheSternEngine. + @throws InvalidCipherTextException + + + Computes the integer x that is expressed through the given primes and the + congruences with the chinese remainder theorem (CRT). + + @param congruences + the congruences c_i + @param primes + the primes p_i + @return an integer x for that x % p_i == c_i + + + A Noekeon engine, using direct-key mode. + + + Create an instance of the Noekeon encryption algorithm + and set some defaults + + + initialise + + @param forEncryption whether or not we are for encryption. + @param params the parameters required to set up the cipher. + @exception ArgumentException if the params argument is + inappropriate. + + + Re-key the cipher. + + @param key the key to be used + + + The no-op engine that just copies bytes through, irrespective of whether encrypting and decrypting. + Provided for the sake of completeness. + + + an implementation of RC2 as described in RFC 2268 + "A Description of the RC2(r) Encryption Algorithm" R. Rivest. + + + initialise a RC2 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the result rotating the 16 bit number in x left by y + + + Wrap keys according to RFC 3217 - RC2 mechanism + + + Field engine + + + Field param + + + Field paramPlusIV + + + Field iv + + + Field forWrapping + + + Field IV2 + + + Method init + + @param forWrapping + @param param + + + Method GetAlgorithmName + + @return + + + Method wrap + + @param in + @param inOff + @param inLen + @return + + + Method unwrap + + @param in + @param inOff + @param inLen + @return + @throws InvalidCipherTextException + + + Some key wrap algorithms make use of the Key Checksum defined + in CMS [CMS-Algorithms]. This is used to provide an integrity + check value for the key being wrapped. The algorithm is + + - Compute the 20 octet SHA-1 hash on the key being wrapped. + - Use the first 8 octets of this hash as the checksum value. + + @param key + @return + @throws Exception + @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum + + + @param key + @param checksum + @return + @see http://www.w3.org/TR/xmlenc-core/#sec-CMSKeyChecksum + + + initialise a RC4 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + The specification for RC5 came from the RC5 Encryption Algorithm + publication in RSA CryptoBytes, Spring of 1995. + http://www.rsasecurity.com/rsalabs/cryptobytes. +

+ This implementation has a word size of 32 bits.

+
+ + Create an instance of the RC5 encryption algorithm + and set some defaults + + + initialise a RC5-32 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Re-key the cipher. + + @param key the key to be used + + + Encrypt the given block starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param in in byte buffer containing data to encrypt + @param inOff offset into src buffer + @param out out buffer where encrypted data is written + @param outOff offset into out buffer + + + Perform a left "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(32) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % 32 + + + Perform a right "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(32) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % 32 + + + The specification for RC5 came from the RC5 Encryption Algorithm + publication in RSA CryptoBytes, Spring of 1995. + http://www.rsasecurity.com/rsalabs/cryptobytes. +

+ This implementation is set to work with a 64 bit word size.

+
+ + Create an instance of the RC5 encryption algorithm + and set some defaults + + + initialise a RC5-64 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Re-key the cipher. + + @param key the key to be used + + + Encrypt the given block starting at the given offset and place + the result in the provided buffer starting at the given offset. + + @param in in byte buffer containing data to encrypt + @param inOff offset into src buffer + @param out out buffer where encrypted data is written + @param outOff offset into out buffer + + + Perform a left "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(wordSize) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % wordSize + + + Perform a right "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(wordSize) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % wordSize + + + An RC6 engine. + + + Create an instance of the RC6 encryption algorithm + and set some defaults + + + initialise a RC5-32 cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Re-key the cipher. + + @param inKey the key to be used + + + Perform a left "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(wordSize) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % wordSize + + + Perform a right "spin" of the word. The rotation of the given + word x is rotated left by y bits. + Only the lg(wordSize) low-order bits of y + are used to determine the rotation amount. Here it is + assumed that the wordsize used is a power of 2. + + @param x word to rotate + @param y number of bits to rotate % wordSize + + + an implementation of the RFC 3211 Key Wrap + Specification. + + + + An implementation of the AES Key Wrapper from the NIST Key Wrap + Specification as described in RFC 3394. +

+ For further details see: http://www.ietf.org/rfc/rfc3394.txt + and http://csrc.nist.gov/encryption/kms/key-wrap.pdf. + + + + an implementation of Rijndael, based on the documentation and reference implementation + by Paulo Barreto, Vincent Rijmen, for v2.0 August '99. +

+ Note: this implementation is based on information prior to readonly NIST publication. +

+
+ + multiply two elements of GF(2^m) + needed for MixColumn and InvMixColumn + + + xor corresponding text input and round key input bytes + + + Row 0 remains unchanged + The other three rows are shifted a variable amount + + + Replace every byte of the input by the byte at that place + in the nonlinear S-box + + + Mix the bytes of every column in a linear way + + + Mix the bytes of every column in a linear way + This is the opposite operation of Mixcolumn + + + Calculate the necessary round keys + The number of calculations depends on keyBits and blockBits + + + default constructor - 128 bit block size. + + + basic constructor - set the cipher up for a given blocksize + + @param blocksize the blocksize in bits, must be 128, 192, or 256. + + + initialise a Rijndael cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + this does your basic RSA algorithm with blinding + + + initialise the RSA engine. + + @param forEncryption true if we are encrypting, false otherwise. + @param param the necessary RSA key parameters. + + + Return the maximum size for an input block to this engine. + For RSA this is always one byte less than the key size on + encryption, and the same length as the key size on decryption. + + @return maximum size for an input block. + + + Return the maximum size for an output block to this engine. + For RSA this is always one byte less than the key size on + decryption, and the same length as the key size on encryption. + + @return maximum size for an output block. + + + Process a single block using the basic RSA algorithm. + + @param inBuf the input array. + @param inOff the offset into the input buffer where the data starts. + @param inLen the length of the data to be processed. + @return the result of the RSA process. + @exception DataLengthException the input block is too large. + + + This does your basic RSA Chaum's blinding and unblinding as outlined in + "Handbook of Applied Cryptography", page 475. You need to use this if you are + trying to get another party to generate signatures without them being aware + of the message they are signing. + + + Initialise the blinding engine. + + @param forEncryption true if we are encrypting (blinding), false otherwise. + @param param the necessary RSA key parameters. + + + Return the maximum size for an input block to this engine. + For RSA this is always one byte less than the key size on + encryption, and the same length as the key size on decryption. + + @return maximum size for an input block. + + + Return the maximum size for an output block to this engine. + For RSA this is always one byte less than the key size on + decryption, and the same length as the key size on encryption. + + @return maximum size for an output block. + + + Process a single block using the RSA blinding algorithm. + + @param in the input array. + @param inOff the offset into the input buffer where the data starts. + @param inLen the length of the data to be processed. + @return the result of the RSA process. + @throws DataLengthException the input block is too large. + + + this does your basic RSA algorithm. + + + initialise the RSA engine. + + @param forEncryption true if we are encrypting, false otherwise. + @param param the necessary RSA key parameters. + + + Return the maximum size for an input block to this engine. + For RSA this is always one byte less than the key size on + encryption, and the same length as the key size on decryption. + + @return maximum size for an input block. + + + Return the maximum size for an output block to this engine. + For RSA this is always one byte less than the key size on + decryption, and the same length as the key size on encryption. + + @return maximum size for an output block. + + + this does your basic RSA algorithm. + + + initialise the RSA engine. + + @param forEncryption true if we are encrypting, false otherwise. + @param param the necessary RSA key parameters. + + + Return the maximum size for an input block to this engine. + For RSA this is always one byte less than the key size on + encryption, and the same length as the key size on decryption. + + @return maximum size for an input block. + + + Return the maximum size for an output block to this engine. + For RSA this is always one byte less than the key size on + decryption, and the same length as the key size on encryption. + + @return maximum size for an output block. + + + Process a single block using the basic RSA algorithm. + + @param inBuf the input array. + @param inOff the offset into the input buffer where the data starts. + @param inLen the length of the data to be processed. + @return the result of the RSA process. + @exception DataLengthException the input block is too large. + + + Implementation of Daniel J. Bernstein's Salsa20 stream cipher, Snuffle 2005 + + + Constants + + + initialise a Salsa20 cipher. + + @param forEncryption whether or not we are for encryption. + @param params the parameters required to set up the cipher. + @exception ArgumentException if the params argument is + inappropriate. + + + Implementation of the SEED algorithm as described in RFC 4009 + + + + An implementation of the SEED key wrapper based on RFC 4010/RFC 3394. +

+ For further details see: http://www.ietf.org/rfc/rfc4010.txt. + + + + * Serpent is a 128-bit 32-round block cipher with variable key lengths, + * including 128, 192 and 256 bit keys conjectured to be at least as + * secure as three-key triple-DES. + *

+ * Serpent was designed by Ross Anderson, Eli Biham and Lars Knudsen as a + * candidate algorithm for the NIST AES Quest.> + *

+ *

+ * For full details see the The Serpent home page + *

+
+ + initialise a Serpent cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Expand a user-supplied key material into a session key. + + @param key The user-key bytes (multiples of 4) to use. + @exception ArgumentException + + + Encrypt one block of plaintext. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + + + Decrypt one block of ciphertext. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + + + S0 - { 3, 8,15, 1,10, 6, 5,11,14,13, 4, 2, 7, 0, 9,12 } - 15 terms. + + + InvSO - {13, 3,11, 0,10, 6, 5,12, 1,14, 4, 7,15, 9, 8, 2 } - 15 terms. + + + S1 - {15,12, 2, 7, 9, 0, 5,10, 1,11,14, 8, 6,13, 3, 4 } - 14 terms. + + + InvS1 - { 5, 8, 2,14,15, 6,12, 3,11, 4, 7, 9, 1,13,10, 0 } - 14 steps. + + + S2 - { 8, 6, 7, 9, 3,12,10,15,13, 1,14, 4, 0,11, 5, 2 } - 16 terms. + + + InvS2 - {12, 9,15, 4,11,14, 1, 2, 0, 3, 6,13, 5, 8,10, 7 } - 16 steps. + + + S3 - { 0,15,11, 8,12, 9, 6, 3,13, 1, 2, 4,10, 7, 5,14 } - 16 terms. + + + InvS3 - { 0, 9,10, 7,11,14, 6,13, 3, 5,12, 2, 4, 8,15, 1 } - 15 terms + + + S4 - { 1,15, 8, 3,12, 0,11, 6, 2, 5, 4,10, 9,14, 7,13 } - 15 terms. + + + InvS4 - { 5, 0, 8, 3,10, 9, 7,14, 2,12,11, 6, 4,15,13, 1 } - 15 terms. + + + S5 - {15, 5, 2,11, 4,10, 9,12, 0, 3,14, 8,13, 6, 7, 1 } - 16 terms. + + + InvS5 - { 8,15, 2, 9, 4, 1,13,14,11, 6, 5, 3, 7,12,10, 0 } - 16 terms. + + + S6 - { 7, 2,12, 5, 8, 4, 6,11,14, 9, 1,15,13, 3,10, 0 } - 15 terms. + + + InvS6 - {15,10, 1,13, 5, 3, 6, 0, 4, 9,14, 7, 2,12, 8,11 } - 15 terms. + + + S7 - { 1,13,15, 0,14, 8, 2,11, 7, 4,12,10, 9, 3, 5, 6 } - 16 terms. + + + InvS7 - { 3, 0, 6,13, 9,14,15, 8, 5,12,11, 7,10, 1, 4, 2 } - 17 terms. + + + Apply the linear transformation to the register set. + + + Apply the inverse of the linear transformation to the register set. + + + a class that provides a basic SKIPJACK engine. + + + initialise a SKIPJACK cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + The G permutation + + + the inverse of the G permutation. + + + An TEA engine. + + + Create an instance of the TEA encryption algorithm + and set some defaults + + + initialise + + @param forEncryption whether or not we are for encryption. + @param params the parameters required to set up the cipher. + @exception ArgumentException if the params argument is + inappropriate. + + + Re-key the cipher. + + @param key the key to be used + + + A class that provides Twofish encryption operations. + + This Java implementation is based on the Java reference + implementation provided by Bruce Schneier and developed + by Raif S. Naffah. + + + Define the fixed p0/p1 permutations used in keyed S-box lookup. + By changing the following constant definitions, the S-boxes will + automatically Get changed in the Twofish engine. + + + gSubKeys[] and gSBox[] are eventually used in the + encryption and decryption methods. + + + initialise a Twofish cipher. + + @param forEncryption whether or not we are for encryption. + @param parameters the parameters required to set up the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Encrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + The input will be an exact multiple of our blocksize. + + encryptBlock uses the pre-calculated gSBox[] and subKey[] + arrays. + + + Decrypt the given input starting at the given offset and place + the result in the provided buffer starting at the given offset. + The input will be an exact multiple of our blocksize. + + + Use (12, 8) Reed-Solomon code over GF(256) to produce + a key S-box 32-bit entity from 2 key material 32-bit + entities. + + @param k0 first 32-bit entity + @param k1 second 32-bit entity + @return Remainder polynomial Generated using RS code + + + * Reed-Solomon code parameters: (12,8) reversible code: + *

+ *

+                    * G(x) = x^4 + (a+1/a)x^3 + ax^2 + (a+1/a)x + 1
+                    * 
+ * where a = primitive root of field generator 0x14D + *

+
+ + initialise a VMPC cipher. + + @param forEncryption + whether or not we are for encryption. + @param params + the parameters required to set up the cipher. + @exception ArgumentException + if the params argument is inappropriate. + + + An XTEA engine. + + + Create an instance of the TEA encryption algorithm + and set some defaults + + + initialise + + @param forEncryption whether or not we are for encryption. + @param params the parameters required to set up the cipher. + @exception ArgumentException if the params argument is + inappropriate. + + + Re-key the cipher. + + @param key the key to be used + + + Basic KDF generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033 +
+ This implementation is based on ISO 18033/P1363a. +
+ + Construct a KDF Parameters generator. + + @param counterStart value of counter. + @param digest the digest to be used as the source of derived keys. + + + return the underlying digest. + + + fill len bytes of the output buffer with bytes generated from + the derivation function. + + @throws ArgumentException if the size of the request will cause an overflow. + @throws DataLengthException if the out buffer is too small. + + + initialise the key generator - if strength is set to zero + the key Generated will be 192 bits in size, otherwise + strength can be 128 or 192 (or 112 or 168 if you don't count + parity bits), depending on whether you wish to do 2-key or 3-key + triple DES. + + @param param the parameters to be used for key generation + + + initialise the key generator - if strength is set to zero + the key generated will be 64 bits in size, otherwise + strength can be 64 or 56 bits (if you don't count the parity bits). + + @param param the parameters to be used for key generation + + + a basic Diffie-Hellman key pair generator. + + This generates keys consistent for use with the basic algorithm for + Diffie-Hellman. + + + a Diffie-Hellman key pair generator. + + This generates keys consistent for use in the MTI/A0 key agreement protocol + as described in "Handbook of Applied Cryptography", Pages 516-519. + + + which Generates the p and g values from the given parameters, + returning the DHParameters object. +

+ Note: can take a while...

+
+ + * a DSA key pair generator. + * + * This Generates DSA keys in line with the method described + * in FIPS 186-3 B.1 FFC Key Pair Generation. + + + Generate suitable parameters for DSA, in line with FIPS 186-2. + + + initialise the key generator. + + @param size size of the key (range 2^512 -> 2^1024 - 64 bit increments) + @param certainty measure of robustness of prime (for FIPS 186-2 compliance this should be at least 80). + @param random random byte source. + + + which Generates the p and g values from the given parameters, + returning the DsaParameters object. +

+ Note: can take a while...

+
+ + generate suitable parameters for DSA, in line with + FIPS 186-3 A.1 Generation of the FFC Primes p and q. + + + Given the domain parameters this routine Generates an EC key + pair in accordance with X9.62 section 5.2.1 pages 26, 27. + + + a ElGamal key pair generator. +

+ This Generates keys consistent for use with ElGamal as described in + page 164 of "Handbook of Applied Cryptography".

+
+ + * which Generates the p and g values from the given parameters, + * returning the ElGamalParameters object. + *

+ * Note: can take a while... + *

+
+ + a GOST3410 key pair generator. + This generates GOST3410 keys in line with the method described + in GOST R 34.10-94. + + + generate suitable parameters for GOST3410. + + + initialise the key generator. + + @param size size of the key + @param typeProcedure type procedure A,B = 1; A',B' - else + @param random random byte source. + + + Procedure C + procedure generates the a value from the given p,q, + returning the a value. + + + which generates the p , q and a values from the given parameters, + returning the Gost3410Parameters object. + + + KFD2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033 +
+ This implementation is based on IEEE P1363/ISO 18033. +
+ + Construct a KDF1 byte generator. + + @param digest the digest to be used as the source of derived keys. + + + KDF2 generator for derived keys and ivs as defined by IEEE P1363a/ISO 18033 +
+ This implementation is based on IEEE P1363/ISO 18033. +
+ + Construct a KDF2 bytes generator. Generates key material + according to IEEE P1363 or ISO 18033 depending on the initialisation. + + @param digest the digest to be used as the source of derived keys. + + + Generator for MGF1 as defined in Pkcs 1v2 + + + @param digest the digest to be used as the source of Generated bytes + + + return the underlying digest. + + + int to octet string. + + + fill len bytes of the output buffer with bytes Generated from + the derivation function. + + @throws DataLengthException if the out buffer is too small. + + + Key generation parameters for NaccacheStern cipher. For details on this cipher, please see + + http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf + + + Generates a permuted ArrayList from the original one. The original List + is not modified + + @param arr + the ArrayList to be permuted + @param rand + the source of Randomness for permutation + @return a new ArrayList with the permuted elements. + + + Finds the first 'count' primes starting with 3 + + @param count + the number of primes to find + @return a vector containing the found primes as Integer + + + Generator for PBE derived keys and ivs as usd by OpenSSL. +

+ The scheme is a simple extension of PKCS 5 V2.0 Scheme 1 using MD5 with an + iteration count of 1. +

+
+ + Construct a OpenSSL Parameters generator. + + + Initialise - note the iteration count for this algorithm is fixed at 1. + + @param password password to use. + @param salt salt to use. + + + the derived key function, the ith hash of the password and the salt. + + + Generate a key parameter derived from the password, salt, and iteration + count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + @exception ArgumentException if the key length larger than the base hash size. + + + Generate a key with initialisation vector parameter derived from + the password, salt, and iteration count we are currently initialised + with. + + @param keySize the size of the key we want (in bits) + @param ivSize the size of the iv we want (in bits) + @return a ParametersWithIV object. + @exception ArgumentException if keySize + ivSize is larger than the base hash size. + + + Generate a key parameter for use with a MAC derived from the password, + salt, and iteration count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + @exception ArgumentException if the key length larger than the base hash size. + + + Generator for Pbe derived keys and ivs as defined by Pkcs 12 V1.0. +

+ The document this implementation is based on can be found at + + RSA's Pkcs12 Page +

+
+ + Construct a Pkcs 12 Parameters generator. + + @param digest the digest to be used as the source of derived keys. + @exception ArgumentException if an unknown digest is passed in. + + + add a + b + 1, returning the result in a. The a value is treated + as a BigInteger of length (b.Length * 8) bits. The result is + modulo 2^b.Length in case of overflow. + + + generation of a derived key ala Pkcs12 V1.0. + + + Generate a key parameter derived from the password, salt, and iteration + count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + + + Generate a key with initialisation vector parameter derived from + the password, salt, and iteration count we are currently initialised + with. + + @param keySize the size of the key we want (in bits) + @param ivSize the size of the iv we want (in bits) + @return a ParametersWithIV object. + + + Generate a key parameter for use with a MAC derived from the password, + salt, and iteration count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + + + Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 1. + Note this generator is limited to the size of the hash produced by the + digest used to drive it. +

+ The document this implementation is based on can be found at + + RSA's Pkcs5 Page +

+
+ + Construct a Pkcs 5 Scheme 1 Parameters generator. + + @param digest the digest to be used as the source of derived keys. + + + the derived key function, the ith hash of the mPassword and the mSalt. + + + Generate a key parameter derived from the mPassword, mSalt, and iteration + count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + @exception ArgumentException if the key length larger than the base hash size. + + + Generate a key with initialisation vector parameter derived from + the mPassword, mSalt, and iteration count we are currently initialised + with. + + @param keySize the size of the key we want (in bits) + @param ivSize the size of the iv we want (in bits) + @return a ParametersWithIV object. + @exception ArgumentException if keySize + ivSize is larger than the base hash size. + + + Generate a key parameter for use with a MAC derived from the mPassword, + mSalt, and iteration count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + @exception ArgumentException if the key length larger than the base hash size. + + + Generator for Pbe derived keys and ivs as defined by Pkcs 5 V2.0 Scheme 2. + This generator uses a SHA-1 HMac as the calculation function. +

+ The document this implementation is based on can be found at + + RSA's Pkcs5 Page

+
+ + construct a Pkcs5 Scheme 2 Parameters generator. + + + Generate a key parameter derived from the password, salt, and iteration + count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + + + Generate a key with initialisation vector parameter derived from + the password, salt, and iteration count we are currently initialised + with. + + @param keySize the size of the key we want (in bits) + @param ivSize the size of the iv we want (in bits) + @return a ParametersWithIV object. + + + Generate a key parameter for use with a MAC derived from the password, + salt, and iteration count we are currently initialised with. + + @param keySize the size of the key we want (in bits) + @return a KeyParameter object. + + + Generate a random factor suitable for use with RSA blind signatures + as outlined in Chaum's blinding and unblinding as outlined in + "Handbook of Applied Cryptography", page 475. + + + Initialise the factor generator + + @param param the necessary RSA key parameters. + + + Generate a suitable blind factor for the public key the generator was initialised with. + + @return a random blind factor + + + an RSA key pair generator. + + + Base interface for a public/private key block cipher. + + + The name of the algorithm this cipher implements. + + + Initialise the cipher. + Initialise for encryption if true, for decryption if false. + The key or other data required by the cipher. + + + The maximum size, in bytes, an input block may be. + + + The maximum size, in bytes, an output block will be. + + + Process a block. + The input buffer. + The offset into inBuf that the input block begins. + The length of the input block. + Input decrypts improperly. + Input is too large for the cipher. + + + interface that a public/private key pair generator should conform to. + + + intialise the key pair generator. + + @param the parameters the key pair is to be initialised with. + + + return an AsymmetricCipherKeyPair containing the Generated keys. + + @return an AsymmetricCipherKeyPair containing the Generated keys. + + + The basic interface that basic Diffie-Hellman implementations + conforms to. + + + initialise the agreement engine. + + + given a public key from a given party calculate the next + message in the agreement sequence. + + + Base interface for a symmetric key block cipher. + + + The name of the algorithm this cipher implements. + + + Initialise the cipher. + Initialise for encryption if true, for decryption if false. + The key or other data required by the cipher. + + + The block size for this cipher, in bytes. + + + Indicates whether this cipher can handle partial blocks. + + + Process a block. + The input buffer. + The offset into inBuf that the input block begins. + The output buffer. + The offset into outBuf to write the output block. + If input block is wrong size, or outBuf too small. + The number of bytes processed and produced. + + + + Reset the cipher to the same state as it was after the last init (if there was one). + + + + Block cipher engines are expected to conform to this interface. + + + The name of the algorithm this cipher implements. + + + Initialise the cipher. + If true the cipher is initialised for encryption, + if false for decryption. + The key and other data required by the cipher. + + + + Reset the cipher. After resetting the cipher is in the same state + as it was after the last init (if there was one). + + + + all parameter classes implement this. + + + base interface for general purpose byte derivation functions. + + + return the message digest used as the basis for the function + + + Parameters for key/byte stream derivation classes + + + interface that a message digest conforms to. + + + return the algorithm name + + @return the algorithm name + + + return the size, in bytes, of the digest produced by this message digest. + + @return the size, in bytes, of the digest produced by this message digest. + + + return the size, in bytes, of the internal buffer used by this digest. + + @return the size, in bytes, of the internal buffer used by this digest. + + + update the message digest with a single byte. + + @param inByte the input byte to be entered. + + + update the message digest with a block of bytes. + + @param input the byte array containing the data. + @param inOff the offset into the byte array where the data starts. + @param len the length of the data. + + + Close the digest, producing the final digest value. The doFinal + call leaves the digest reset. + + @param output the array the digest is to be copied into. + @param outOff the offset into the out array the digest is to start at. + + + reset the digest back to it's initial state. + + + interface for classes implementing the Digital Signature Algorithm + + + initialise the signer for signature generation or signature + verification. + + @param forSigning true if we are generating a signature, false + otherwise. + @param param key parameters for signature generation. + + + sign the passed in message (usually the output of a hash function). + + @param message the message to be signed. + @return two big integers representing the r and s values respectively. + + + verify the message message against the signature values r and s. + + @param message the message that was supposed to have been signed. + @param r the r signature value. + @param s the s signature value. + + + The base interface for implementations of message authentication codes (MACs). + + + Initialise the MAC. + + @param param the key and other data required by the MAC. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Return the name of the algorithm the MAC implements. + + @return the name of the algorithm the MAC implements. + + + Return the block size for this MAC (in bytes). + + @return the block size for this MAC in bytes. + + + add a single byte to the mac for processing. + + @param in the byte to be processed. + @exception InvalidOperationException if the MAC is not initialised. + + + @param in the array containing the input. + @param inOff the index in the array the data begins at. + @param len the length of the input starting at inOff. + @exception InvalidOperationException if the MAC is not initialised. + @exception DataLengthException if there isn't enough data in in. + + + Compute the final stage of the MAC writing the output to the out + parameter. +

+ doFinal leaves the MAC in the same state it was after the last init. +

+ @param out the array the MAC is to be output to. + @param outOff the offset into the out buffer the output is to start at. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the MAC is not initialised. +
+ + Reset the MAC. At the end of resetting the MAC should be in the + in the same state it was after the last init (if there was one). + + + this exception is thrown whenever we find something we don't expect in a + message. + + + base constructor. + + + create a InvalidCipherTextException with the given message. + + @param message the message to be carried with the exception. + + + Return the name of the algorithm the signer implements. + + @return the name of the algorithm the signer implements. + + + Initialise the signer for signing or verification. + + @param forSigning true if for signing, false otherwise + @param param necessary parameters. + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + Generate a signature for the message we've been loaded with using + the key we were initialised with. + + + return true if the internal state represents the signature described + in the passed in array. + + + reset the internal state + + + Signer with message recovery. + + + Returns true if the signer has recovered the full message as + part of signature verification. + + @return true if full message recovered. + + + Returns a reference to what message was recovered (if any). + + @return full/partial message, null if nothing. + + + Perform an update with the recovered message before adding any other data. This must + be the first update method called, and calling it will result in the signer assuming + that further calls to update will include message content past what is recoverable. + + @param signature the signature that we are in the process of verifying. + @throws IllegalStateException + + + The interface stream ciphers conform to. + + + The name of the algorithm this cipher implements. + + + Initialise the cipher. + If true the cipher is initialised for encryption, + if false for decryption. + The key and other data required by the cipher. + + If the parameters argument is inappropriate. + + + + encrypt/decrypt a single byte returning the result. + the byte to be processed. + the result of processing the input byte. + + + + Process a block of bytes from input putting the result into output. + + The input byte array. + + The offset into input where the data to be processed starts. + + The number of bytes to be processed. + The output buffer the processed bytes go into. + + The offset into output the processed data starts at. + + If the output buffer is too small. + + + + Reset the cipher to the same state as it was after the last init (if there was one). + + + + The name of the algorithm this cipher implements. + + + The base class for parameters to key generators. + + + initialise the generator with a source of randomness + and a strength (in bits). + + @param random the random byte source. + @param strength the size, in bits, of the keys we want to produce. + + + return the random source associated with this + generator. + + @return the generators random source. + + + return the bit strength for keys produced by this generator, + + @return the strength of the keys this generator produces (in bits). + + + standard CBC Block Cipher MAC - if no padding is specified the default of + pad of zeroes is used. + + + create a standard MAC based on a CBC block cipher. This will produce an + authentication code half the length of the block size of the cipher. + + @param cipher the cipher to be used as the basis of the MAC generation. + + + create a standard MAC based on a CBC block cipher. This will produce an + authentication code half the length of the block size of the cipher. + + @param cipher the cipher to be used as the basis of the MAC generation. + @param padding the padding to be used to complete the last block. + + + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. This class uses CBC mode as the basis for the + MAC generation. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. +
+ + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. This class uses CBC mode as the basis for the + MAC generation. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. + @param padding the padding to be used to complete the last block. +
+ + Reset the mac generator. + + + implements a Cipher-FeedBack (CFB) mode on top of a simple cipher. + + + Basic constructor. + + @param cipher the block cipher to be used as the basis of the + feedback mode. + @param blockSize the block size in bits (note: a multiple of 8) + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + An IV which is too short is handled in FIPS compliant fashion. + + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/CFB" + and the block size in bits. + + + return the block size we are operating at. + + @return the block size we are operating at (in bytes). + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the chaining vector back to the IV and reset the underlying + cipher. + + + create a standard MAC based on a CFB block cipher. This will produce an + authentication code half the length of the block size of the cipher, with + the CFB mode set to 8 bits. + + @param cipher the cipher to be used as the basis of the MAC generation. + + + create a standard MAC based on a CFB block cipher. This will produce an + authentication code half the length of the block size of the cipher, with + the CFB mode set to 8 bits. + + @param cipher the cipher to be used as the basis of the MAC generation. + @param padding the padding to be used. + + + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. This class uses CFB mode as the basis for the + MAC generation. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param cfbBitSize the size of an output block produced by the CFB mode. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. +
+ + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. This class uses CFB mode as the basis for the + MAC generation. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param cfbBitSize the size of an output block produced by the CFB mode. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. + @param padding a padding to be used. +
+ + Reset the mac generator. + + + CMAC - as specified at www.nuee.nagoya-u.ac.jp/labs/tiwata/omac/omac.html +

+ CMAC is analogous to OMAC1 - see also en.wikipedia.org/wiki/CMAC +

+ CMAC is a NIST recomendation - see + csrc.nist.gov/CryptoToolkit/modes/800-38_Series_Publications/SP800-38B.pdf +

+ CMAC/OMAC1 is a blockcipher-based message authentication code designed and + analyzed by Tetsu Iwata and Kaoru Kurosawa. +

+ CMAC/OMAC1 is a simple variant of the CBC MAC (Cipher Block Chaining Message + Authentication Code). OMAC stands for One-Key CBC MAC. +

+ It supports 128- or 64-bits block ciphers, with any key size, and returns + a MAC with dimension less or equal to the block size of the underlying + cipher. +

+
+ + create a standard MAC based on a CBC block cipher (64 or 128 bit block). + This will produce an authentication code the length of the block size + of the cipher. + + @param cipher the cipher to be used as the basis of the MAC generation. + + + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). + + @param cipher the cipher to be used as the basis of the MAC generation. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8 and @lt;= 128. + + + Reset the mac generator. + + + implementation of GOST 28147-89 MAC + + + HMAC implementation based on RFC2104 + + H(K XOR opad, H(K XOR ipad, text)) + + + Reset the mac generator. + + + DES based CBC Block Cipher MAC according to ISO9797, algorithm 3 (ANSI X9.19 Retail MAC) + + This could as well be derived from CBCBlockCipherMac, but then the property mac in the base + class must be changed to protected + + + create a Retail-MAC based on a CBC block cipher. This will produce an + authentication code of the length of the block size of the cipher. + + @param cipher the cipher to be used as the basis of the MAC generation. This must + be DESEngine. + + + create a Retail-MAC based on a CBC block cipher. This will produce an + authentication code of the length of the block size of the cipher. + + @param cipher the cipher to be used as the basis of the MAC generation. + @param padding the padding to be used to complete the last block. + + + create a Retail-MAC based on a block cipher with the size of the + MAC been given in bits. This class uses single DES CBC mode as the basis for the + MAC generation. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. +
+ + create a standard MAC based on a block cipher with the size of the + MAC been given in bits. This class uses single DES CBC mode as the basis for the + MAC generation. The final block is decrypted and then encrypted using the + middle and right part of the key. +

+ Note: the size of the MAC must be at least 24 bits (FIPS Publication 81), + or 16 bits if being used as a data authenticator (FIPS Publication 113), + and in general should be less than the size of the block cipher as it reduces + the chance of an exhaustive attack (see Handbook of Applied Cryptography). +

+ @param cipher the cipher to be used as the basis of the MAC generation. + @param macSizeInBits the size of the MAC in bits, must be a multiple of 8. + @param padding the padding to be used to complete the last block. +
+ + Reset the mac generator. + + + + This exception is thrown whenever a cipher requires a change of key, iv + or similar after x amount of bytes enciphered + + + + implements Cipher-Block-Chaining (CBC) mode on top of a simple cipher. + + + Basic constructor. + + @param cipher the block cipher to be used as the basis of chaining. + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/CBC". + + + return the block size of the underlying cipher. + + @return the block size of the underlying cipher. + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the chaining vector back to the IV and reset the underlying + cipher. + + + Do the appropriate chaining step for CBC mode encryption. + + @param in the array containing the data to be encrypted. + @param inOff offset into the in array the data starts at. + @param out the array the encrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Do the appropriate chaining step for CBC mode decryption. + + @param in the array containing the data to be decrypted. + @param inOff offset into the in array the data starts at. + @param out the array the decrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + * Implements the Counter with Cipher Block Chaining mode (CCM) detailed in + * NIST Special Publication 800-38C. + *

+ * Note: this mode is a packet mode - it needs all the data up front. + *

+
+ + Basic constructor. + + @param cipher the block cipher to be used. + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Returns a byte array containing the mac calculated as part of the + last encrypt or decrypt operation. + + @return the last mac calculated. + + + implements a Cipher-FeedBack (CFB) mode on top of a simple cipher. + + + Basic constructor. + + @param cipher the block cipher to be used as the basis of the + feedback mode. + @param blockSize the block size in bits (note: a multiple of 8) + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + An IV which is too short is handled in FIPS compliant fashion. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/CFB" + and the block size in bits. + + + return the block size we are operating at. + + @return the block size we are operating at (in bytes). + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Do the appropriate processing for CFB mode encryption. + + @param in the array containing the data to be encrypted. + @param inOff offset into the in array the data starts at. + @param out the array the encrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Do the appropriate processing for CFB mode decryption. + + @param in the array containing the data to be decrypted. + @param inOff offset into the in array the data starts at. + @param out the array the encrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the chaining vector back to the IV and reset the underlying + cipher. + + + A Cipher Text Stealing (CTS) mode cipher. CTS allows block ciphers to + be used to produce cipher text which is the same outLength as the plain text. + + + Create a buffered block cipher that uses Cipher Text Stealing + + @param cipher the underlying block cipher this buffering object wraps. + + + return the size of the output buffer required for an update of 'length' bytes. + + @param length the outLength of the input. + @return the space required to accommodate a call to update + with length bytes of input. + + + return the size of the output buffer required for an update plus a + doFinal with an input of length bytes. + + @param length the outLength of the input. + @return the space required to accommodate a call to update and doFinal + with length bytes of input. + + + process a single byte, producing an output block if neccessary. + + @param in the input byte. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + process an array of bytes, producing output if necessary. + + @param in the input byte array. + @param inOff the offset at which the input data starts. + @param length the number of bytes to be copied out of the input array. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + Process the last block in the buffer. + + @param out the array the block currently being held is copied into. + @param outOff the offset at which the copying starts. + @return the number of output bytes copied to out. + @exception DataLengthException if there is insufficient space in out for + the output. + @exception InvalidOperationException if the underlying cipher is not + initialised. + @exception InvalidCipherTextException if cipher text decrypts wrongly (in + case the exception will never Get thrown). + + + A Two-Pass Authenticated-Encryption Scheme Optimized for Simplicity and + Efficiency - by M. Bellare, P. Rogaway, D. Wagner. + + http://www.cs.ucdavis.edu/~rogaway/papers/eax.pdf + + EAX is an AEAD scheme based on CTR and OMAC1/CMAC, that uses a single block + cipher to encrypt and authenticate data. It's on-line (the length of a + message isn't needed to begin processing it), has good performances, it's + simple and provably secure (provided the underlying block cipher is secure). + + Of course, this implementations is NOT thread-safe. + + + Constructor that accepts an instance of a block cipher engine. + + @param cipher the engine to use + + + + Implements the Galois/Counter mode (GCM) detailed in + NIST Special Publication 800-38D. + + + + implements the GOST 28147 OFB counter mode (GCTR). + + + Basic constructor. + + @param cipher the block cipher to be used as the basis of the + counter mode (must have a 64 bit block size). + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + An IV which is too short is handled in FIPS compliant fashion. + + @param encrypting if true the cipher is initialised for + encryption, if false for decryption. + @param parameters the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is inappropriate. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/GCTR" + and the block size in bits + + + return the block size we are operating at (in bytes). + + @return the block size we are operating at (in bytes). + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the feedback vector back to the IV and reset the underlying + cipher. + + + + A block cipher mode that includes authenticated encryption with a streaming mode + and optional associated data. + + + + The name of the algorithm this cipher implements. + + + Initialise the cipher. + Parameter can either be an AeadParameters or a ParametersWithIV object. + Initialise for encryption if true, for decryption if false. + The key or other data required by the cipher. + + + The block size for this cipher, in bytes. + + + Encrypt/decrypt a single byte. + + @param input the byte to be processed. + @param outBytes the output buffer the processed byte goes into. + @param outOff the offset into the output byte array the processed data starts at. + @return the number of bytes written to out. + @exception DataLengthException if the output buffer is too small. + + + Process a block of bytes from in putting the result into out. + + @param inBytes the input byte array. + @param inOff the offset into the in array where the data to be processed starts. + @param len the number of bytes to be processed. + @param outBytes the output buffer the processed bytes go into. + @param outOff the offset into the output byte array the processed data starts at. + @return the number of bytes written to out. + @exception DataLengthException if the output buffer is too small. + + + Finish the operation either appending or verifying the MAC at the end of the data. + + @param outBytes space for any resulting output data. + @param outOff offset into out to start copying the data at. + @return number of bytes written into out. + @throws InvalidOperationException if the cipher is in an inappropriate state. + @throws InvalidCipherTextException if the MAC fails to match. + + + Return the value of the MAC associated with the last stream processed. + + @return MAC for plaintext data. + + + Return the size of the output buffer required for a ProcessBytes + an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to ProcessBytes + with len bytes of input. + + + Return the size of the output buffer required for a ProcessBytes plus a + DoFinal with an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to ProcessBytes and DoFinal + with len bytes of input. + + + + Reset the cipher to the same state as it was after the last init (if there was one). + + + + implements a Output-FeedBack (OFB) mode on top of a simple cipher. + + + Basic constructor. + + @param cipher the block cipher to be used as the basis of the + feedback mode. + @param blockSize the block size in bits (note: a multiple of 8) + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + An IV which is too short is handled in FIPS compliant fashion. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/OFB" + and the block size in bits + + + return the block size we are operating at (in bytes). + + @return the block size we are operating at (in bytes). + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the feedback vector back to the IV and reset the underlying + cipher. + + + * Implements OpenPGP's rather strange version of Cipher-FeedBack (CFB) mode + * on top of a simple cipher. This class assumes the IV has been prepended + * to the data stream already, and just accomodates the reset after + * (blockSize + 2) bytes have been read. + *

+ * For further info see RFC 2440. + *

+
+ + Basic constructor. + + @param cipher the block cipher to be used as the basis of the + feedback mode. + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + return the algorithm name and mode. + + @return the name of the underlying algorithm followed by "/PGPCFB" + and the block size in bits. + + + return the block size we are operating at. + + @return the block size we are operating at (in bytes). + + + Process one block of input from the array in and write it to + the out array. + + @param in the array containing the input data. + @param inOff offset into the in array the data starts at. + @param out the array the output data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + reset the chaining vector back to the IV and reset the underlying + cipher. + + + Initialise the cipher and, possibly, the initialisation vector (IV). + If an IV isn't passed as part of the parameter, the IV will be all zeros. + An IV which is too short is handled in FIPS compliant fashion. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param parameters the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + Encrypt one byte of data according to CFB mode. + @param data the byte to encrypt + @param blockOff offset in the current block + @returns the encrypted byte + + + Do the appropriate processing for CFB IV mode encryption. + + @param in the array containing the data to be encrypted. + @param inOff offset into the in array the data starts at. + @param out the array the encrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Do the appropriate processing for CFB IV mode decryption. + + @param in the array containing the data to be decrypted. + @param inOff offset into the in array the data starts at. + @param out the array the encrypted data will be copied into. + @param outOff the offset into the out array the output will start at. + @exception DataLengthException if there isn't enough data in in, or + space in out. + @exception InvalidOperationException if the cipher isn't initialised. + @return the number of bytes processed and produced. + + + Implements the Segmented Integer Counter (SIC) mode on top of a simple + block cipher. + + + Basic constructor. + + @param c the block cipher to be used. + + + return the underlying block cipher that we are wrapping. + + @return the underlying block cipher that we are wrapping. + + + Block cipher padders are expected to conform to this interface + + + Initialise the padder. + + @param param parameters, if any required. + + + Return the name of the algorithm the cipher implements. + + @return the name of the algorithm the cipher implements. + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + return the number of pad bytes present in the block. + @exception InvalidCipherTextException if the padding is badly formed + or invalid. + + + A padder that adds ISO10126-2 padding to a block. + + + Initialise the padder. + + @param random a SecureRandom if available. + + + Return the name of the algorithm the cipher implements. + + @return the name of the algorithm the cipher implements. + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + return the number of pad bytes present in the block. + + + A padder that adds the padding according to the scheme referenced in + ISO 7814-4 - scheme 2 from ISO 9797-1. The first byte is 0x80, rest is 0x00 + + + Initialise the padder. + + @param random - a SecureRandom if available. + + + Return the name of the algorithm the padder implements. + + @return the name of the algorithm the padder implements. + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + return the number of pad bytes present in the block. + + + A wrapper class that allows block ciphers to be used to process data in + a piecemeal fashion with padding. The PaddedBufferedBlockCipher + outputs a block only when the buffer is full and more data is being added, + or on a doFinal (unless the current block in the buffer is a pad block). + The default padding mechanism used is the one outlined in Pkcs5/Pkcs7. + + + Create a buffered block cipher with the desired padding. + + @param cipher the underlying block cipher this buffering object wraps. + @param padding the padding type. + + + Create a buffered block cipher Pkcs7 padding + + @param cipher the underlying block cipher this buffering object wraps. + + + initialise the cipher. + + @param forEncryption if true the cipher is initialised for + encryption, if false for decryption. + @param param the key and other data required by the cipher. + @exception ArgumentException if the parameters argument is + inappropriate. + + + return the minimum size of the output buffer required for an update + plus a doFinal with an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update and doFinal + with len bytes of input. + + + return the size of the output buffer required for an update + an input of len bytes. + + @param len the length of the input. + @return the space required to accommodate a call to update + with len bytes of input. + + + process a single byte, producing an output block if neccessary. + + @param in the input byte. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + process an array of bytes, producing output if necessary. + + @param in the input byte array. + @param inOff the offset at which the input data starts. + @param len the number of bytes to be copied out of the input array. + @param out the space for any output that might be produced. + @param outOff the offset from which the output will be copied. + @return the number of output bytes copied to out. + @exception DataLengthException if there isn't enough space in out. + @exception InvalidOperationException if the cipher isn't initialised. + + + Process the last block in the buffer. If the buffer is currently + full and padding needs to be added a call to doFinal will produce + 2 * GetBlockSize() bytes. + + @param out the array the block currently being held is copied into. + @param outOff the offset at which the copying starts. + @return the number of output bytes copied to out. + @exception DataLengthException if there is insufficient space in out for + the output or we are decrypting and the input is not block size aligned. + @exception InvalidOperationException if the underlying cipher is not + initialised. + @exception InvalidCipherTextException if padding is expected and not found. + + + A padder that adds Pkcs7/Pkcs5 padding to a block. + + + Initialise the padder. + + @param random - a SecureRandom if available. + + + Return the name of the algorithm the cipher implements. + + @return the name of the algorithm the cipher implements. + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + return the number of pad bytes present in the block. + + + A padder that adds Trailing-Bit-Compliment padding to a block. +

+ This padding pads the block out compliment of the last bit + of the plain text. +

+
+
+ + Return the name of the algorithm the cipher implements. + the name of the algorithm the cipher implements. + + + + Initialise the padder. + - a SecureRandom if available. + + + + add the pad bytes to the passed in block, returning the + number of bytes added. +

+ Note: this assumes that the last block of plain text is always + passed to it inside in. i.e. if inOff is zero, indicating the + entire block is to be overwritten with padding the value of in + should be the same as the last block of plain text. +

+
+
+ + return the number of pad bytes present in the block. + + + A padder that adds X9.23 padding to a block - if a SecureRandom is + passed in random padding is assumed, otherwise padding with zeros is used. + + + Initialise the padder. + + @param random a SecureRandom if one is available. + + + Return the name of the algorithm the cipher implements. + + @return the name of the algorithm the cipher implements. + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + return the number of pad bytes present in the block. + + + A padder that adds Null byte padding to a block. + + + Return the name of the algorithm the cipher implements. + + + the name of the algorithm the cipher implements. + + + + Initialise the padder. + + + - a SecureRandom if available. + + + + add the pad bytes to the passed in block, returning the + number of bytes added. + + + + return the number of pad bytes present in the block. + + + Base constructor. + + @param key key to be used by underlying cipher + @param macSize macSize in bits + @param nonce nonce to be used + @param associatedText associated text, if any + + + Base constructor. + + @param key key to be used by underlying cipher + @param macSize macSize in bits + @param nonce nonce to be used + @param associatedText associated text, if any + + + return true if the passed in key is a DES-EDE weak key. + + @param key bytes making up the key + @param offset offset into the byte array the key starts at + @param length number of bytes making up the key + + + return true if the passed in key is a DES-EDE weak key. + + @param key bytes making up the key + @param offset offset into the byte array the key starts at + + + DES has 16 weak keys. This method will check + if the given DES key material is weak or semi-weak. + Key material that is too short is regarded as weak. +

+ See "Applied + Cryptography" by Bruce Schneier for more information. +

+ @return true if the given DES key material is weak or semi-weak, + false otherwise. +
+ + DES Keys use the LSB as the odd parity bit. This can + be used to check for corrupt keys. + + @param bytes the byte array to set the parity on. + + + The minimum bitlength of the private value. + + + The bitlength of the private value. + + + return the generator - g + + + return private value limit - l + + + parameters for using an integrated cipher in stream mode. + + + @param derivation the derivation parameter for the KDF function. + @param encoding the encoding parameter for the KDF function. + @param macKeySize the size of the MAC key (in bits). + + + @param derivation the derivation parameter for the KDF function. + @param encoding the encoding parameter for the KDF function. + @param macKeySize the size of the MAC key (in bits). + @param cipherKeySize the size of the associated Cipher key (in bits). + + + parameters for Key derivation functions for ISO-18033 + + + parameters for Key derivation functions for IEEE P1363a + + + Parameters for mask derivation functions. + + + Parameters for NaccacheStern public private key generation. For details on + this cipher, please see + + http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf + + + Parameters for generating a NaccacheStern KeyPair. + + @param random + The source of randomness + @param strength + The desired strength of the Key in Bits + @param certainty + the probability that the generated primes are not really prime + as integer: 2^(-certainty) is then the probability + @param countSmallPrimes + How many small key factors are desired + + + Parameters for a NaccacheStern KeyPair. + + @param random + The source of randomness + @param strength + The desired strength of the Key in Bits + @param certainty + the probability that the generated primes are not really prime + as integer: 2^(-certainty) is then the probability + @param cntSmallPrimes + How many small key factors are desired + @param debug + Turn debugging on or off (reveals secret information, use with + caution) + + + @return Returns the certainty. + + + @return Returns the countSmallPrimes. + + + Public key parameters for NaccacheStern cipher. For details on this cipher, + please see + + http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf + + + @param privateKey + + + @return Returns the g. + + + @return Returns the lowerSigmaBound. + + + @return Returns the n. + + + Private key parameters for NaccacheStern cipher. For details on this cipher, + please see + + http://www.gemplus.com/smart/rd/publications/pdf/NS98pkcs.pdf + + + Constructs a NaccacheSternPrivateKey + + @param g + the public enryption parameter g + @param n + the public modulus n = p*q + @param lowerSigmaBound + the public lower sigma bound up to which data can be encrypted + @param smallPrimes + the small primes, of which sigma is constructed in the right + order + @param phi_n + the private modulus phi(n) = (p-1)(q-1) + + + Cipher parameters with a fixed salt value associated with them. + + + super class for all Password Based Encyrption (Pbe) parameter generator classes. + + + base constructor. + + + initialise the Pbe generator. + + @param password the password converted into bytes (see below). + @param salt the salt to be mixed with the password. + @param iterationCount the number of iterations the "mixing" function + is to be applied for. + + + return the password byte array. + + @return the password byte array. + + + return the salt byte array. + + @return the salt byte array. + + + return the iteration count. + + @return the iteration count. + + + Generate derived parameters for a key of length keySize. + + @param keySize the length, in bits, of the key required. + @return a parameters object representing a key. + + + Generate derived parameters for a key of length keySize, and + an initialisation vector (IV) of length ivSize. + + @param keySize the length, in bits, of the key required. + @param ivSize the length, in bits, of the iv required. + @return a parameters object representing a key and an IV. + + + Generate derived parameters for a key of length keySize, specifically + for use with a MAC. + + @param keySize the length, in bits, of the key required. + @return a parameters object representing a key. + + + converts a password to a byte array according to the scheme in + Pkcs5 (ascii, no padding) + + @param password a character array representing the password. + @return a byte array representing the password. + + + converts a password to a byte array according to the scheme in + PKCS5 (UTF-8, no padding) + + @param password a character array representing the password. + @return a byte array representing the password. + + + converts a password to a byte array according to the scheme in + Pkcs12 (unicode, big endian, 2 zero pad bytes at the end). + + @param password a character array representing the password. + @return a byte array representing the password. + + + Random generation based on the digest with counter. Calling AddSeedMaterial will + always increase the entropy of the hash. +

+ Internal access to the digest is synchronized so a single one of these can be shared. +

+
+ + Generic interface for objects generating random bytes. + + + Add more seed material to the generator. + A byte array to be mixed into the generator's state. + + + Add more seed material to the generator. + A long value to be mixed into the generator's state. + + + Fill byte array with random values. + Array to be filled. + + + Fill byte array with random values. + Array to receive bytes. + Index to start filling at. + Length of segment to fill. + + + + Takes bytes generated by an underling RandomGenerator and reverses the order in + each small window (of configurable size). +

+ Access to internals is synchronized so a single one of these can be shared. +

+
+
+ + Add more seed material to the generator. + A byte array to be mixed into the generator's state. + + + Add more seed material to the generator. + A long value to be mixed into the generator's state. + + + Fill byte array with random values. + Array to be filled. + + + Fill byte array with random values. + Array to receive bytes. + Index to start filling at. + Length of segment to fill. + + + A thread based seed generator - one source of randomness. +

+ Based on an idea from Marcus Lippert. +

+
+ + Generate seed bytes. Set fast to false for best quality. +

+ If fast is set to true, the code should be round about 8 times faster when + generating a long sequence of random bytes. 20 bytes of random values using + the fast mode take less than half a second on a Nokia e70. If fast is set to false, + it takes round about 2500 ms. +

+ @param numBytes the number of bytes to generate + @param fast true if fast mode should be used +
+ + + Permutation generated by code: + + // First 1850 fractional digit of Pi number. + byte[] key = new BigInteger("14159265358979323846...5068006422512520511").ToByteArray(); + s = 0; + P = new byte[256]; + for (int i = 0; i < 256; i++) + { + P[i] = (byte) i; + } + for (int m = 0; m < 768; m++) + { + s = P[(s + P[m & 0xff] + key[m % key.length]) & 0xff]; + byte temp = P[m & 0xff]; + P[m & 0xff] = P[s & 0xff]; + P[s & 0xff] = temp; + } + + + + Value generated in the same way as P. + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + Generate a signature for the message we've been loaded with using + the key we were initialised with. + + + true if the internal state represents the signature described in the passed in array. + + + Reset the internal state + + + The Digital Signature Algorithm - as described in "Handbook of Applied + Cryptography", pages 452 - 453. + + + Generate a signature for the given message using the key we were + initialised with. For conventional DSA the message should be a SHA-1 + hash of the message of interest. + + @param message the message that will be verified later. + + + return true if the value r and s represent a DSA signature for + the passed in message for standard DSA the message should be a + SHA-1 hash of the real message to be verified. + + + EC-DSA as described in X9.62 + + + Generate a signature for the given message using the key we were + initialised with. For conventional DSA the message should be a SHA-1 + hash of the message of interest. + + @param message the message that will be verified later. + + + return true if the value r and s represent a DSA signature for + the passed in message (for standard DSA the message should be + a SHA-1 hash of the real message to be verified). + + + GOST R 34.10-2001 Signature Algorithm + + + generate a signature for the given message using the key we were + initialised with. For conventional GOST3410 the message should be a GOST3411 + hash of the message of interest. + + @param message the message that will be verified later. + + + return true if the value r and s represent a GOST3410 signature for + the passed in message (for standard GOST3410 the message should be + a GOST3411 hash of the real message to be verified). + + + EC-NR as described in IEEE 1363-2000 + + + generate a signature for the given message using the key we were + initialised with. Generally, the order of the curve should be at + least as long as the hash of the message of interest, and with + ECNR it *must* be at least as long. + + @param digest the digest to be signed. + @exception DataLengthException if the digest is longer than the key allows + + + return true if the value r and s represent a signature for the + message passed in. Generally, the order of the curve should be at + least as long as the hash of the message of interest, and with + ECNR, it *must* be at least as long. But just in case the signer + applied mod(n) to the longer digest, this implementation will + apply mod(n) during verification. + + @param digest the digest to be verified. + @param r the r value of the signature. + @param s the s value of the signature. + @exception DataLengthException if the digest is longer than the key allows + + + initialise the signer for signing or verification. + + @param forSigning + true if for signing, false otherwise + @param parameters + necessary parameters. + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + Generate a signature for the message we've been loaded with using the key + we were initialised with. + + + return true if the internal state represents the signature described in + the passed in array. + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + Generate a signature for the message we've been loaded with using + the key we were initialised with. + + + true if the internal state represents the signature described in the passed in array. + + + Reset the internal state + + + Gost R 34.10-94 Signature Algorithm + + + generate a signature for the given message using the key we were + initialised with. For conventional Gost3410 the message should be a Gost3411 + hash of the message of interest. + + @param message the message that will be verified later. + + + return true if the value r and s represent a Gost3410 signature for + the passed in message for standard Gost3410 the message should be a + Gost3411 hash of the real message to be verified. + + + ISO9796-2 - mechanism using a hash function with recovery (scheme 2 and 3). +

+ Note: the usual length for the salt is the length of the hash + function used in bytes.

+
+
+ + + Return a reference to the recoveredMessage message. + + The full/partial recoveredMessage message. + + + + + Generate a signer for the with either implicit or explicit trailers + for ISO9796-2, scheme 2 or 3. + + base cipher to use for signature creation/verification + digest to use. + length of salt in bytes. + whether or not the trailer is implicit or gives the hash. + + + Constructor for a signer with an explicit digest trailer. + + + cipher to use. + + digest to sign with. + + length of salt in bytes. + + + + Initialise the signer. + true if for signing, false if for verification. + parameters for signature generation/verification. If the + parameters are for generation they should be a ParametersWithRandom, + a ParametersWithSalt, or just an RsaKeyParameters object. If RsaKeyParameters + are passed in a SecureRandom will be created. + + if wrong parameter type or a fixed + salt is passed in which is the wrong length. + + + + compare two byte arrays - constant time. + + + clear possible sensitive data + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + reset the internal state + + + Generate a signature for the loaded message using the key we were + initialised with. + + + + return true if the signature represents a ISO9796-2 signature + for the passed in message. + + + + + Return true if the full message was recoveredMessage. + + true on full message recovery, false otherwise, or if not sure. + + + + int to octet string. + int to octet string. + + + long to octet string. + + + mask generator function, as described in Pkcs1v2. + + + ISO9796-2 - mechanism using a hash function with recovery (scheme 1) + + + + Return a reference to the recoveredMessage message. + + The full/partial recoveredMessage message. + + + + + Generate a signer for the with either implicit or explicit trailers + for ISO9796-2. + + base cipher to use for signature creation/verification + digest to use. + whether or not the trailer is implicit or gives the hash. + + + Constructor for a signer with an explicit digest trailer. + + + cipher to use. + + digest to sign with. + + + + compare two byte arrays - constant time. + + + clear possible sensitive data + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + reset the internal state + + + Generate a signature for the loaded message using the key we were + initialised with. + + + + return true if the signature represents a ISO9796-2 signature + for the passed in message. + + + + + Return true if the full message was recoveredMessage. + + true on full message recovery, false otherwise. + + + + RSA-PSS as described in Pkcs# 1 v 2.1. +

+ Note: the usual value for the salt length is the number of + bytes in the hash function.

+
+
+ + Basic constructor + the asymmetric cipher to use. + the digest to use. + the length of the salt to use (in bytes). + + + clear possible sensitive data + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + reset the internal state + + + Generate a signature for the message we've been loaded with using + the key we were initialised with. + + + + return true if the internal state represents the signature described + in the passed in array. + + + + int to octet string. + + + mask generator function, as described in Pkcs1v2. + + + + Load oid table. + + + + Initialise the signer for signing or verification. + + @param forSigning true if for signing, false otherwise + @param param necessary parameters. + + + update the internal digest with the byte b + + + update the internal digest with the byte array in + + + Generate a signature for the message we've been loaded with using + the key we were initialised with. + + + return true if the internal state represents the signature described + in the passed in array. + + + a wrapper for block ciphers with a single byte block size, so that they + can be treated like stream ciphers. + + + basic constructor. + + @param cipher the block cipher to be wrapped. + @exception ArgumentException if the cipher has a block size other than + one. + + + initialise the underlying cipher. + + @param forEncryption true if we are setting up for encryption, false otherwise. + @param param the necessary parameters for the underlying cipher to be initialised. + + + return the name of the algorithm we are wrapping. + + @return the name of the algorithm we are wrapping. + + + encrypt/decrypt a single byte returning the result. + + @param in the byte to be processed. + @return the result of processing the input byte. + + + process a block of bytes from in putting the result into out. + + @param in the input byte array. + @param inOff the offset into the in array where the data to be processed starts. + @param len the number of bytes to be processed. + @param out the output buffer the processed bytes go into. + @param outOff the offset into the output byte array the processed data stars at. + @exception DataLengthException if the output buffer is too small. + + + reset the underlying cipher. This leaves it in the same state + it was at after the last init (if there was one). + + + + RFC 2246 7.2 + + + + + RFC 2246 7.2 + + + + + A certificate verifyer, that will always return true. +
+            DO NOT USE THIS FILE UNLESS YOU KNOW EXACTLY WHAT YOU ARE DOING.
+            
+
+
+ + Return true. + + + + A queue for bytes. +

+ This file could be more optimized. +

+
+
+ + The smallest number which can be written as 2^x which is bigger than i. + + + The initial size for our buffer. + + + The buffer where we store our data. + + + How many bytes at the beginning of the buffer are skipped. + + + How many bytes in the buffer are valid data. + + + Read data from the buffer. + The buffer where the read data will be copied to. + How many bytes to skip at the beginning of buf. + How many bytes to read at all. + How many bytes from our data to skip. + + + Add some data to our buffer. + A byte-array to read data from. + How many bytes to skip at the beginning of the array. + How many bytes to read from the array. + + + Remove some bytes from our data from the beginning. + How many bytes to remove. + + + The number of bytes which are available in this buffer. + + + A representation for a certificate chain. + + + The certificates. + + + Parse the ServerCertificate message. + + @param inStr The stream where to parse from. + @return A Certificate object with the certs, the server has sended. + @throws IOException If something goes wrong during parsing. + + + Encodes version of the ClientCertificate message + + @param outStr stream to write the message to + @throws IOException If something goes wrong + + + Private constructor from a cert array. + + @param certs The certs the chain should contain. + + + An array which contains the certs, this chain contains. + + + A of X509Name + + + + RFC 2246 A.5 + + + + + RFC 2246 7.4.4 + + + + A combined hash, which implements md5(m) || sha1(m). + + + + + + + + + + + + + + + + + + + + + + + + + RFC 2246 6.1 + + + + + RFC 2246 6.2.1 + + + + + + + + + + + + + + RFC 4492 5.4 + + + + Indicates the elliptic curve domain parameters are conveyed verbosely, and the + underlying finite field is a prime field. + + + Indicates the elliptic curve domain parameters are conveyed verbosely, and the + underlying finite field is a characteristic-2 field. + + + Indicates that a named curve is used. This option SHOULD be used when applicable. + + + + RFC 4492 5.1.2 + + + + + RFC 4366 2.3 + + + + + RFC 2246 7.4 + + + + + This should be implemented by any class which can find out, if a given + certificate chain is being accepted by an client. + + + + The certs, which are part of the chain. + True, if the chain is accepted, false otherwise + + + + A temporary class to wrap old CertificateVerifyer stuff for new TlsAuthentication. + + + + + A temporary class to use LegacyTlsAuthentication + + + + + RFC 4492 5.1.1 + The named curves defined here are those specified in SEC 2 [13]. Note that many of + these curves are also recommended in ANSI X9.62 [7] and FIPS 186-2 [11]. Values 0xFE00 + through 0xFEFF are reserved for private use. Values 0xFF01 and 0xFF02 indicate that the + client supports arbitrary prime and characteristic-2 curves, respectively (the curve + parameters must be encoded explicitly in ECParameters). + + + + An implementation of the TLS 1.0 record layer. + + + HMAC implementation based on original internet draft for HMAC (RFC 2104) + + The difference is that padding is concatentated versus XORed with the key + + H(K + opad, H(K + ipad, text)) + + + Base constructor for one of the standard digest algorithms that the byteLength of + the algorithm is know for. Behaviour is undefined for digests other than MD5 or SHA1. + + @param digest the digest. + + + Reset the mac generator. + + + + + + + Called by the protocol handler to report the server certificate. + + + This method is responsible for certificate verification and validation + + The server received + + + + + Return client credentials in response to server's certificate request + + + A containing server certificate request details + + + A to be used for client authentication + (or null for no client authentication) + + + + + + A generic TLS 1.0 block cipher. This can be used for AES or 3DES for example. + + + + + + + + + + + + + + Called at the start of a new TLS session, before any other methods. + + + A + + + + + Get the list of cipher suites that this client supports. + + + An array of , each specifying a supported cipher suite. + + + + + Get the list of compression methods that this client supports. + + + An array of , each specifying a supported compression method. + + + + + Get the (optional) table of client extensions to be included in (extended) client hello. + + + A ( -> byte[]). May be null. + + + + + + Reports the session ID once it has been determined. + + + A + + + + + Report the cipher suite that was selected by the server. + + + The protocol handler validates this value against the offered cipher suites + + + + A + + + + + Report the compression method that was selected by the server. + + + The protocol handler validates this value against the offered compression methods + + + + A + + + + + Report whether the server supports secure renegotiation + + + The protocol handler automatically processes the relevant extensions + + + A , true if the server supports secure renegotiation + + + + + + Report the extensions from an extended server hello. + + + Will only be called if we returned a non-null result from . + + + A ( -> byte[]) + + + + + Return an implementation of to negotiate the key exchange + part of the protocol. + + + A + + + + + + Return an implementation of to handle authentication + part of the protocol. + + + + + + Return an implementation of to handle record compression. + + + + + + Return an implementation of to use for encryption/decryption. + + + A + + + + + + TLS 1.0 DH key exchange. + + + + ECDHE key exchange (see RFC 4492) + + + ECDH key exchange (see RFC 4492) + + + + A generic interface for key exchange implementations in TLS 1.0. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + A generic TLS MAC implementation, which can be used with any kind of + IDigest to act as an HMAC. + + + + Generate a new instance of an TlsMac. + + @param digest The digest to use. + @param key_block A byte-array where the key for this mac is located. + @param offset The number of bytes to skip, before the key starts in the buffer. + @param len The length of the key. + + + @return the MAC write secret + + + @return the current write sequence number + + + Increment the current write sequence number + + + @return The Keysize of the mac. + + + Calculate the mac for some given data. +

+ TlsMac will keep track of the sequence number internally. + + @param type The message type of the message. + @param message A byte-buffer containing the message. + @param offset The number of bytes to skip, before the message starts. + @param len The length of the message. + @return A new byte-buffer containing the mac value. + + +

+ A NULL cipher suite, for use during handshake. + +
+ + An implementation of all high level protocols in TLS 1.0. + + + Both streams can be the same object + + + Both streams can be the same object + + + This method is called, when a change cipher spec message is received. + + @throws IOException If the message has an invalid content or the + handshake is not in the correct state. + + + Connects to the remote system. + Will be used when a certificate is received to verify + that this certificate is accepted by the client. + If handshake was not successful + + + Read data from the network. The method will return immediately, if there is + still some data left in the buffer, or block until some application + data has been read from the network. + + @param buf The buffer where the data will be copied to. + @param offset The position where the data will be placed in the buffer. + @param len The maximum number of bytes to read. + @return The number of bytes read. + @throws IOException If something goes wrong during reading data. + + + Send some application data to the remote system. +

+ The method will handle fragmentation internally. + + @param buf The buffer with the data. + @param offset The position in the buffer where the data is placed. + @param len The length of the data. + @throws IOException If something goes wrong during sending. + + +

A Stream which can be used to send data. +
+ + A Stream which can be used to read data. + + + The secure bidirectional stream for this connection + + + Terminate this connection with an alert. +

+ Can be used for normal closure too. + + @param alertLevel The level of the alert, an be AlertLevel.fatal or AL_warning. + @param alertDescription The exact alert message. + @throws IOException If alert was fatal. + + +

Closes this connection + If something goes wrong during closing. +
+ + Make sure the Stream is now empty. Fail otherwise. + + @param is The Stream to check. + @throws IOException If is is not empty. + + + + TLS 1.0 RSA key exchange. + + + + + + + + TLS 1.1 SRP key exchange. + + + + Some helper fuctions for MicroTLS. + + + return a = a + b - b preserved. + + + unsigned comparison on two arrays - note the arrays may + start with leading zeros. + + + return z = x / y - done in place (z value preserved, x contains the + remainder) + + + return whether or not a BigInteger is probably prime with a + probability of 1 - (1/2)**certainty. +

From Knuth Vol 2, pg 395.

+
+ + Calculate the numbers u1, u2, and u3 such that: + + u1 * a + u2 * b = u3 + + where u3 is the greatest common divider of a and b. + a and b using the extended Euclid algorithm (refer p. 323 + of The Art of Computer Programming vol 2, 2nd ed). + This also seems to have the side effect of calculating + some form of multiplicative inverse. + + @param a First number to calculate gcd for + @param b Second number to calculate gcd for + @param u1Out the return object for the u1 value + @param u2Out the return object for the u2 value + @return The greatest common divisor of a and b + + + return w with w = x * x - w is assumed to have enough space. + + + return x with x = y * z - x is assumed to have enough space. + + + Calculate mQuote = -m^(-1) mod b with b = 2^32 (32 = word size) + + + Montgomery multiplication: a = x * y * R^(-1) mod m +
+ Based algorithm 14.36 of Handbook of Applied Cryptography. +
+
  • m, x, y should have length n
  • +
  • a should have length (n + 1)
  • +
  • b = 2^32, R = b^n
  • +
    + The result is put in x +
    + NOTE: the indices of x, y, m, a different in HAC and in Java +
    + + return x = x % y - done in place (y value preserved) + + + do a left shift - this returns a new array. + + + do a right shift - this does it in place. + + + do a right shift by one - this does it in place. + + + returns x = x - y - we assume x is >= y + + + Class representing a simple version of a big decimal. A + SimpleBigDecimal is basically a + {@link java.math.BigInteger BigInteger} with a few digits on the right of + the decimal point. The number of (binary) digits on the right of the decimal + point is called the scale of the SimpleBigDecimal. + Unlike in {@link java.math.BigDecimal BigDecimal}, the scale is not adjusted + automatically, but must be set manually. All SimpleBigDecimals + taking part in the same arithmetic operation must have equal scale. The + result of a multiplication of two SimpleBigDecimals returns a + SimpleBigDecimal with double scale. + + + Returns a SimpleBigDecimal representing the same numerical + value as value. + @param value The value of the SimpleBigDecimal to be + created. + @param scale The scale of the SimpleBigDecimal to be + created. + @return The such created SimpleBigDecimal. + + + Constructor for SimpleBigDecimal. The value of the + constructed SimpleBigDecimal Equals bigInt / + 2scale. + @param bigInt The bigInt value parameter. + @param scale The scale of the constructed SimpleBigDecimal. + + + Class holding methods for point multiplication based on the window + τ-adic nonadjacent form (WTNAF). The algorithms are based on the + paper "Improved Algorithms for Arithmetic on Anomalous Binary Curves" + by Jerome A. Solinas. The paper first appeared in the Proceedings of + Crypto 1997. + + + The window width of WTNAF. The standard value of 4 is slightly less + than optimal for running time, but keeps space requirements for + precomputation low. For typical curves, a value of 5 or 6 results in + a better running time. When changing this value, the + αu's must be computed differently, see + e.g. "Guide to Elliptic Curve Cryptography", Darrel Hankerson, + Alfred Menezes, Scott Vanstone, Springer-Verlag New York Inc., 2004, + p. 121-122 + + + 24 + + + The αu's for a=0 as an array + of ZTauElements. + + + The αu's for a=0 as an array + of TNAFs. + + + The αu's for a=1 as an array + of ZTauElements. + + + The αu's for a=1 as an array + of TNAFs. + + + Computes the norm of an element λ of + Z[τ]. + @param mu The parameter μ of the elliptic curve. + @param lambda The element λ of + Z[τ]. + @return The norm of λ. + + + Computes the norm of an element λ of + R[τ], where λ = u + vτ + and u and u are real numbers (elements of + R). + @param mu The parameter μ of the elliptic curve. + @param u The real part of the element λ of + R[τ]. + @param v The τ-adic part of the element + λ of R[τ]. + @return The norm of λ. + + + Rounds an element λ of R[τ] + to an element of Z[τ], such that their difference + has minimal norm. λ is given as + λ = λ0 + λ1τ. + @param lambda0 The component λ0. + @param lambda1 The component λ1. + @param mu The parameter μ of the elliptic curve. Must + equal 1 or -1. + @return The rounded element of Z[τ]. + @throws ArgumentException if lambda0 and + lambda1 do not have same scale. + + + Approximate division by n. For an integer + k, the value λ = s k / n is + computed to c bits of accuracy. + @param k The parameter k. + @param s The curve parameter s0 or + s1. + @param vm The Lucas Sequence element Vm. + @param a The parameter a of the elliptic curve. + @param m The bit length of the finite field + Fm. + @param c The number of bits of accuracy, i.e. the scale of the returned + SimpleBigDecimal. + @return The value λ = s k / n computed to + c bits of accuracy. + + + Computes the τ-adic NAF (non-adjacent form) of an + element λ of Z[τ]. + @param mu The parameter μ of the elliptic curve. + @param lambda The element λ of + Z[τ]. + @return The τ-adic NAF of λ. + + + Applies the operation τ() to an + F2mPoint. + @param p The F2mPoint to which τ() is applied. + @return τ(p) + + + Returns the parameter μ of the elliptic curve. + @param curve The elliptic curve from which to obtain μ. + The curve must be a Koblitz curve, i.e. a Equals + 0 or 1 and b Equals + 1. + @return μ of the elliptic curve. + @throws ArgumentException if the given ECCurve is not a Koblitz + curve. + + + Calculates the Lucas Sequence elements Uk-1 and + Uk or Vk-1 and + Vk. + @param mu The parameter μ of the elliptic curve. + @param k The index of the second element of the Lucas Sequence to be + returned. + @param doV If set to true, computes Vk-1 and + Vk, otherwise Uk-1 and + Uk. + @return An array with 2 elements, containing Uk-1 + and Uk or Vk-1 + and Vk. + + + Computes the auxiliary value tw. If the width is + 4, then for mu = 1, tw = 6 and for + mu = -1, tw = 10 + @param mu The parameter μ of the elliptic curve. + @param w The window width of the WTNAF. + @return the auxiliary value tw + + + Computes the auxiliary values s0 and + s1 used for partial modular reduction. + @param curve The elliptic curve for which to compute + s0 and s1. + @throws ArgumentException if curve is not a + Koblitz curve (Anomalous Binary Curve, ABC). + + + Partial modular reduction modulo + m - 1)/(τ - 1). + @param k The integer to be reduced. + @param m The bitlength of the underlying finite field. + @param a The parameter a of the elliptic curve. + @param s The auxiliary values s0 and + s1. + @param mu The parameter μ of the elliptic curve. + @param c The precision (number of bits of accuracy) of the partial + modular reduction. + @return ρ := k partmod (τm - 1)/(τ - 1) + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by a BigInteger using the reduced τ-adic + NAF (RTNAF) method. + @param p The F2mPoint to Multiply. + @param k The BigInteger by which to Multiply p. + @return k * p + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by an element λ of Z[τ] + using the τ-adic NAF (TNAF) method. + @param p The F2mPoint to Multiply. + @param lambda The element λ of + Z[τ]. + @return λ * p + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by an element λ of Z[τ] + using the τ-adic NAF (TNAF) method, given the TNAF + of λ. + @param p The F2mPoint to Multiply. + @param u The the TNAF of λ.. + @return λ * p + + + Computes the [τ]-adic window NAF of an element + λ of Z[τ]. + @param mu The parameter μ of the elliptic curve. + @param lambda The element λ of + Z[τ] of which to compute the + [τ]-adic NAF. + @param width The window width of the resulting WNAF. + @param pow2w 2width. + @param tw The auxiliary value tw. + @param alpha The αu's for the window width. + @return The [τ]-adic window NAF of + λ. + + + Does the precomputation for WTNAF multiplication. + @param p The ECPoint for which to do the precomputation. + @param a The parameter a of the elliptic curve. + @return The precomputation array for p. + + + Class representing an element of Z[τ]. Let + λ be an element of Z[τ]. Then + λ is given as λ = u + vτ. The + components u and v may be used directly, there + are no accessor methods. + Immutable class. + + + The "real" part of λ. + + + The "τ-adic" part of λ. + + + Constructor for an element λ of + Z[τ]. + @param u The "real" part of λ. + @param v The "τ-adic" part of + λ. + + + Base class for an elliptic curve. + + + Decode a point on this curve from its ASN.1 encoding. The different + encodings are taken account of, including point compression for + Fp (X9.62 s 4.2.1 pg 17). + @return The decoded point. + + + Elliptic curve over Fp + + + Elliptic curves over F2m. The Weierstrass equation is given by + y2 + xy = x3 + ax2 + b. + + + The exponent m of F2m. + + + TPB: The integer k where xm + + xk + 1 represents the reduction polynomial + f(z).
    + PPB: The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + TPB: Always set to 0
    + PPB: The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + TPB: Always set to 0
    + PPB: The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + The order of the base point of the curve. + + + The cofactor of the curve. + + + The point at infinity on this curve. + + + The parameter μ of the elliptic curve if this is + a Koblitz curve. + + + The auxiliary values s0 and + s1 used for partial modular reduction for + Koblitz curves. + + + Constructor for Trinomial Polynomial Basis (TPB). + @param m The exponent m of + F2m. + @param k The integer k where xm + + xk + 1 represents the reduction + polynomial f(z). + @param a The coefficient a in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param b The coefficient b in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + + + Constructor for Trinomial Polynomial Basis (TPB). + @param m The exponent m of + F2m. + @param k The integer k where xm + + xk + 1 represents the reduction + polynomial f(z). + @param a The coefficient a in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param b The coefficient b in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param n The order of the main subgroup of the elliptic curve. + @param h The cofactor of the elliptic curve, i.e. + #Ea(F2m) = h * n. + + + Constructor for Pentanomial Polynomial Basis (PPB). + @param m The exponent m of + F2m. + @param k1 The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k2 The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k3 The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param a The coefficient a in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param b The coefficient b in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + + + Constructor for Pentanomial Polynomial Basis (PPB). + @param m The exponent m of + F2m. + @param k1 The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k2 The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k3 The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param a The coefficient a in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param b The coefficient b in the Weierstrass equation + for non-supersingular elliptic curves over + F2m. + @param n The order of the main subgroup of the elliptic curve. + @param h The cofactor of the elliptic curve, i.e. + #Ea(F2m) = h * n. + + + Returns true if this is a Koblitz curve (ABC curve). + @return true if this is a Koblitz curve (ABC curve), false otherwise + + + Returns the parameter μ of the elliptic curve. + @return μ of the elliptic curve. + @throws ArgumentException if the given ECCurve is not a + Koblitz curve. + + + @return the auxiliary values s0 and + s1 used for partial modular reduction for + Koblitz curves. + + + Solves a quadratic equation z2 + z = beta(X9.62 + D.1.6) The other solution is z + 1. + + @param beta + The value to solve the qradratic equation for. + @return the solution for z2 + z = beta or + null if no solution exists. + + + Return true if curve uses a Trinomial basis. + + @return true if curve Trinomial, false otherwise. + + + return the field name for this field. + + @return the string "Fp". + + + return a sqrt root - the routine verifies that the calculation + returns the right value - if none exists it returns null. + + + Class representing the Elements of the finite field + F2m in polynomial basis (PB) + representation. Both trinomial (Tpb) and pentanomial (Ppb) polynomial + basis representations are supported. Gaussian normal basis (GNB) + representation is not supported. + + + Indicates gaussian normal basis representation (GNB). Number chosen + according to X9.62. GNB is not implemented at present. + + + Indicates trinomial basis representation (Tpb). Number chosen + according to X9.62. + + + Indicates pentanomial basis representation (Ppb). Number chosen + according to X9.62. + + + Tpb or Ppb. + + + The exponent m of F2m. + + + Tpb: The integer k where xm + + xk + 1 represents the reduction polynomial + f(z).
    + Ppb: The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + Tpb: Always set to 0
    + Ppb: The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + Tpb: Always set to 0
    + Ppb: The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + The IntArray holding the bits. + + + The number of ints required to hold m bits. + + + Constructor for Ppb. + @param m The exponent m of + F2m. + @param k1 The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k2 The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param k3 The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z). + @param x The BigInteger representing the value of the field element. + + + Constructor for Tpb. + @param m The exponent m of + F2m. + @param k The integer k where xm + + xk + 1 represents the reduction + polynomial f(z). + @param x The BigInteger representing the value of the field element. + + + Checks, if the ECFieldElements a and b + are elements of the same field F2m + (having the same representation). + @param a field element. + @param b field element to be compared. + @throws ArgumentException if a and b + are not elements of the same field + F2m (having the same + representation). + + + @return the representation of the field + F2m, either of + {@link F2mFieldElement.Tpb} (trinomial + basis representation) or + {@link F2mFieldElement.Ppb} (pentanomial + basis representation). + + + @return the degree m of the reduction polynomial + f(z). + + + @return Tpb: The integer k where xm + + xk + 1 represents the reduction polynomial + f(z).
    + Ppb: The integer k1 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + @return Tpb: Always returns 0
    + Ppb: The integer k2 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + @return Tpb: Always set to 0
    + Ppb: The integer k3 where xm + + xk3 + xk2 + xk1 + 1 + represents the reduction polynomial f(z).
    +
    + + base class for points on elliptic curves. + + + Sets the PreCompInfo. Used by ECMultipliers + to save the precomputation for this ECPoint to store the + precomputation result for use by subsequent multiplication. + @param preCompInfo The values precomputed by the + ECMultiplier. + + + Sets the appropriate ECMultiplier, unless already set. + + + return the field element encoded with point compression. (S 4.3.6) + + + Multiplies this ECPoint by the given number. + @param k The multiplicator. + @return k * this. + + + Elliptic curve points over Fp + + + Create a point which encodes with point compression. + + @param curve the curve to use + @param x affine x co-ordinate + @param y affine y co-ordinate + + + Create a point that encodes with or without point compresion. + + @param curve the curve to use + @param x affine x co-ordinate + @param y affine y co-ordinate + @param withCompression if true encode with point compression + + + Sets the default ECMultiplier, unless already set. + + + Elliptic curve points over F2m + + + @param curve base curve + @param x x point + @param y y point + + + @param curve base curve + @param x x point + @param y y point + @param withCompression true if encode with point compression. + + + Constructor for point at infinity + + + Check, if two ECPoints can be added or subtracted. + @param a The first ECPoint to check. + @param b The second ECPoint to check. + @throws IllegalArgumentException if a and b + cannot be added. + + + Adds another ECPoints.F2m to this without + checking if both points are on the same curve. Used by multiplication + algorithms, because there all points are a multiple of the same point + and hence the checks can be omitted. + @param b The other ECPoints.F2m to add to + this. + @return this + b + + + Subtracts another ECPoints.F2m from this + without checking if both points are on the same curve. Used by + multiplication algorithms, because there all points are a multiple + of the same point and hence the checks can be omitted. + @param b The other ECPoints.F2m to subtract from + this. + @return this - b + + + Sets the appropriate ECMultiplier, unless already set. + + + Interface for classes encapsulating a point multiplication algorithm + for ECPoints. + + + Multiplies the ECPoint p by k, i.e. + p is added k times to itself. + @param p The ECPoint to be multiplied. + @param k The factor by which p i multiplied. + @return p multiplied by k. + + + Class implementing the NAF (Non-Adjacent Form) multiplication algorithm. + + + D.3.2 pg 101 + @see org.bouncycastle.math.ec.multiplier.ECMultiplier#multiply(org.bouncycastle.math.ec.ECPoint, java.math.BigInteger) + + + Interface for classes storing precomputation data for multiplication + algorithms. Used as a Memento (see GOF patterns) for + WNafMultiplier. + + + Simple shift-and-add multiplication. Serves as reference implementation + to verify (possibly faster) implementations in + {@link org.bouncycastle.math.ec.ECPoint ECPoint}. + + @param p The point to multiply. + @param k The factor by which to multiply. + @return The result of the point multiplication k * p. + + + Class implementing the WNAF (Window Non-Adjacent Form) multiplication + algorithm. + + + Computes the Window NAF (non-adjacent Form) of an integer. + @param width The width w of the Window NAF. The width is + defined as the minimal number w, such that for any + w consecutive digits in the resulting representation, at + most one is non-zero. + @param k The integer of which the Window NAF is computed. + @return The Window NAF of the given width, such that the following holds: + k = −i=0l-1 ki2i + , where the ki denote the elements of the + returned sbyte[]. + + + Multiplies this by an integer k using the + Window NAF method. + @param k The integer by which this is multiplied. + @return A new ECPoint which equals this + multiplied by k. + + + Class holding precomputation data for the WNAF (Window Non-Adjacent Form) + algorithm. + + + Array holding the precomputed ECPoints used for the Window + NAF multiplication in + {@link org.bouncycastle.math.ec.multiplier.WNafMultiplier.multiply() + WNafMultiplier.multiply()}. + + + Holds an ECPoint representing twice(this). Used for the + Window NAF multiplication in + {@link org.bouncycastle.math.ec.multiplier.WNafMultiplier.multiply() + WNafMultiplier.multiply()}. + + + Class implementing the WTNAF (Window + τ-adic Non-Adjacent Form) algorithm. + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by k using the reduced τ-adic NAF (RTNAF) + method. + @param p The F2mPoint to multiply. + @param k The integer by which to multiply k. + @return p multiplied by k. + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by an element λ of Z[τ] using + the τ-adic NAF (TNAF) method. + @param p The F2mPoint to multiply. + @param lambda The element λ of + Z[τ] of which to compute the + [τ]-adic NAF. + @return p multiplied by λ. + + + Multiplies a {@link org.bouncycastle.math.ec.F2mPoint F2mPoint} + by an element λ of Z[τ] + using the window τ-adic NAF (TNAF) method, given the + WTNAF of λ. + @param p The F2mPoint to multiply. + @param u The the WTNAF of λ.. + @return λ * p + + + Class holding precomputation data for the WTNAF (Window + τ-adic Non-Adjacent Form) algorithm. + + + Array holding the precomputed F2mPoints used for the + WTNAF multiplication in + {@link org.bouncycastle.math.ec.multiplier.WTauNafMultiplier.multiply() + WTauNafMultiplier.multiply()}. + + + Constructor for WTauNafPreCompInfo + @param preComp Array holding the precomputed F2mPoints + used for the WTNAF multiplication in + {@link org.bouncycastle.math.ec.multiplier.WTauNafMultiplier.multiply() + WTauNafMultiplier.multiply()}. + + + @return the array holding the precomputed F2mPoints + used for the WTNAF multiplication in + {@link org.bouncycastle.math.ec.multiplier.WTauNafMultiplier.multiply() + WTauNafMultiplier.multiply()}. + + + + + BasicOcspResponse ::= SEQUENCE { + tbsResponseData ResponseData, + signatureAlgorithm AlgorithmIdentifier, + signature BIT STRING, + certs [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL + } + + + + + The DER encoding of the tbsResponseData field. + In the event of an encoding error. + + + The certificates, if any, associated with the response. + In the event of an encoding error. + + + + Verify the signature against the tbsResponseData object we contain. + + + + The ASN.1 encoded representation of this object. + + + Generator for basic OCSP response objects. + + + basic constructor + + + construct with the responderID to be the SHA-1 keyHash of the passed in public key. + + + Add a response for a particular Certificate ID. + + @param certID certificate ID details + @param certStatus status of the certificate - null if okay + + + Add a response for a particular Certificate ID. + + @param certID certificate ID details + @param certStatus status of the certificate - null if okay + @param singleExtensions optional extensions + + + Add a response for a particular Certificate ID. + + @param certID certificate ID details + @param nextUpdate date when next update should be requested + @param certStatus status of the certificate - null if okay + @param singleExtensions optional extensions + + + Add a response for a particular Certificate ID. + + @param certID certificate ID details + @param thisUpdate date this response was valid on + @param nextUpdate date when next update should be requested + @param certStatus status of the certificate - null if okay + @param singleExtensions optional extensions + + + Set the extensions for the response. + + @param responseExtensions the extension object to carry. + + + Return an IEnumerable of the signature names supported by the generator. + + @return an IEnumerable containing recognised names. + + + create from an issuer certificate and the serial number of the + certificate it signed. + @exception OcspException if any problems occur creating the id fields. + + + return the serial number for the certificate associated + with this request. + + + Create a new CertificateID for a new serial number derived from a previous one + calculated for the same CA certificate. + + @param original the previously calculated CertificateID for the CA. + @param newSerialNumber the serial number for the new certificate of interest. + + @return a new CertificateID for newSerialNumber + + +
    +             OcspRequest     ::=     SEQUENCE {
    +                   tbsRequest                  TBSRequest,
    +                   optionalSignature   [0]     EXPLICIT Signature OPTIONAL }
    +            
    +               TBSRequest      ::=     SEQUENCE {
    +                   version             [0]     EXPLICIT Version DEFAULT v1,
    +                   requestorName       [1]     EXPLICIT GeneralName OPTIONAL,
    +                   requestList                 SEQUENCE OF Request,
    +                   requestExtensions   [2]     EXPLICIT Extensions OPTIONAL }
    +            
    +               Signature       ::=     SEQUENCE {
    +                   signatureAlgorithm      AlgorithmIdentifier,
    +                   signature               BIT STRING,
    +                   certs               [0] EXPLICIT SEQUENCE OF Certificate OPTIONAL}
    +            
    +               Version         ::=             INTEGER  {  v1(0) }
    +            
    +               Request         ::=     SEQUENCE {
    +                   reqCert                     CertID,
    +                   singleRequestExtensions     [0] EXPLICIT Extensions OPTIONAL }
    +            
    +               CertID          ::=     SEQUENCE {
    +                   hashAlgorithm       AlgorithmIdentifier,
    +                   issuerNameHash      OCTET STRING, -- Hash of Issuer's DN
    +                   issuerKeyHash       OCTET STRING, -- Hash of Issuers public key
    +                   serialNumber        CertificateSerialNumber }
    +             
    +
    + + Return the DER encoding of the tbsRequest field. + @return DER encoding of tbsRequest + @throws OcspException in the event of an encoding error. + + + return the object identifier representing the signature algorithm + + + If the request is signed return a possibly empty CertStore containing the certificates in the + request. If the request is not signed the method returns null. + + @return null if not signed, a CertStore otherwise + @throws OcspException + + + Return whether or not this request is signed. + + @return true if signed false otherwise. + + + Verify the signature against the TBSRequest object we contain. + + + return the ASN.1 encoded representation of this object. + + + Add a request for the given CertificateID. + + @param certId certificate ID of interest + + + Add a request with extensions + + @param certId certificate ID of interest + @param singleRequestExtensions the extensions to attach to the request + + + Set the requestor name to the passed in X509Principal + + @param requestorName a X509Principal representing the requestor name. + + + Generate an unsigned request + + @return the OcspReq + @throws OcspException + + + Return an IEnumerable of the signature names supported by the generator. + + @return an IEnumerable containing recognised names. + + + return the ASN.1 encoded representation of this object. + + + base generator for an OCSP response - at the moment this only supports the + generation of responses containing BasicOCSP responses. + + + note 4 is not used. + + + Carrier for a ResponderID. + + + wrapper for the RevokedInfo object + + + return the revocation reason. Note: this field is optional, test for it + with hasRevocationReason() first. + @exception InvalidOperationException if a reason is asked for and none is avaliable + + + Return the status object for the response - null indicates good. + + @return the status object for the response, null if it is good. + + + return the NextUpdate value - note: this is an optional field so may + be returned as null. + + @return nextUpdate, or null if not present. + + + wrapper for the UnknownInfo object + + + + Utility class for creating IBasicAgreement objects from their names/Oids + + + + + Cipher Utility class contains methods that can not be specifically grouped into other classes. + + + + + Returns a ObjectIdentifier for a give encoding. + + A string representation of the encoding. + A DerObjectIdentifier, null if the Oid is not available. + + + + Utility class for creating IDigest objects from their names/Oids + + + + + Returns a ObjectIdentifier for a given digest mechanism. + + A string representation of the digest meanism. + A DerObjectIdentifier, null if the Oid is not available. + + + + Utility class for creating HMac object from their names/Oids + + + + + + + + + + Returns a ObjectIdentifier for a give encoding. + + A string representation of the encoding. + A DerObjectIdentifier, null if the Oid is not available. + + + Use the specified instance of IRandomGenerator as random source. + + This constructor performs no seeding of either the IRandomGenerator or the + constructed SecureRandom. It is the responsibility of the client to provide + proper seed material as necessary/appropriate for the given IRandomGenerator + implementation. + + The source to generate all random bytes from. + + + base constructor. + + + create a SecurityUtilityException with the given message. + + @param message the message to be carried with the exception. + + + + Signer Utility class contains methods that can not be specifically grouped into other classes. + + + + + Returns a ObjectIdentifier for a give encoding. + + A string representation of the encoding. + A DerObjectIdentifier, null if the Oid is not available. + + + + Utility class for creating IWrapper objects from their names/Oids + + + + PEM generator for the original set of PEM objects used in Open SSL. + + + Class for reading OpenSSL PEM encoded streams containing + X509 certificates, PKCS8 encoded keys and PKCS7 objects. +

    + In the case of PKCS7 objects the reader will return a CMS ContentInfo object. Keys and + Certificates will be returned using the appropriate java.security type.

    +
    + + Create a new PemReader + + @param reader the Reader + + + Create a new PemReader with a password finder + + @param reader the Reader + @param pFinder the password finder + + + Reads in a X509Certificate. + + @return the X509Certificate + @throws IOException if an I/O error occured + + + Reads in a X509CRL. + + @return the X509Certificate + @throws IOException if an I/O error occured + + + Reads in a PKCS10 certification request. + + @return the certificate request. + @throws IOException if an I/O error occured + + + Reads in a X509 Attribute Certificate. + + @return the X509 Attribute Certificate + @throws IOException if an I/O error occured + + + Reads in a PKCS7 object. This returns a ContentInfo object suitable for use with the CMS + API. + + @return the X509Certificate + @throws IOException if an I/O error occured + + + Read a Key Pair + + + General purpose writer for OpenSSL PEM objects. + + + The TextWriter object to write the output to. + + + Constructor for an unencrypted private key PEM object. + + @param key private key to be encoded. + + + Constructor for an encrypted private key PEM object. + + @param key private key to be encoded + @param algorithm encryption algorithm to use + @param provider provider to use + @throws NoSuchAlgorithmException if algorithm/mode cannot be found + + + + A class for verifying and creating Pkcs10 Certification requests. + + + CertificationRequest ::= Sequence { + certificationRequestInfo CertificationRequestInfo, + signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }}, + signature BIT STRING + } + + CertificationRequestInfo ::= Sequence { + version Integer { v1(0) } (v1,...), + subject Name, + subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }}, + attributes [0] Attributes{{ CRIAttributes }} + } + + Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }} + + Attr { ATTRIBUTE:IOSet } ::= Sequence { + type ATTRIBUTE.&id({IOSet}), + values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type}) + } + + see + + + + Instantiate a Pkcs10CertificationRequest object with the necessary credentials. + + Name of Sig Alg. + X509Name of subject eg OU="My unit." O="My Organisatioin" C="au" + Public Key to be included in cert reqest. + ASN1Set of Attributes. + Matching Private key for nominated (above) public key to be used to sign the request. + + + + Get the public key. + + The public key. + + + + Verify Pkcs10 Cert Request is valid. + + true = valid. + + + + A class for creating and verifying Pkcs10 Certification requests (this is an extension on ). + The requests are made using delay signing. This is useful for situations where + the private key is in another environment and not directly accessible (e.g. HSM) + So the first step creates the request, then the signing is done outside this + object and the signature is then used to complete the request. + + + CertificationRequest ::= Sequence { + certificationRequestInfo CertificationRequestInfo, + signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }}, + signature BIT STRING + } + + CertificationRequestInfo ::= Sequence { + version Integer { v1(0) } (v1,...), + subject Name, + subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }}, + attributes [0] Attributes{{ CRIAttributes }} + } + + Attributes { ATTRIBUTE:IOSet } ::= Set OF Attr{{ IOSet }} + + Attr { ATTRIBUTE:IOSet } ::= Sequence { + type ATTRIBUTE.&id({IOSet}), + values Set SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{\@type}) + } + + see + + + + Instantiate a Pkcs10CertificationRequest object with the necessary credentials. + + Name of Sig Alg. + X509Name of subject eg OU="My unit." O="My Organisatioin" C="au" + Public Key to be included in cert reqest. + ASN1Set of Attributes. + + After the object is constructed use the and finally the + SignRequest methods to finalize the request. + + + + simply return the cert entry for the private key + + + Utility class for reencoding PKCS#12 files to definite length. + + + Just re-encode the outer layer of the PKCS#12 file to definite length encoding. + + @param berPKCS12File - original PKCS#12 file + @return a byte array representing the DER encoding of the PFX structure + @throws IOException + + + Re-encode the PKCS#12 structure to definite length encoding at the inner layer + as well, recomputing the MAC accordingly. + + @param berPKCS12File - original PKCS12 file. + @param provider - provider to use for MAC calculation. + @return a byte array representing the DER encoding of the PFX structure. + @throws IOException on parsing, encoding errors. + + + + Returns the revocationDate. + + + + + Returns the certStatus. + + + + Returns an immutable Set of X.509 attribute certificate + extensions that this PkixAttrCertChecker supports or + null if no extensions are supported. +

    + Each element of the set is a String representing the + Object Identifier (OID) of the X.509 extension that is supported. +

    +

    + All X.509 attribute certificate extensions that a + PkixAttrCertChecker might possibly be able to process + should be included in the set. +

    + + @return an immutable Set of X.509 extension OIDs (in + String format) supported by this + PkixAttrCertChecker, or null if no + extensions are supported +
    + + Performs checks on the specified attribute certificate. Every handled + extension is rmeoved from the unresolvedCritExts + collection. + + @param attrCert The attribute certificate to be checked. + @param certPath The certificate path which belongs to the attribute + certificate issuer public key certificate. + @param holderCertPath The certificate path which belongs to the holder + certificate. + @param unresolvedCritExts a Collection of OID strings + representing the current set of unresolved critical extensions + @throws CertPathValidatorException if the specified attribute certificate + does not pass the check. + + + Returns a clone of this object. + + @return a copy of this PkixAttrCertChecker + + + Build and validate a CertPath using the given parameter. + + @param params PKIXBuilderParameters object containing all information to + build the CertPath + + + CertPathValidatorSpi implementation for X.509 Attribute Certificates la RFC 3281. + + @see org.bouncycastle.x509.ExtendedPkixParameters + + + Validates an attribute certificate with the given certificate path. + +

    + params must be an instance of + ExtendedPkixParameters. +

    + The target constraints in the params must be an + X509AttrCertStoreSelector with at least the attribute + certificate criterion set. Obey that also target informations may be + necessary to correctly validate this attribute certificate. +

    + The attribute certificate issuer must be added to the trusted attribute + issuers with {@link ExtendedPkixParameters#setTrustedACIssuers(Set)}. +

    + @param certPath The certificate path which belongs to the attribute + certificate issuer public key certificate. + @param params The PKIX parameters. + @return A PKIXCertPathValidatorResult of the result of + validating the certPath. + @throws InvalidAlgorithmParameterException if params is + inappropriate for this validator. + @throws CertPathValidatorException if the verification fails. +
    + + + Summary description for PkixBuilderParameters. + + + + Returns an instance of PkixBuilderParameters. +

    + This method can be used to get a copy from other + PKIXBuilderParameters, PKIXParameters, + and ExtendedPKIXParameters instances. +

    + + @param pkixParams The PKIX parameters to create a copy of. + @return An PkixBuilderParameters instance. +
    + + + Excluded certificates are not used for building a certification path. + + the excluded certificates. + + + + Sets the excluded certificates which are not used for building a + certification path. If the ISet is null an + empty set is assumed. + + + The given set is cloned to protect it against subsequent modifications. + + The excluded certificates to set. + + + Can alse handle ExtendedPKIXBuilderParameters and + PKIXBuilderParameters. + + @param params Parameters to set. + @see org.bouncycastle.x509.ExtendedPKIXParameters#setParams(java.security.cert.PKIXParameters) + + + Makes a copy of this PKIXParameters object. Changes to the + copy will not affect the original and vice versa. + + @return a copy of this PKIXParameters object + + + An immutable sequence of certificates (a certification path).
    +
    + This is an abstract class that defines the methods common to all CertPaths. + Subclasses can handle different kinds of certificates (X.509, PGP, etc.).
    +
    + All CertPath objects have a type, a list of Certificates, and one or more + supported encodings. Because the CertPath class is immutable, a CertPath + cannot change in any externally visible way after being constructed. This + stipulation applies to all public fields and methods of this class and any + added or overridden by subclasses.
    +
    + The type is a string that identifies the type of Certificates in the + certification path. For each certificate cert in a certification path + certPath, cert.getType().equals(certPath.getType()) must be true.
    +
    + The list of Certificates is an ordered List of zero or more Certificates. + This List and all of the Certificates contained in it must be immutable.
    +
    + Each CertPath object must support one or more encodings so that the object + can be translated into a byte array for storage or transmission to other + parties. Preferably, these encodings should be well-documented standards + (such as PKCS#7). One of the encodings supported by a CertPath is considered + the default encoding. This encoding is used if no encoding is explicitly + requested (for the {@link #getEncoded()} method, for instance).
    +
    + All CertPath objects are also Serializable. CertPath objects are resolved + into an alternate {@link CertPathRep} object during serialization. This + allows a CertPath object to be serialized into an equivalent representation + regardless of its underlying implementation.
    +
    + CertPath objects can be created with a CertificateFactory or they can be + returned by other classes, such as a CertPathBuilder.
    +
    + By convention, X.509 CertPaths (consisting of X509Certificates), are ordered + starting with the target certificate and ending with a certificate issued by + the trust anchor. That is, the issuer of one certificate is the subject of + the following one. The certificate representing the + {@link TrustAnchor TrustAnchor} should not be included in the certification + path. Unvalidated X.509 CertPaths may not follow these conventions. PKIX + CertPathValidators will detect any departure from these conventions that + cause the certification path to be invalid and throw a + CertPathValidatorException.
    +
    + Concurrent Access
    +
    + All CertPath objects must be thread-safe. That is, multiple threads may + concurrently invoke the methods defined in this class on a single CertPath + object (or more than one) with no ill effects. This is also true for the List + returned by CertPath.getCertificates.
    +
    + Requiring CertPath objects to be immutable and thread-safe allows them to be + passed around to various pieces of code without worrying about coordinating + access. Providing this thread-safety is generally not difficult, since the + CertPath and List objects in question are immutable. + + @see CertificateFactory + @see CertPathBuilder + + CertPath implementation for X.509 certificates. + +
    + + @param certs + + + Creates a CertPath of the specified type. + This constructor is protected because most users should use + a CertificateFactory to create CertPaths. + @param type the standard name of the type of Certificatesin this path + + + + Creates a CertPath of the specified type. + This constructor is protected because most users should use + a CertificateFactory to create CertPaths. + + @param type the standard name of the type of Certificatesin this path + + + + Returns an iteration of the encodings supported by this + certification path, with the default encoding + first. Attempts to modify the returned Iterator via its + remove method result in an UnsupportedOperationException. + + @return an Iterator over the names of the supported encodings (as Strings) + + + + Compares this certification path for equality with the specified object. + Two CertPaths are equal if and only if their types are equal and their + certificate Lists (and by implication the Certificates in those Lists) + are equal. A CertPath is never equal to an object that is not a CertPath.
    +
    + This algorithm is implemented by this method. If it is overridden, the + behavior specified here must be maintained. + + @param other + the object to test for equality with this certification path + + @return true if the specified object is equal to this certification path, + false otherwise + + @see Object#hashCode() Object.hashCode() +
    + + Returns the encoded form of this certification path, using + the default encoding. + + @return the encoded bytes + @exception CertificateEncodingException if an encoding error occurs + + + + Returns the encoded form of this certification path, using + the specified encoding. + + @param encoding the name of the encoding to use + @return the encoded bytes + @exception CertificateEncodingException if an encoding error + occurs or the encoding requested is not supported + + + + + Returns the list of certificates in this certification + path. + + + + Return a DERObject containing the encoded certificate. + + @param cert the X509Certificate object to be encoded + + @return the DERObject + + + + Implements the PKIX CertPathBuilding algorithm for BouncyCastle. + + @see CertPathBuilderSpi + + + Build and validate a CertPath using the given parameter. + + @param params PKIXBuilderParameters object containing all information to + build the CertPath + + + + Summary description for PkixCertPathBuilderException. + + + + + Summary description for PkixCertPathBuilderResult. + + + + * Initializes the internal state of this PKIXCertPathChecker. + *

    + * The forward flag specifies the order that certificates + * will be passed to the {@link #check check} method (forward or reverse). A + * PKIXCertPathChecker must support reverse checking + * and may support forward checking. + *

    + * + * @param forward + * the order that certificates are presented to the + * check method. If true, + * certificates are presented from target to most-trusted CA + * (forward); if false, from most-trusted CA to + * target (reverse). + * @exception CertPathValidatorException + * if this PKIXCertPathChecker is unable to + * check certificates in the specified order; it should never + * be thrown if the forward flag is false since reverse + * checking must be supported +
    + + Indicates if forward checking is supported. Forward checking refers to + the ability of the PKIXCertPathChecker to perform its + checks when certificates are presented to the check method + in the forward direction (from target to most-trusted CA). + + @return true if forward checking is supported, + false otherwise + + + * Returns an immutable Set of X.509 certificate extensions + * that this PKIXCertPathChecker supports (i.e. recognizes, + * is able to process), or null if no extensions are + * supported. + *

    + * Each element of the set is a String representing the + * Object Identifier (OID) of the X.509 extension that is supported. The OID + * is represented by a set of nonnegative integers separated by periods. + *

    + * All X.509 certificate extensions that a PKIXCertPathChecker + * might possibly be able to process should be included in the set. + *

    + * + * @return an immutable Set of X.509 extension OIDs (in + * String format) supported by this + * PKIXCertPathChecker, or null if no + * extensions are supported +
    + + Performs the check(s) on the specified certificate using its internal + state and removes any critical extensions that it processes from the + specified collection of OID strings that represent the unresolved + critical extensions. The certificates are presented in the order + specified by the init method. + + @param cert + the Certificate to be checked + @param unresolvedCritExts + a Collection of OID strings representing the + current set of unresolved critical extensions + @exception CertPathValidatorException + if the specified certificate does not pass the check + + + Returns a clone of this object. Calls the Object.clone() + method. All subclasses which maintain state must support and override + this method, if necessary. + + @return a copy of this PKIXCertPathChecker + + + The Service Provider Interface (SPI) + for the {@link CertPathValidator CertPathValidator} class. All + CertPathValidator implementations must include a class (the + SPI class) that extends this class (CertPathValidatorSpi) + and implements all of its methods. In general, instances of this class + should only be accessed through the CertPathValidator class. + For details, see the Java Cryptography Architecture.
    +
    + Concurrent Access
    +
    + Instances of this class need not be protected against concurrent + access from multiple threads. Threads that need to access a single + CertPathValidatorSpi instance concurrently should synchronize + amongst themselves and provide the necessary locking before calling the + wrapping CertPathValidator object.
    +
    + However, implementations of CertPathValidatorSpi may still + encounter concurrency issues, since multiple threads each + manipulating a different CertPathValidatorSpi instance need not + synchronize. + + CertPathValidatorSpi implementation for X.509 Certificate validation a la RFC + 3280. + +
    + + An exception indicating one of a variety of problems encountered when + validating a certification path.
    +
    + A CertPathValidatorException provides support for wrapping + exceptions. The {@link #getCause getCause} method returns the throwable, + if any, that caused this exception to be thrown.
    +
    + A CertPathValidatorException may also include the + certification path that was being validated when the exception was thrown + and the index of the certificate in the certification path that caused the + exception to be thrown. Use the {@link #getCertPath getCertPath} and + {@link #getIndex getIndex} methods to retrieve this information.
    +
    + Concurrent Access
    +
    + Unless otherwise specified, the methods defined in this class are not + thread-safe. Multiple threads that need to access a single + object concurrently should synchronize amongst themselves and + provide the necessary locking. Multiple threads each manipulating + separate objects need not synchronize. + + @see CertPathValidator + +
    + + + Creates a PkixCertPathValidatorException with the given detail + message. A detail message is a String that describes this + particular exception. + + the detail message + + + + Creates a PkixCertPathValidatorException with the specified + detail message and cause. + + the detail message + the cause (which is saved for later retrieval by the + {@link #getCause getCause()} method). (A null + value is permitted, and indicates that the cause is + nonexistent or unknown.) + + + + Creates a PkixCertPathValidatorException with the specified + detail message, cause, certification path, and index. + + the detail message (or null if none) + the cause (or null if none) + the certification path that was in the process of being + validated when the error was encountered + the index of the certificate in the certification path that * + + + + Returns the detail message for this CertPathValidatorException. + + the detail message, or null if neither the message nor cause were specified + + + Returns the certification path that was being validated when the + exception was thrown. + + @return the CertPath that was being validated when the + exception was thrown (or null if not specified) + + + Returns the index of the certificate in the certification path that + caused the exception to be thrown. Note that the list of certificates in + a CertPath is zero based. If no index has been set, -1 is + returned. + + @return the index that has been set, or -1 if none has been set + + + + Summary description for PkixCertPathValidatorResult. + + + + + Summary description for PkixCertPathValidatorUtilities. + + + + + key usage bits + + + + + Search the given Set of TrustAnchor's for one that is the + issuer of the given X509 certificate. + + the X509 certificate + a Set of TrustAnchor's + the TrustAnchor object if found or + null if not. + + @exception + + + + Returns the issuer of an attribute certificate or certificate. + + The attribute certificate or certificate. + The issuer as X500Principal. + + + Return the next working key inheriting DSA parameters if necessary. +

    + This methods inherits DSA parameters from the indexed certificate or + previous certificates in the certificate chain to the returned + PublicKey. The list is searched upwards, meaning the end + certificate is at position 0 and previous certificates are following. +

    +

    + If the indexed certificate does not contain a DSA key this method simply + returns the public key. If the DSA key already contains DSA parameters + the key is also only returned. +

    + + @param certs The certification path. + @param index The index of the certificate which contains the public key + which should be extended with DSA parameters. + @return The public key of the certificate in list position + index extended with DSA parameters if applicable. + @throws Exception if DSA parameters cannot be inherited. +
    + + + Return a Collection of all certificates or attribute certificates found + in the X509Store's that are matching the certSelect criteriums. + + a {@link Selector} object that will be used to select + the certificates + a List containing only X509Store objects. These + are used to search for certificates. + a Collection of all found or + org.bouncycastle.x509.X509AttributeCertificate objects. + May be empty but never null. + + + + Add the CRL issuers from the cRLIssuer field of the distribution point or + from the certificate if not given to the issuer criterion of the + selector. +

    + The issuerPrincipals are a collection with a single + X500Principal for X509Certificates. For + {@link X509AttributeCertificate}s the issuer may contain more than one + X500Principal. +

    + + @param dp The distribution point. + @param issuerPrincipals The issuers of the certificate or attribute + certificate which contains the distribution point. + @param selector The CRL selector. + @param pkixParams The PKIX parameters containing the cert stores. + @throws Exception if an exception occurs while processing. + @throws ClassCastException if issuerPrincipals does not + contain only X500Principals. +
    + + Fetches complete CRLs according to RFC 3280. + + @param dp The distribution point for which the complete CRL + @param cert The X509Certificate or + {@link org.bouncycastle.x509.X509AttributeCertificate} for + which the CRL should be searched. + @param currentDate The date for which the delta CRLs must be valid. + @param paramsPKIX The extended PKIX parameters. + @return A Set of X509CRLs with complete + CRLs. + @throws Exception if an exception occurs while picking the CRLs + or no CRLs are found. + + + Fetches delta CRLs according to RFC 3280 section 5.2.4. + + @param currentDate The date for which the delta CRLs must be valid. + @param paramsPKIX The extended PKIX parameters. + @param completeCRL The complete CRL the delta CRL is for. + @return A Set of X509CRLs with delta CRLs. + @throws Exception if an exception occurs while picking the delta + CRLs. + + + Find the issuer certificates of a given certificate. + + @param cert + The certificate for which an issuer should be found. + @param pkixParams + @return A Collection object containing the issuer + X509Certificates. Never null. + + @exception Exception + if an error occurs. + + + + Extract the value of the given extension, if it exists. + + The extension object. + The object identifier to obtain. + Asn1Object + if the extension cannot be read. + + + + crl checking + Return a Collection of all CRLs found in the X509Store's that are + matching the crlSelect criteriums. + + a {@link X509CRLStoreSelector} object that will be used + to select the CRLs + a List containing only {@link org.bouncycastle.x509.X509Store + X509Store} objects. These are used to search for CRLs + a Collection of all found {@link X509CRL X509CRL} objects. May be + empty but never null. + + + + Returns the intersection of the permitted IP ranges in + permitted with ip. + + @param permitted A Set of permitted IP addresses with + their subnet mask as byte arrays. + @param ips The IP address with its subnet mask. + @return The Set of permitted IP ranges intersected with + ip. + + + Returns the union of the excluded IP ranges in excluded + with ip. + + @param excluded A Set of excluded IP addresses with their + subnet mask as byte arrays. + @param ip The IP address with its subnet mask. + @return The Set of excluded IP ranges unified with + ip as byte arrays. + + + Calculates the union if two IP ranges. + + @param ipWithSubmask1 The first IP address with its subnet mask. + @param ipWithSubmask2 The second IP address with its subnet mask. + @return A Set with the union of both addresses. + + + Calculates the interesction if two IP ranges. + + @param ipWithSubmask1 The first IP address with its subnet mask. + @param ipWithSubmask2 The second IP address with its subnet mask. + @return A Set with the single IP address with its subnet + mask as a byte array or an empty Set. + + + Concatenates the IP address with its subnet mask. + + @param ip The IP address. + @param subnetMask Its subnet mask. + @return The concatenated IP address with its subnet mask. + + + Splits the IP addresses and their subnet mask. + + @param ipWithSubmask1 The first IP address with the subnet mask. + @param ipWithSubmask2 The second IP address with the subnet mask. + @return An array with two elements. Each element contains the IP address + and the subnet mask in this order. + + + Based on the two IP addresses and their subnet masks the IP range is + computed for each IP address - subnet mask pair and returned as the + minimum IP address and the maximum address of the range. + + @param ip1 The first IP address. + @param subnetmask1 The subnet mask of the first IP address. + @param ip2 The second IP address. + @param subnetmask2 The subnet mask of the second IP address. + @return A array with two elements. The first/second element contains the + min and max IP address of the first/second IP address and its + subnet mask. + + + Checks if the IP ip is included in the permitted ISet + permitted. + + @param permitted A Set of permitted IP addresses with + their subnet mask as byte arrays. + @param ip The IP address. + @throws PkixNameConstraintValidatorException + if the IP is not permitted. + + + Checks if the IP ip is included in the excluded ISet + excluded. + + @param excluded A Set of excluded IP addresses with their + subnet mask as byte arrays. + @param ip The IP address. + @throws PkixNameConstraintValidatorException + if the IP is excluded. + + + Checks if the IP address ip is constrained by + constraint. + + @param ip The IP address. + @param constraint The constraint. This is an IP address concatenated with + its subnetmask. + @return true if constrained, false + otherwise. + + + The common part of email1 and email2 is + added to the union union. If email1 and + email2 have nothing in common they are added both. + + @param email1 Email address constraint 1. + @param email2 Email address constraint 2. + @param union The union. + + + The most restricting part from email1 and + email2 is added to the intersection intersect. + + @param email1 Email address constraint 1. + @param email2 Email address constraint 2. + @param intersect The intersection. + + + Checks if the given GeneralName is in the permitted ISet. + + @param name The GeneralName + @throws PkixNameConstraintValidatorException + If the name + + + Check if the given GeneralName is contained in the excluded ISet. + + @param name The GeneralName. + @throws PkixNameConstraintValidatorException + If the name is + excluded. + + + Updates the permitted ISet of these name constraints with the intersection + with the given subtree. + + @param permitted The permitted subtrees + + + Adds a subtree to the excluded ISet of these name constraints. + + @param subtree A subtree with an excluded GeneralName. + + + Returns the maximum IP address. + + @param ip1 The first IP address. + @param ip2 The second IP address. + @return The maximum IP address. + + + Returns the minimum IP address. + + @param ip1 The first IP address. + @param ip2 The second IP address. + @return The minimum IP address. + + + Compares IP address ip1 with ip2. If ip1 + is equal to ip2 0 is returned. If ip1 is bigger 1 is returned, -1 + otherwise. + + @param ip1 The first IP address. + @param ip2 The second IP address. + @return 0 if ip1 is equal to ip2, 1 if ip1 is bigger, -1 otherwise. + + + Returns the logical OR of the IP addresses ip1 and + ip2. + + @param ip1 The first IP address. + @param ip2 The second IP address. + @return The OR of ip1 and ip2. + + + Stringifies an IPv4 or v6 address with subnet mask. + + @param ip The IP with subnet mask. + @return The stringified IP address. + + + + Summary description for PkixParameters. + + + + This is the default PKIX validity model. Actually there are two variants + of this: The PKIX model and the modified PKIX model. The PKIX model + verifies that all involved certificates must have been valid at the + current time. The modified PKIX model verifies that all involved + certificates were valid at the signing time. Both are indirectly choosen + with the {@link PKIXParameters#setDate(java.util.Date)} method, so this + methods sets the Date when all certificates must have been + valid. + + + This model uses the following validity model. Each certificate must have + been valid at the moment where is was used. That means the end + certificate must have been valid at the time the signature was done. The + CA certificate which signed the end certificate must have been valid, + when the end certificate was signed. The CA (or Root CA) certificate must + have been valid, when the CA certificate was signed and so on. So the + {@link PKIXParameters#setDate(java.util.Date)} method sets the time, when + the end certificate must have been valid.

    It is used e.g. + in the German signature law. + + + Creates an instance of PKIXParameters with the specified Set of + most-trusted CAs. Each element of the set is a TrustAnchor.
    +
    + Note that the Set is copied to protect against subsequent modifications. + + @param trustAnchors + a Set of TrustAnchors + + @exception InvalidAlgorithmParameterException + if the specified Set is empty + (trustAnchors.isEmpty() == true) + @exception NullPointerException + if the specified Set is null + @exception ClassCastException + if any of the elements in the Set are not of type + java.security.cert.TrustAnchor +
    + + Returns the required constraints on the target certificate. The + constraints are returned as an instance of CertSelector. If + null, no constraints are defined.
    +
    + Note that the CertSelector returned is cloned to protect against + subsequent modifications. + + @return a CertSelector specifying the constraints on the target + certificate (or null) + + @see #setTargetCertConstraints(CertSelector) +
    + + Sets the required constraints on the target certificate. The constraints + are specified as an instance of CertSelector. If null, no constraints are + defined.
    +
    + Note that the CertSelector specified is cloned to protect against + subsequent modifications. + + @param selector + a CertSelector specifying the constraints on the target + certificate (or null) + + @see #getTargetCertConstraints() +
    + + Returns an immutable Set of initial policy identifiers (OID strings), + indicating that any one of these policies would be acceptable to the + certificate user for the purposes of certification path processing. The + default return value is an empty Set, which is + interpreted as meaning that any policy would be acceptable. + + @return an immutable Set of initial policy OIDs in String + format, or an empty Set (implying any policy is + acceptable). Never returns null. + + @see #setInitialPolicies(java.util.Set) + + + Sets the Set of initial policy identifiers (OID strings), + indicating that any one of these policies would be acceptable to the + certificate user for the purposes of certification path processing. By + default, any policy is acceptable (i.e. all policies), so a user that + wants to allow any policy as acceptable does not need to call this + method, or can call it with an empty Set (or + null).
    +
    + Note that the Set is copied to protect against subsequent modifications.
    +
    + + @param initialPolicies + a Set of initial policy OIDs in String format (or + null) + + @exception ClassCastException + if any of the elements in the set are not of type String + + @see #getInitialPolicies() +
    + + Sets a List of additional certification path checkers. If + the specified List contains an object that is not a PKIXCertPathChecker, + it is ignored.
    +
    + Each PKIXCertPathChecker specified implements additional + checks on a certificate. Typically, these are checks to process and + verify private extensions contained in certificates. Each + PKIXCertPathChecker should be instantiated with any + initialization parameters needed to execute the check.
    +
    + This method allows sophisticated applications to extend a PKIX + CertPathValidator or CertPathBuilder. Each + of the specified PKIXCertPathCheckers will be called, in turn, by a PKIX + CertPathValidator or CertPathBuilder for + each certificate processed or validated.
    +
    + Regardless of whether these additional PKIXCertPathCheckers are set, a + PKIX CertPathValidator or CertPathBuilder + must perform all of the required PKIX checks on each certificate. The one + exception to this rule is if the RevocationEnabled flag is set to false + (see the {@link #setRevocationEnabled(boolean) setRevocationEnabled} + method).
    +
    + Note that the List supplied here is copied and each PKIXCertPathChecker + in the list is cloned to protect against subsequent modifications. + + @param checkers + a List of PKIXCertPathCheckers. May be null, in which case no + additional checkers will be used. + @exception ClassCastException + if any of the elements in the list are not of type + java.security.cert.PKIXCertPathChecker + @see #getCertPathCheckers() +
    + + Returns the List of certification path checkers. Each PKIXCertPathChecker + in the returned IList is cloned to protect against subsequent modifications. + + @return an immutable List of PKIXCertPathCheckers (may be empty, but not + null) + + @see #setCertPathCheckers(java.util.List) + + + Adds a PKIXCertPathChecker to the list of certification + path checkers. See the {@link #setCertPathCheckers setCertPathCheckers} + method for more details. +

    + Note that the PKIXCertPathChecker is cloned to protect + against subsequent modifications.

    + + @param checker a PKIXCertPathChecker to add to the list of + checks. If null, the checker is ignored (not added to list). +
    + + Method to support Clone() under J2ME. + super.Clone() does not exist and fields are not copied. + + @param params Parameters to set. If this are + ExtendedPkixParameters they are copied to. + + + Whether delta CRLs should be used for checking the revocation status. + Defaults to false. + + + The validity model. + @see #CHAIN_VALIDITY_MODEL + @see #PKIX_VALIDITY_MODEL + + + Sets the Bouncy Castle Stores for finding CRLs, certificates, attribute + certificates or cross certificates. +

    + The IList is cloned. +

    + + @param stores A list of stores to use. + @see #getStores + @throws ClassCastException if an element of stores is not + a {@link Store}. +
    + + Adds a Bouncy Castle {@link Store} to find CRLs, certificates, attribute + certificates or cross certificates. +

    + This method should be used to add local stores, like collection based + X.509 stores, if available. Local stores should be considered first, + before trying to use additional (remote) locations, because they do not + need possible additional network traffic. +

    + If store is null it is ignored. +

    + + @param store The store to add. + @see #getStores +
    + + Adds an additional Bouncy Castle {@link Store} to find CRLs, certificates, + attribute certificates or cross certificates. +

    + You should not use this method. This method is used for adding additional + X.509 stores, which are used to add (remote) locations, e.g. LDAP, found + during X.509 object processing, e.g. in certificates or CRLs. This method + is used in PKIX certification path processing. +

    + If store is null it is ignored. +

    + + @param store The store to add. + @see #getStores() +
    + + Returns an IList of additional Bouncy Castle + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of additional Bouncy Castle + Stores. Never null. + + @see #addAddionalStore(Store) + + + Returns an IList of Bouncy Castle + Stores used for finding CRLs, certificates, attribute + certificates or cross certificates. + + @return an immutable IList of Bouncy Castle + Stores. Never null. + + @see #setStores(IList) + + + Returns if additional {@link X509Store}s for locations like LDAP found + in certificates or CRLs should be used. + + @return Returns true if additional stores are used. + + + Sets if additional {@link X509Store}s for locations like LDAP found in + certificates or CRLs should be used. + + @param enabled true if additional stores are used. + + + Returns the required constraints on the target certificate or attribute + certificate. The constraints are returned as an instance of + IX509Selector. If null, no constraints are + defined. + +

    + The target certificate in a PKIX path may be a certificate or an + attribute certificate. +

    + Note that the IX509Selector returned is cloned to protect + against subsequent modifications. +

    + @return a IX509Selector specifying the constraints on the + target certificate or attribute certificate (or null) + @see #setTargetConstraints + @see X509CertStoreSelector + @see X509AttributeCertStoreSelector +
    + + Sets the required constraints on the target certificate or attribute + certificate. The constraints are specified as an instance of + IX509Selector. If null, no constraints are + defined. +

    + The target certificate in a PKIX path may be a certificate or an + attribute certificate. +

    + Note that the IX509Selector specified is cloned to protect + against subsequent modifications. +

    + + @param selector a IX509Selector specifying the constraints on + the target certificate or attribute certificate (or + null) + @see #getTargetConstraints + @see X509CertStoreSelector + @see X509AttributeCertStoreSelector +
    + + Returns the trusted attribute certificate issuers. If attribute + certificates is verified the trusted AC issuers must be set. +

    + The returned ISet consists of TrustAnchors. +

    + The returned ISet is immutable. Never null +

    + + @return Returns an immutable set of the trusted AC issuers. +
    + + Sets the trusted attribute certificate issuers. If attribute certificates + is verified the trusted AC issuers must be set. +

    + The trustedACIssuers must be a ISet of + TrustAnchor +

    + The given set is cloned. +

    + + @param trustedACIssuers The trusted AC issuers to set. Is never + null. + @throws ClassCastException if an element of stores is not + a TrustAnchor. +
    + + Returns the neccessary attributes which must be contained in an attribute + certificate. +

    + The returned ISet is immutable and contains + Strings with the OIDs. +

    + + @return Returns the necessary AC attributes. +
    + + Sets the neccessary which must be contained in an attribute certificate. +

    + The ISet must contain Strings with the + OIDs. +

    + The set is cloned. +

    + + @param necessaryACAttributes The necessary AC attributes to set. + @throws ClassCastException if an element of + necessaryACAttributes is not a + String. +
    + + Returns the attribute certificates which are not allowed. +

    + The returned ISet is immutable and contains + Strings with the OIDs. +

    + + @return Returns the prohibited AC attributes. Is never null. +
    + + Sets the attribute certificates which are not allowed. +

    + The ISet must contain Strings with the + OIDs. +

    + The set is cloned. +

    + + @param prohibitedACAttributes The prohibited AC attributes to set. + @throws ClassCastException if an element of + prohibitedACAttributes is not a + String. +
    + + Returns the attribute certificate checker. The returned set contains + {@link PKIXAttrCertChecker}s and is immutable. + + @return Returns the attribute certificate checker. Is never + null. + + + Sets the attribute certificate checkers. +

    + All elements in the ISet must a {@link PKIXAttrCertChecker}. +

    +

    + The given set is cloned. +

    + + @param attrCertCheckers The attribute certificate checkers to set. Is + never null. + @throws ClassCastException if an element of attrCertCheckers + is not a PKIXAttrCertChecker. +
    + + + Summary description for PkixPolicyNode. + + + + Constructors + + + + This class helps to handle CRL revocation reasons mask. Each CRL handles a + certain set of revocation reasons. + + + + + Constructs are reason mask with the reasons. + + The reasons. + + + + A reason mask with no reason. + + + + + A mask with all revocation reasons. + + + + Adds all reasons from the reasons mask to this mask. + + @param mask The reasons mask to add. + + + + Returns true if this reasons mask contains all possible + reasons. + + true if this reasons mask contains all possible reasons. + + + + + Intersects this mask with the given reasons mask. + + mask The mask to intersect with. + The intersection of this and teh given mask. + + + + Returns true if the passed reasons mask has new reasons. + + The reasons mask which should be tested for new reasons. + true if the passed reasons mask has new reasons. + + + + Returns the reasons in this mask. + + + + If the complete CRL includes an issuing distribution point (IDP) CRL + extension check the following: +

    + (i) If the distribution point name is present in the IDP CRL extension + and the distribution field is present in the DP, then verify that one of + the names in the IDP matches one of the names in the DP. If the + distribution point name is present in the IDP CRL extension and the + distribution field is omitted from the DP, then verify that one of the + names in the IDP matches one of the names in the cRLIssuer field of the + DP. +

    +

    + (ii) If the onlyContainsUserCerts boolean is asserted in the IDP CRL + extension, verify that the certificate does not include the basic + constraints extension with the cA boolean asserted. +

    +

    + (iii) If the onlyContainsCACerts boolean is asserted in the IDP CRL + extension, verify that the certificate includes the basic constraints + extension with the cA boolean asserted. +

    +

    + (iv) Verify that the onlyContainsAttributeCerts boolean is not asserted. +

    + + @param dp The distribution point. + @param cert The certificate. + @param crl The CRL. + @throws AnnotatedException if one of the conditions is not met or an error occurs. +
    + + If the DP includes cRLIssuer, then verify that the issuer field in the + complete CRL matches cRLIssuer in the DP and that the complete CRL + contains an + g distribution point extension with the indirectCRL + boolean asserted. Otherwise, verify that the CRL issuer matches the + certificate issuer. + + @param dp The distribution point. + @param cert The certificate ot attribute certificate. + @param crl The CRL for cert. + @throws AnnotatedException if one of the above conditions does not apply or an error + occurs. + + + Obtain and validate the certification path for the complete CRL issuer. + If a key usage extension is present in the CRL issuer's certificate, + verify that the cRLSign bit is set. + + @param crl CRL which contains revocation information for the certificate + cert. + @param cert The attribute certificate or certificate to check if it is + revoked. + @param defaultCRLSignCert The issuer certificate of the certificate cert. + @param defaultCRLSignKey The public key of the issuer certificate + defaultCRLSignCert. + @param paramsPKIX paramsPKIX PKIX parameters. + @param certPathCerts The certificates on the certification path. + @return A Set with all keys of possible CRL issuer + certificates. + @throws AnnotatedException if the CRL is not valid or the status cannot be checked or + some error occurs. + + + Checks a distribution point for revocation information for the + certificate cert. + + @param dp The distribution point to consider. + @param paramsPKIX PKIX parameters. + @param cert Certificate to check if it is revoked. + @param validDate The date when the certificate revocation status should be + checked. + @param defaultCRLSignCert The issuer certificate of the certificate cert. + @param defaultCRLSignKey The public key of the issuer certificate + defaultCRLSignCert. + @param certStatus The current certificate revocation status. + @param reasonMask The reasons mask which is already checked. + @param certPathCerts The certificates of the certification path. + @throws AnnotatedException if the certificate is revoked or the status cannot be checked + or some error occurs. + + + Checks a certificate if it is revoked. + + @param paramsPKIX PKIX parameters. + @param cert Certificate to check if it is revoked. + @param validDate The date when the certificate revocation status should be + checked. + @param sign The issuer certificate of the certificate cert. + @param workingPublicKey The public key of the issuer certificate sign. + @param certPathCerts The certificates of the certification path. + @throws AnnotatedException if the certificate is revoked or the status cannot be checked + or some error occurs. + + + If use-deltas is set, verify the issuer and scope of the delta CRL. + + @param deltaCRL The delta CRL. + @param completeCRL The complete CRL. + @param pkixParams The PKIX paramaters. + @throws AnnotatedException if an exception occurs. + + + Checks if an attribute certificate is revoked. + + @param attrCert Attribute certificate to check if it is revoked. + @param paramsPKIX PKIX parameters. + @param issuerCert The issuer certificate of the attribute certificate + attrCert. + @param validDate The date when the certificate revocation status should + be checked. + @param certPathCerts The certificates of the certification path to be + checked. + + @throws CertPathValidatorException if the certificate is revoked or the + status cannot be checked or some error occurs. + + + Searches for a holder public key certificate and verifies its + certification path. + + @param attrCert the attribute certificate. + @param pkixParams The PKIX parameters. + @return The certificate path of the holder certificate. + @throws Exception if +
      +
    • no public key certificate can be found although holder + information is given by an entity name or a base certificate + ID
    • +
    • support classes cannot be created
    • +
    • no certification path for the public key certificate can + be built
    • +
    +
    + + + Checks a distribution point for revocation information for the + certificate attrCert. + + @param dp The distribution point to consider. + @param attrCert The attribute certificate which should be checked. + @param paramsPKIX PKIX parameters. + @param validDate The date when the certificate revocation status should + be checked. + @param issuerCert Certificate to check if it is revoked. + @param reasonMask The reasons mask which is already checked. + @param certPathCerts The certificates of the certification path to be + checked. + @throws Exception if the certificate is revoked or the status + cannot be checked or some error occurs. + + + + A trust anchor or most-trusted Certification Authority (CA). + + This class represents a "most-trusted CA", which is used as a trust anchor + for validating X.509 certification paths. A most-trusted CA includes the + public key of the CA, the CA's name, and any constraints upon the set of + paths which may be validated using this key. These parameters can be + specified in the form of a trusted X509Certificate or as individual + parameters. + + + + + Creates an instance of TrustAnchor with the specified X509Certificate and + optional name constraints, which are intended to be used as additional + constraints when validating an X.509 certification path. + The name constraints are specified as a byte array. This byte array + should contain the DER encoded form of the name constraints, as they + would appear in the NameConstraints structure defined in RFC 2459 and + X.509. The ASN.1 definition of this structure appears below. + +
    +            	NameConstraints ::= SEQUENCE {
    +            		permittedSubtrees       [0]     GeneralSubtrees OPTIONAL,
    +            		excludedSubtrees        [1]     GeneralSubtrees OPTIONAL }
    +            	   
    +             GeneralSubtrees ::= SEQUENCE SIZE (1..MAX) OF GeneralSubtree
    +             
    +            		GeneralSubtree ::= SEQUENCE {
    +            		base                    GeneralName,
    +            		minimum         [0]     BaseDistance DEFAULT 0,
    +            		maximum         [1]     BaseDistance OPTIONAL }
    +            		
    +            		BaseDistance ::= INTEGER (0..MAX)
    +            
    +            		GeneralName ::= CHOICE {
    +            		otherName                       [0]     OtherName,
    +            		rfc822Name                      [1]     IA5String,
    +            		dNSName                         [2]     IA5String,
    +            		x400Address                     [3]     ORAddress,
    +            		directoryName                   [4]     Name,
    +            		ediPartyName                    [5]     EDIPartyName,
    +            		uniformResourceIdentifier       [6]     IA5String,
    +            		iPAddress                       [7]     OCTET STRING,
    +            		registeredID                    [8]     OBJECT IDENTIFIER}
    +            	
    + + Note that the name constraints byte array supplied is cloned to protect + against subsequent modifications. +
    + a trusted X509Certificate + a byte array containing the ASN.1 DER encoding of a + NameConstraints extension to be used for checking name + constraints. Only the value of the extension is included, not + the OID or criticality flag. Specify null to omit the + parameter. + if the specified X509Certificate is null +
    + + + Creates an instance of TrustAnchor where the + most-trusted CA is specified as an X500Principal and public key. + + +

    + Name constraints are an optional parameter, and are intended to be used + as additional constraints when validating an X.509 certification path. +

    + The name constraints are specified as a byte array. This byte array + contains the DER encoded form of the name constraints, as they + would appear in the NameConstraints structure defined in RFC 2459 + and X.509. The ASN.1 notation for this structure is supplied in the + documentation for the other constructors. +

    + Note that the name constraints byte array supplied here is cloned to + protect against subsequent modifications. +

    +
    + the name of the most-trusted CA as X509Name + the public key of the most-trusted CA + + a byte array containing the ASN.1 DER encoding of a NameConstraints extension to + be used for checking name constraints. Only the value of the extension is included, + not the OID or criticality flag. Specify null to omit the parameter. + + + if caPrincipal or pubKey is null + +
    + + + Creates an instance of TrustAnchor where the most-trusted + CA is specified as a distinguished name and public key. Name constraints + are an optional parameter, and are intended to be used as additional + constraints when validating an X.509 certification path. +
    + The name constraints are specified as a byte array. This byte array + contains the DER encoded form of the name constraints, as they would + appear in the NameConstraints structure defined in RFC 2459 and X.509. +
    + the X.500 distinguished name of the most-trusted CA in RFC + 2253 string format + the public key of the most-trusted CA + a byte array containing the ASN.1 DER encoding of a + NameConstraints extension to be used for checking name + constraints. Only the value of the extension is included, not + the OID or criticality flag. Specify null to omit the + parameter. + throws NullPointerException, IllegalArgumentException +
    + + + Returns the most-trusted CA certificate. + + + + + Returns the name of the most-trusted CA as an X509Name. + + + + + Returns the name of the most-trusted CA in RFC 2253 string format. + + + + + Returns the public key of the most-trusted CA. + + + + + Decode the name constraints and clone them if not null. + + + + + Returns a formatted string describing the TrustAnchor. + + a formatted string describing the TrustAnchor + + + Base class for an RFC 3161 Time Stamp Request. + + + Create a TimeStampRequest from the past in byte array. + + @param req byte array containing the request. + @throws IOException if the request is malformed. + + + Create a TimeStampRequest from the past in input stream. + + @param in input stream containing the request. + @throws IOException if the request is malformed. + + + Validate the timestamp request, checking the digest to see if it is of an + accepted type and whether it is of the correct length for the algorithm specified. + + @param algorithms a set of string OIDS giving accepted algorithms. + @param policies if non-null a set of policies we are willing to sign under. + @param extensions if non-null a set of extensions we are willing to accept. + @throws TspException if the request is invalid, or processing fails. + + + return the ASN.1 encoded representation of this object. + + + Generator for RFC 3161 Time Stamp Request objects. + + + add a given extension field for the standard extensions tag (tag 3) + @throws IOException + + + add a given extension field for the standard extensions tag + The value parameter becomes the contents of the octet string associated + with the extension. + + + add a given extension field for the standard extensions tag (tag 3) + @throws IOException + + + add a given extension field for the standard extensions tag + The value parameter becomes the contents of the octet string associated + with the extension. + + + Base class for an RFC 3161 Time Stamp Response object. + + + Create a TimeStampResponse from a byte array containing an ASN.1 encoding. + + @param resp the byte array containing the encoded response. + @throws TspException if the response is malformed. + @throws IOException if the byte array doesn't represent an ASN.1 encoding. + + + Create a TimeStampResponse from an input stream containing an ASN.1 encoding. + + @param input the input stream containing the encoded response. + @throws TspException if the response is malformed. + @throws IOException if the stream doesn't represent an ASN.1 encoding. + + + Check this response against to see if it a well formed response for + the passed in request. Validation will include checking the time stamp + token if the response status is GRANTED or GRANTED_WITH_MODS. + + @param request the request to be checked against + @throws TspException if the request can not match this response. + + + return the ASN.1 encoded representation of this object. + + + Generator for RFC 3161 Time Stamp Responses. + + + Return an appropriate TimeStampResponse. +

    + If genTime is null a timeNotAvailable error response will be returned. + + @param request the request this response is for. + @param serialNumber serial number for the response token. + @param genTime generation time for the response token. + @param provider provider to use for signature calculation. + @return + @throws NoSuchAlgorithmException + @throws NoSuchProviderException + @throws TSPException +

    +
    + + Generate a TimeStampResponse with chosen status and FailInfoField. + + @param status the PKIStatus to set. + @param failInfoField the FailInfoField to set. + @param statusString an optional string describing the failure. + @return a TimeStampResponse with a failInfoField and optional statusString + @throws TSPException in case the response could not be created + + + Validate the time stamp token. +

    + To be valid the token must be signed by the passed in certificate and + the certificate must be the one referred to by the SigningCertificate + attribute included in the hashed attributes of the token. The + certificate must also have the ExtendedKeyUsageExtension with only + KeyPurposeID.IdKPTimeStamping and have been valid at the time the + timestamp was created. +

    +

    + A successful call to validate means all the above are true. +

    +
    + + Return the underlying CmsSignedData object. + + @return the underlying CMS structure. + + + Return a ASN.1 encoded byte stream representing the encoded object. + + @throws IOException if encoding fails. + + + basic creation - only the default attributes will be included here. + + + create with a signer with extra signed/unsigned attributes. + + + @return the nonce value, null if there isn't one. + + + Recognised hash algorithms for the time stamp protocol. + + + Fetches the signature time-stamp attributes from a SignerInformation object. + Checks that the MessageImprint for each time-stamp matches the signature field. + (see RFC 3161 Appendix A). + + @param signerInfo a SignerInformation to search for time-stamps + @return a collection of TimeStampToken objects + @throws TSPValidationException + + + Validate the passed in certificate as being of the correct type to be used + for time stamping. To be valid it must have an ExtendedKeyUsage extension + which has a key purpose identifier of id-kp-timeStamping. + + @param cert the certificate of interest. + @throws TspValidationException if the certicate fails on one of the check points. + + + + Return the digest algorithm using one of the standard JCA string + representations rather than the algorithm identifier (if possible). + + + + Exception thrown if a TSP request or response fails to validate. +

    + If a failure code is associated with the exception it can be retrieved using + the getFailureCode() method.

    +
    + + Return the failure code associated with this exception - if one is set. + + @return the failure code if set, -1 otherwise. + + + General array utilities. + + + + Are two arrays equal. + + Left side. + Right side. + True if equal. + + + + A constant time equals comparison - does not terminate early if + test will fail. + + first array + second array + true if arrays equal, false otherwise. + + + BigInteger utilities. + + + Return the passed in value as an unsigned byte array. + + @param value value to be converted. + @return a byte array without a leading zero byte if present in the signed encoding. + + + Return a random BigInteger not less than 'min' and not greater than 'max' + + @param min the least value that may be generated + @param max the greatest value that may be generated + @param random the source of randomness + @return a random BigInteger value in the range [min,max] + + + + Return the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC) for a given DateTime value. + + A UTC DateTime value not before epoch. + Number of whole milliseconds after epoch. + 'dateTime' is before epoch. + + + + Create a DateTime value from the number of milliseconds since the Unix epoch (1 Jan., 1970 UTC). + + Number of milliseconds since the epoch. + A UTC DateTime value + + + + Return the current number of milliseconds since the Unix epoch (1 Jan., 1970 UTC). + + + + encode the input data producing a base 64 encoded byte array. + + @return a byte array containing the base 64 encoded data. + + + Encode the byte data to base 64 writing it to the given output stream. + + @return the number of bytes produced. + + + Encode the byte data to base 64 writing it to the given output stream. + + @return the number of bytes produced. + + + decode the base 64 encoded input data. It is assumed the input data is valid. + + @return a byte array representing the decoded data. + + + decode the base 64 encoded string data - whitespace will be ignored. + + @return a byte array representing the decoded data. + + + decode the base 64 encoded string data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + encode the input data producing a base 64 output stream. + + @return the number of bytes produced. + + + decode the base 64 encoded byte data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + decode the base 64 encoded string data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + + A buffering class to allow translation from one format to another to + be done in discrete chunks. + + + + + Create a buffered Decoder. + + The translater to use. + The size of the buffer. + + + + Process one byte of data. + + Data in. + Byte array for the output. + The offset in the output byte array to start writing from. + The amount of output bytes. + + + + Process data from a byte array. + + The input data. + Start position within input data array. + Amount of data to process from input data array. + Array to store output. + Position in output array to start writing from. + The amount of output bytes. + + + + A class that allows encoding of data using a specific encoder to be processed in chunks. + + + + + Create. + + The translator to use. + Size of the chunks. + + + + Process one byte of data. + + The byte. + An array to store output in. + Offset within output array to start writing from. + + + + + Process data from a byte array. + + Input data Byte array containing data to be processed. + Start position within input data array. + Amount of input data to be processed. + Output data array. + Offset within output data array to start writing to. + The amount of data written. + + + + Class to decode and encode Hex. + + + + encode the input data producing a Hex encoded byte array. + + @return a byte array containing the Hex encoded data. + + + encode the input data producing a Hex encoded byte array. + + @return a byte array containing the Hex encoded data. + + + Hex encode the byte data writing it to the given output stream. + + @return the number of bytes produced. + + + Hex encode the byte data writing it to the given output stream. + + @return the number of bytes produced. + + + decode the Hex encoded input data. It is assumed the input data is valid. + + @return a byte array representing the decoded data. + + + decode the Hex encoded string data - whitespace will be ignored. + + @return a byte array representing the decoded data. + + + decode the Hex encoded string data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + encode the input data producing a Hex output stream. + + @return the number of bytes produced. + + + decode the Hex encoded byte data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + decode the Hex encoded string data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + + A hex translator. + + + + + Return encoded block size. + + 2 + + + + Encode some data. + + Input data array. + Start position within input data array. + The amount of data to process. + The output data array. + The offset within the output data array to start writing from. + Amount of data encoded. + + + + Returns the decoded block size. + + 1 + + + + Decode data from a byte array. + + The input data array. + Start position within input data array. + The amounty of data to process. + The output data array. + The position within the output data array to start writing from. + The amount of data written. + + + Encode and decode byte arrays (typically from binary to 7-bit ASCII + encodings). + + + + Translator interface. + + + + Convert binary data to and from UrlBase64 encoding. This is identical to + Base64 encoding, except that the padding character is "." and the other + non-alphanumeric characters are "-" and "_" instead of "+" and "/". +

    + The purpose of UrlBase64 encoding is to provide a compact encoding of binary + data that is safe for use as an URL parameter. Base64 encoding does not + produce encoded values that are safe for use in URLs, since "/" can be + interpreted as a path delimiter; "+" is the encoded form of a space; and + "=" is used to separate a name from the corresponding value in an URL + parameter. +

    +
    + + Encode the input data producing a URL safe base 64 encoded byte array. + + @return a byte array containing the URL safe base 64 encoded data. + + + Encode the byte data writing it to the given output stream. + + @return the number of bytes produced. + + + Decode the URL safe base 64 encoded input data - white space will be ignored. + + @return a byte array representing the decoded data. + + + decode the URL safe base 64 encoded byte data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + decode the URL safe base 64 encoded string data - whitespace will be ignored. + + @return a byte array representing the decoded data. + + + Decode the URL safe base 64 encoded string data writing it to the given output stream, + whitespace characters will be ignored. + + @return the number of bytes produced. + + + Convert binary data to and from UrlBase64 encoding. This is identical to + Base64 encoding, except that the padding character is "." and the other + non-alphanumeric characters are "-" and "_" instead of "+" and "/". +

    + The purpose of UrlBase64 encoding is to provide a compact encoding of binary + data that is safe for use as an URL parameter. Base64 encoding does not + produce encoded values that are safe for use in URLs, since "/" can be + interpreted as a path delimiter; "+" is the encoded form of a space; and + "=" is used to separate a name from the corresponding value in an URL + parameter. +

    +
    + + + A + + + + + + A + + + A + + + + + + A + + + + + A generic PEM writer, based on RFC 1421 + + + Base constructor. + + @param out output stream to use. + + + Return the number of bytes or characters required to contain the + passed in object if it is PEM encoded. + + @param obj pem object to be output + @return an estimate of the number of bytes + + + + Pipe all bytes from inStr to outStr, throwing StreamFlowException if greater + than limit bytes in inStr. + + + A + + + A + + + A + + The number of bytes actually transferred, if not greater than limit + + + + Validate the given IPv4 or IPv6 address. + + @param address the IP address as a string. + + @return true if a valid address, false otherwise + + + Validate the given IPv4 or IPv6 address and netmask. + + @param address the IP address as a string. + + @return true if a valid address with netmask, false otherwise + + + Validate the given IPv4 address. + + @param address the IP address as a string. + + @return true if a valid IPv4 address, false otherwise + + + Validate the given IPv6 address. + + @param address the IP address as a string. + + @return true if a valid IPv4 address, false otherwise + + + General string utilities. + + + + Summary description for DeflaterOutputStream. + + + + + Summary description for DeflaterOutputStream. + + + + + The Holder object. +
    +            Holder ::= SEQUENCE {
    +            	baseCertificateID   [0] IssuerSerial OPTIONAL,
    +            		-- the issuer and serial number of
    +            		-- the holder's Public Key Certificate
    +            	entityName          [1] GeneralNames OPTIONAL,
    +            		-- the name of the claimant or role
    +            	objectDigestInfo    [2] ObjectDigestInfo OPTIONAL
    +            		-- used to directly authenticate the holder,
    +            		-- for example, an executable
    +            }
    +            
    +
    +
    + + Constructs a holder for v2 attribute certificates with a hash value for + some type of object. +

    + digestedObjectType can be one of the following: +

      +
    • 0 - publicKey - A hash of the public key of the holder must be + passed.
    • +
    • 1 - publicKeyCert - A hash of the public key certificate of the + holder must be passed.
    • +
    • 2 - otherObjectDigest - A hash of some other object type must be + passed. otherObjectTypeID must not be empty.
    • +
    +

    +

    This cannot be used if a v1 attribute certificate is used.

    + + @param digestedObjectType The digest object type. + @param digestAlgorithm The algorithm identifier for the hash. + @param otherObjectTypeID The object type ID if + digestedObjectType is + otherObjectDigest. + @param objectDigest The hash value. +
    + + Returns the digest object type if an object digest info is used. +

    +

      +
    • 0 - publicKey - A hash of the public key of the holder must be + passed.
    • +
    • 1 - publicKeyCert - A hash of the public key certificate of the + holder must be passed.
    • +
    • 2 - otherObjectDigest - A hash of some other object type must be + passed. otherObjectTypeID must not be empty.
    • +
    +

    + + @return The digest object type or -1 if no object digest info is set. +
    + + Returns the other object type ID if an object digest info is used. + + @return The other object type ID or null if no object + digest info is set. + + + Returns the hash if an object digest info is used. + + @return The hash or null if no object digest info is set. + + + Returns the digest algorithm ID if an object digest info is used. + + @return The digest algorithm ID or null if no object + digest info is set. + + + Return any principal objects inside the attribute certificate holder entity names field. + + @return an array of IPrincipal objects (usually X509Name), null if no entity names field is set. + + + Return the principals associated with the issuer attached to this holder + + @return an array of principals, null if no BaseCertificateID is set. + + + Return the serial number associated with the issuer attached to this holder. + + @return the certificate serial number, null if no BaseCertificateID is set. + + + Carrying class for an attribute certificate issuer. + + + Set the issuer directly with the ASN.1 structure. + + @param issuer The issuer + + + Return any principal objects inside the attribute certificate issuer object. + An array of IPrincipal objects (usually X509Principal). + + + A high level authority key identifier. + + + Constructor which will take the byte[] returned from getExtensionValue() + + @param encodedValue a DER octet encoded string with the extension structure in it. + @throws IOException on parsing errors. + + + Create an AuthorityKeyIdentifier using the passed in certificate's public + key, issuer and serial number. + + @param certificate the certificate providing the information. + @throws CertificateParsingException if there is a problem processing the certificate + + + Create an AuthorityKeyIdentifier using just the hash of the + public key. + + @param pubKey the key to generate the hash from. + @throws InvalidKeyException if there is a problem using the key. + + + A high level subject key identifier. + + + Constructor which will take the byte[] returned from getExtensionValue() + + @param encodedValue a DER octet encoded string with the extension structure in it. + @throws IOException on parsing errors. + + + Interface for an X.509 Attribute Certificate. + + + The version number for the certificate. + + + The serial number for the certificate. + + + The UTC DateTime before which the certificate is not valid. + + + The UTC DateTime after which the certificate is not valid. + + + The holder of the certificate. + + + The issuer details for the certificate. + + + Return the attributes contained in the attribute block in the certificate. + An array of attributes. + + + Return the attributes with the same type as the passed in oid. + The object identifier we wish to match. + An array of matched attributes, null if there is no match. + + + Return an ASN.1 encoded byte array representing the attribute certificate. + An ASN.1 encoded byte array. + If the certificate cannot be encoded. + + + + Get all critical extension values, by oid + + IDictionary with string (OID) keys and Asn1OctetString values + + + + Get all non-critical extension values, by oid + + IDictionary with string (OID) keys and Asn1OctetString values + + + + A utility class that will extract X509Principal objects from X.509 certificates. +

    + Use this in preference to trying to recreate a principal from a string, not all + DNs are what they should be, so it's best to leave them encoded where they + can be.

    +
    +
    + + Return the issuer of the given cert as an X509Principal. + + + Return the subject of the given cert as an X509Principal. + + + Return the issuer of the given CRL as an X509Principal. + + + This class is an Selector like implementation to select + attribute certificates from a given set of criteria. + + @see org.bouncycastle.x509.X509AttributeCertificate + @see org.bouncycastle.x509.X509Store + + + + Decides if the given attribute certificate should be selected. + + The attribute certificate to be checked. + true if the object matches this selector. + + + The attribute certificate which must be matched. + If null is given, any will do. + + + The criteria for validity + If null is given any will do. + + + The holder. + If null is given any will do. + + + The issuer. + If null is given any will do. + + + The serial number. + If null is given any will do. + + + Adds a target name criterion for the attribute certificate to the target + information extension criteria. The X509AttributeCertificate + must contain at least one of the specified target names. +

    + Each attribute certificate may contain a target information extension + limiting the servers where this attribute certificate can be used. If + this extension is not present, the attribute certificate is not targeted + and may be accepted by any server. +

    + + @param name The name as a GeneralName (not null) +
    + + Adds a target name criterion for the attribute certificate to the target + information extension criteria. The X509AttributeCertificate + must contain at least one of the specified target names. +

    + Each attribute certificate may contain a target information extension + limiting the servers where this attribute certificate can be used. If + this extension is not present, the attribute certificate is not targeted + and may be accepted by any server. +

    + + @param name a byte array containing the name in ASN.1 DER encoded form of a GeneralName + @throws IOException if a parsing error occurs. +
    + + Adds a collection with target names criteria. If null is + given any will do. +

    + The collection consists of either GeneralName objects or byte[] arrays representing + DER encoded GeneralName structures. +

    + + @param names A collection of target names. + @throws IOException if a parsing error occurs. + @see #AddTargetName(byte[]) + @see #AddTargetName(GeneralName) +
    + + Gets the target names. The collection consists of Lists + made up of an Integer in the first entry and a DER encoded + byte array or a String in the second entry. +

    The returned collection is immutable.

    + + @return The collection of target names + @see #setTargetNames(Collection) +
    + + Adds a target group criterion for the attribute certificate to the target + information extension criteria. The X509AttributeCertificate + must contain at least one of the specified target groups. +

    + Each attribute certificate may contain a target information extension + limiting the servers where this attribute certificate can be used. If + this extension is not present, the attribute certificate is not targeted + and may be accepted by any server. +

    + + @param group The group as GeneralName form (not null) +
    + + Adds a target group criterion for the attribute certificate to the target + information extension criteria. The X509AttributeCertificate + must contain at least one of the specified target groups. +

    + Each attribute certificate may contain a target information extension + limiting the servers where this attribute certificate can be used. If + this extension is not present, the attribute certificate is not targeted + and may be accepted by any server. +

    + + @param name a byte array containing the group in ASN.1 DER encoded form of a GeneralName + @throws IOException if a parsing error occurs. +
    + + Adds a collection with target groups criteria. If null is + given any will do. +

    + The collection consists of GeneralName objects or byte[] + representing DER encoded GeneralNames. +

    + + @param names A collection of target groups. + @throws IOException if a parsing error occurs. + @see #AddTargetGroup(byte[]) + @see #AddTargetGroup(GeneralName) +
    + + Gets the target groups. The collection consists of Lists + made up of an Integer in the first entry and a DER encoded + byte array or a String in the second entry. +

    The returned collection is immutable.

    + + @return The collection of target groups. + @see #setTargetGroups(Collection) +
    + + + This class is an IX509Selector implementation to select + certificate pairs, which are e.g. used for cross certificates. The set of + criteria is given from two X509CertStoreSelector objects, + each of which, if present, must match the respective component of a pair. + + + + The certificate pair which is used for testing on equality. + + + The certificate selector for the forward part. + + + The certificate selector for the reverse part. + + + + Decides if the given certificate pair should be selected. If + obj is not a X509CertificatePair, this method + returns false. + + The X509CertificatePair to be tested. + true if the object matches this selector. + + + + An ISet of DerObjectIdentifier objects. + + + + A simple collection backed store. + + + Basic constructor. + + @param collection - initial contents for the store, this is copied. + + + Return the matches in the collection for the passed in selector. + + @param selector the selector to match against. + @return a possibly empty collection of matching objects. + + + This class contains a collection for collection based X509Stores. + + + + Constructor. +

    + The collection is copied. +

    +
    + The collection containing X.509 object types. + If collection is null. +
    + + Returns a copy of the ICollection. + + + Returns a formatted string describing the parameters. + + + + An ICollection of X509Name objects + + + + The attribute certificate being checked. This is not a criterion. + Rather, it is optional information that may help a {@link X509Store} find + CRLs that would be relevant when checking revocation for the specified + attribute certificate. If null is specified, then no such + optional information is provided. + + @param attrCert the IX509AttributeCertificate being checked (or + null) + @see #getAttrCertificateChecking() + + + If true only complete CRLs are returned. Defaults to + false. + + @return true if only complete CRLs are returned. + + + Returns if this selector must match CRLs with the delta CRL indicator + extension set. Defaults to false. + + @return Returns true if only CRLs with the delta CRL + indicator extension are selected. + + + The issuing distribution point. +

    + The issuing distribution point extension is a CRL extension which + identifies the scope and the distribution point of a CRL. The scope + contains among others information about revocation reasons contained in + the CRL. Delta CRLs and complete CRLs must have matching issuing + distribution points.

    +

    + The byte array is cloned to protect against subsequent modifications.

    +

    + You must also enable or disable this criteria with + {@link #setIssuingDistributionPointEnabled(bool)}.

    + + @param issuingDistributionPoint The issuing distribution point to set. + This is the DER encoded OCTET STRING extension value. + @see #getIssuingDistributionPoint() +
    + + Whether the issuing distribution point criteria should be applied. + Defaults to false. +

    + You may also set the issuing distribution point criteria if not a missing + issuing distribution point should be assumed.

    + + @return Returns if the issuing distribution point check is enabled. +
    + + The maximum base CRL number. Defaults to null. + + @return Returns the maximum base CRL number. + @see #setMaxBaseCRLNumber(BigInteger) + + + + A factory to produce Public Key Info Objects. + + + + + Create a Subject Public Key Info object for a given public key. + + One of ElGammalPublicKeyParameters, DSAPublicKeyParameter, DHPublicKeyParameters, RsaKeyParameters or ECPublicKeyParameters + A subject public key info object. + Throw exception if object provided is not one of the above. + + + + Create loading data from byte array. + + + + + + Create loading data from byte array. + + + + + Generates a certificate object and initializes it with the data + read from the input stream inStream. + + + Returns a (possibly empty) collection view of the certificates + read from the given input stream inStream. + + + Class for carrying the values in an X.509 Attribute. + + + @param at an object representing an attribute. + + + Create an X.509 Attribute with the type given by the passed in oid and + the value represented by an ASN.1 Set containing value. + + @param oid type of the attribute + @param value value object to go into the atribute's value set. + + + Create an X.59 Attribute with the type given by the passed in oid and the + value represented by an ASN.1 Set containing the objects in value. + + @param oid type of the attribute + @param value vector of values to go in the attribute's value set. + + + + An Object representing an X509 Certificate. + Has static methods for loading Certificates encoded in many forms that return X509Certificate Objects. + + + + + Return true if the current time is within the start and end times nominated on the certificate. + + true id certificate is valid for the current time. + + + + Return true if the nominated time is within the start and end times nominated on the certificate. + + The time to test validity against. + True if certificate is valid for nominated time. + + + + Checks if the current date is within certificate's validity period. + + + + + Checks if the given date is within certificate's validity period. + + if the certificate is expired by given date + if the certificate is not yet valid on given date + + + + Return the certificate's version. + + An integer whose value Equals the version of the cerficate. + + + + Return a BigInteger containing the serial number. + + The Serial number. + + + + Get the Issuer Distinguished Name. (Who signed the certificate.) + + And X509Object containing name and value pairs. + + + + Get the subject of this certificate. + + An X509Name object containing name and value pairs. + + + + The time that this certificate is valid from. + + A DateTime object representing that time in the local time zone. + + + + The time that this certificate is valid up to. + + A DateTime object representing that time in the local time zone. + + + + Return the Der encoded TbsCertificate data. + This is the certificate component less the signature. + To Get the whole certificate call the GetEncoded() member. + + A byte array containing the Der encoded Certificate component. + + + + The signature. + + A byte array containg the signature of the certificate. + + + + A meaningful version of the Signature Algorithm. (EG SHA1WITHRSA) + + A sting representing the signature algorithm. + + + + Get the Signature Algorithms Object ID. + + A string containg a '.' separated object id. + + + + Get the signature algorithms parameters. (EG DSA Parameters) + + A byte array containing the Der encoded version of the parameters or null if there are none. + + + + Get the issuers UID. + + A DerBitString. + + + + Get the subjects UID. + + A DerBitString. + + + + Get a key usage guidlines. + + + + + Get the public key of the subject of the certificate. + + The public key parameters. + + + + Return a Der encoded version of this certificate. + + A byte array. + + + + Verify the certificate's signature using the nominated public key. + + An appropriate public key parameter object, RsaPublicKeyParameters, DsaPublicKeyParameters or ECDsaPublicKeyParameters + True if the signature is valid. + If key submitted is not of the above nominated types. + + + + This class contains a cross certificate pair. Cross certificates pairs may + contain two cross signed certificates from two CAs. A certificate from the + other CA to this CA is contained in the forward certificate, the certificate + from this CA to the other CA is contained in the reverse certificate. + + + + Constructor + Certificate from the other CA to this CA. + Certificate from this CA to the other CA. + + + Constructor from a ASN.1 CertificatePair structure. + The CertificatePair ASN.1 object. + + + Returns the certificate from the other CA to this CA. + + + Returns the certificate from this CA to the other CA. + + + class for dealing with X509 certificates. +

    + At the moment this will deal with "-----BEGIN CERTIFICATE-----" to "-----END CERTIFICATE-----" + base 64 encoded certs, as well as the BER binaries of certificates and some classes of PKCS#7 + objects.

    +
    + + + Create loading data from byte array. + + + + + + Create loading data from byte array. + + + + + Generates a certificate object and initializes it with the data + read from the input stream inStream. + + + Returns a (possibly empty) collection view of the certificates + read from the given input stream inStream. + + + + Create loading data from byte array. + + + + + + Create loading data from byte array. + + + + + The following extensions are listed in RFC 2459 as relevant to CRLs + + Authority Key Identifier + Issuer Alternative Name + CRL Number + Delta CRL Indicator (critical) + Issuing Distribution Point (critical) + + + Returns a string representation of this CRL. + + @return a string representation of this CRL. + + + Checks whether the given certificate is on this CRL. + + @param cert the certificate to check for. + @return true if the given certificate is on this CRL, + false otherwise. + + + The following extensions are listed in RFC 2459 as relevant to CRL Entries + + ReasonCode Hode Instruction Code Invalidity Date Certificate Issuer + (critical) + + + Constructor for CRLEntries of indirect CRLs. If isIndirect + is false {@link #getCertificateIssuer()} will always + return null, previousCertificateIssuer is + ignored. If this isIndirect is specified and this CrlEntry + has no certificate issuer CRL entry extension + previousCertificateIssuer is returned by + {@link #getCertificateIssuer()}. + + @param c + TbsCertificateList.CrlEntry object. + @param isIndirect + true if the corresponding CRL is a indirect + CRL. + @param previousCertificateIssuer + Certificate issuer of the previous CrlEntry. + + + + Create loading data from byte array. + + + + + + Create loading data from byte array. + + + + + Generates a certificate revocation list (CRL) object and initializes + it with the data read from the input stream inStream. + + + Returns a (possibly empty) collection view of the CRLs read from + the given input stream inStream. + + The inStream may contain a sequence of DER-encoded CRLs, or + a PKCS#7 CRL set. This is a PKCS#7 SignedData object, with the + only significant field being crls. In particular the signature + and the contents are ignored. + + + + Get non critical extensions. + + A set of non critical extension oids. + + + + Get any critical extensions. + + A sorted list of critical entension. + + + + Get the value of a given extension. + + The object ID of the extension. + An Asn1OctetString object if that extension is found or null if not. + + + A holding class for constructing an X509 Key Usage extension. + +
    +                id-ce-keyUsage OBJECT IDENTIFIER ::=  { id-ce 15 }
    +            
    +                KeyUsage ::= BIT STRING {
    +                     digitalSignature        (0),
    +                     nonRepudiation          (1),
    +                     keyEncipherment         (2),
    +                     dataEncipherment        (3),
    +                     keyAgreement            (4),
    +                     keyCertSign             (5),
    +                     cRLSign                 (6),
    +                     encipherOnly            (7),
    +                     decipherOnly            (8) }
    +             
    +
    + + Basic constructor. + + @param usage - the bitwise OR of the Key Usage flags giving the + allowed uses for the key. + e.g. (X509KeyUsage.keyEncipherment | X509KeyUsage.dataEncipherment) + + + Return the digest algorithm using one of the standard JCA string + representations rather than the algorithm identifier (if possible). + + + + Class to Generate X509V1 Certificates. + + + + + Default Constructor. + + + + + Reset the generator. + + + + + Set the certificate's serial number. + + Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data. + You will be surprised how ugly a serial number collision can get. + The serial number. + + + + Set the issuer distinguished name. + The issuer is the entity whose private key is used to sign the certificate. + + The issuers DN. + + + + Set the date that this certificate is to be valid from. + + + + + + Set the date after which this certificate will no longer be valid. + + + + + + Set the subject distinguished name. + The subject describes the entity associated with the public key. + + + + + + Set the public key that this certificate identifies. + + + + + + Set the signature algorithm that will be used to sign this certificate. + This can be either a name or an OID, names are treated as case insensitive. + + string representation of the algorithm name + + + + Generate a new X509Certificate. + + The private key of the issuer used to sign this certificate. + An X509Certificate. + + + + Generate a new X509Certificate specifying a SecureRandom instance that you would like to use. + + The private key of the issuer used to sign this certificate. + The Secure Random you want to use. + An X509Certificate. + + + + Allows enumeration of the signature names supported by the generator. + + + + An implementation of a version 2 X.509 Attribute Certificate. + + + Class to produce an X.509 Version 2 AttributeCertificate. + + + Reset the generator + + + Set the Holder of this Attribute Certificate. + + + Set the issuer. + + + Set the serial number for the certificate. + + + + Set the signature algorithm. This can be either a name or an OID, names + are treated as case insensitive. + + The algorithm name. + + + Add an attribute. + + + Add a given extension field for the standard extensions tag. + + + + Add a given extension field for the standard extensions tag. + The value parameter becomes the contents of the octet string associated + with the extension. + + + + + Generate an X509 certificate, based on the current issuer and subject. + + + + + Generate an X509 certificate, based on the current issuer and subject, + using the supplied source of randomness, if required. + + + + + Allows enumeration of the signature names supported by the generator. + + + + class to produce an X.509 Version 2 CRL. + + + reset the generator + + + Set the issuer distinguished name - the issuer is the entity whose private key is used to sign the + certificate. + + + Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise + or 0 if CrlReason is not to be used + + + + Add a CRL entry with an Invalidity Date extension as well as a CrlReason extension. + Reason being as indicated by CrlReason, i.e. CrlReason.KeyCompromise + or 0 if CrlReason is not to be used + + + + Add a CRL entry with extensions. + + + + Add the CRLEntry objects contained in a previous CRL. + + @param other the X509Crl to source the other entries from. + + + Set the signature algorithm. This can be either a name or an oid, names + are treated as case insensitive. + + @param signatureAlgorithm string representation of the algorithm name. + + + add a given extension field for the standard extensions tag (tag 0) + + + add a given extension field for the standard extensions tag (tag 0) + + + add a given extension field for the standard extensions tag (tag 0) + + + add a given extension field for the standard extensions tag (tag 0) + + + Generate an X509 CRL, based on the current issuer and subject. + The key used for signing. + + + Generate an X509 CRL, based on the current issuer and subject. + The key used for signing. + A user-defined source of randomness. + + + + Allows enumeration of the signature names supported by the generator. + + + + + A class to Generate Version 3 X509Certificates. + + + + + Reset the Generator. + + + + + Set the certificate's serial number. + + Make serial numbers long, if you have no serial number policy make sure the number is at least 16 bytes of secure random data. + You will be surprised how ugly a serial number collision can Get. + The serial number. + + + + Set the distinguished name of the issuer. + The issuer is the entity which is signing the certificate. + + The issuer's DN. + + + + Set the date that this certificate is to be valid from. + + + + + + Set the date after which this certificate will no longer be valid. + + + + + + Set the DN of the entity that this certificate is about. + + + + + + Set the public key that this certificate identifies. + + + + + + Set the signature algorithm that will be used to sign this certificate. + + + + + + Set the subject unique ID - note: it is very rare that it is correct to do this. + + + + + + Set the issuer unique ID - note: it is very rare that it is correct to do this. + + + + + + Add a given extension field for the standard extensions tag (tag 3). + + string containing a dotted decimal Object Identifier. + Is it critical. + The value. + + + + Add an extension to this certificate. + + Its Object Identifier. + Is it critical. + The value. + + + + Add an extension using a string with a dotted decimal OID. + + string containing a dotted decimal Object Identifier. + Is it critical. + byte[] containing the value of this extension. + + + + Add an extension to this certificate. + + Its Object Identifier. + Is it critical. + byte[] containing the value of this extension. + + + + Add a given extension field for the standard extensions tag (tag 3), + copying the extension value from another certificate. + + + + add a given extension field for the standard extensions tag (tag 3) + copying the extension value from another certificate. + @throws CertificateParsingException if the extension cannot be extracted. + + + + Generate an X509Certificate. + + The private key of the issuer that is signing this certificate. + An X509Certificate. + + + + Generate an X509Certificate using your own SecureRandom. + + The private key of the issuer that is signing this certificate. + You Secure Random instance. + An X509Certificate. + + + + Allows enumeration of the signature names supported by the generator. + + + + diff --git a/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache b/obj/Debug/DesignTimeResolveAssemblyReferencesInput.cache index 0fcf44efb59c5afff5a0d4d9c0ed08a3f8ec09bc..df9d4aed3759f1f9636ae7fa15dcad20f7de0596 100644 GIT binary patch literal 18557 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 delta 770 zcmYk2O-~b16oz}TGjv*7N^MKZS4kU0q1I}Ghzhp!!xjbGN*xMTIvpl5W@efULkJ;N ze}eREP29NEXo^b~#I+0m0Ez#AohuX1y%lwmJ2~(3p09g9j0cXL2FD0(VMb*ePO?@Z6rD^;nko+arq9PexJqd@w5{&!Y$DInU1oeH!an84&MTzx3_~%GD|0UDwe7-`_}mY@P_O{s#sujj$I0gb5S+67`jcj_J;b&9T*R7lDqIa zBy;mvU1!T;F3b&i$pX3+csJza?x9yiFY7Mv8kVYe-y+!_u98&SpMdF+1hxrBO*#`ScyRX=-YNP0suo5`)I*49UXFvHHKa&B5o1Dtw6cLSt;0+(%R8@>uW! z`_!Ni_HYGMo2Z_0^f{K`IIM9GkZn^2n-M{v{2>yV5{6 z)v$_^wVgAYdcjik7XJkK(7`GsdxG};7B7P6D)`qBx(~|IUQX4N6-ifGd=(PeJXyyD Zsyx4eehpHSHP=7@L;Cd=JIUO9&u + + + +
    + + + + + + + + + + + + + + + False + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/obj/Debug/Omnibus.csproj.CoreCompileInputs.cache b/obj/Debug/Omnibus.csproj.CoreCompileInputs.cache index 415ecf6..deb797f 100644 --- a/obj/Debug/Omnibus.csproj.CoreCompileInputs.cache +++ b/obj/Debug/Omnibus.csproj.CoreCompileInputs.cache @@ -1 +1 @@ -3aa95803eca7cb013af7e351f492994d9807cb9d +1358e7ac0d4055ac1b0c66ba00a0a247bf7ec4ba diff --git a/obj/Debug/Omnibus.csproj.FileListAbsolute.txt b/obj/Debug/Omnibus.csproj.FileListAbsolute.txt index 7c36aa0..c3b1bd8 100644 --- a/obj/Debug/Omnibus.csproj.FileListAbsolute.txt +++ b/obj/Debug/Omnibus.csproj.FileListAbsolute.txt @@ -64,3 +64,13 @@ C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Debug\Omnibus.csproj.CoreCom C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Debug\Omnibus.csproj.CopyComplete C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Debug\Omnibus.exe C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Debug\Omnibus.pdb +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\crypto.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\MediaFireSDK.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Extensions.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Formatting.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Primitives.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\crypto.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Extensions.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Formatting.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Debug\System.Net.Http.Primitives.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Debug\Omnibus.csproj.App.config diff --git a/obj/Debug/Omnibus.csproj.GenerateResource.cache b/obj/Debug/Omnibus.csproj.GenerateResource.cache index c83913ea1e1f17de0568e6b55365ac101d208bc6..d25c9d20b21cd70e0e28edd9fbd60f97dd30748e 100644 GIT binary patch delta 26 icmX@lb)IWOD-)x@<~F7*Mm7_+-V?lsHh*J|WCQ?u^$80A delta 26 icmX@lb)IWOD-$En<~F7*MmELz;3KyiHh*J|WCQ?!f(g3- diff --git a/obj/Debug/Omnibus.csprojAssemblyReference.cache b/obj/Debug/Omnibus.csprojAssemblyReference.cache index e9f59ad45869e1befacf7a9ab00c413296589c26..7a42654f9dcf752fc21dab622ce1dfe9e429ed85 100644 GIT binary patch literal 334323 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 literal 284002 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 delta 22682 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 diff --git a/obj/Debug/Omnibus.pdb b/obj/Debug/Omnibus.pdb index 867af0c05237fc4004351012e095e817aa2cd65f..303149e6298c28d5ab640b8cee19306899a72d05 100644 GIT binary patch delta 17374 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 diff --git a/obj/Release/Omnibus.csproj.App.config b/obj/Release/Omnibus.csproj.App.config new file mode 100644 index 0000000..c128e5a --- /dev/null +++ b/obj/Release/Omnibus.csproj.App.config @@ -0,0 +1,53 @@ + + + + +
    + + + + + + + + + + + + + + + False + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/obj/Release/Omnibus.csproj.CoreCompileInputs.cache b/obj/Release/Omnibus.csproj.CoreCompileInputs.cache index 415ecf6..deb797f 100644 --- a/obj/Release/Omnibus.csproj.CoreCompileInputs.cache +++ b/obj/Release/Omnibus.csproj.CoreCompileInputs.cache @@ -1 +1 @@ -3aa95803eca7cb013af7e351f492994d9807cb9d +1358e7ac0d4055ac1b0c66ba00a0a247bf7ec4ba diff --git a/obj/Release/Omnibus.csproj.FileListAbsolute.txt b/obj/Release/Omnibus.csproj.FileListAbsolute.txt index 30b568d..a40095d 100644 --- a/obj/Release/Omnibus.csproj.FileListAbsolute.txt +++ b/obj/Release/Omnibus.csproj.FileListAbsolute.txt @@ -64,3 +64,13 @@ C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\IKVM.OpenJDK.XML.Web C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\IKVM.OpenJDK.XML.XPath.dll C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\IKVM.Runtime.dll C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\IKVM.Runtime.JNI.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\crypto.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\MediaFireSDK.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Extensions.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Formatting.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Primitives.dll +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\crypto.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Extensions.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Formatting.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\bin\Release\System.Net.Http.Primitives.xml +C:\Users\Rory\source\repos\Omnibus\Comic Search\obj\Release\Omnibus.csproj.App.config diff --git a/obj/Release/Omnibus.csproj.GenerateResource.cache b/obj/Release/Omnibus.csproj.GenerateResource.cache index 12c12126e4f9d6d89acd43ca75d9159685a044cc..b80ab014a871711270892c14ce84be656245c164 100644 GIT binary patch delta 54 zcmX@lb)IWOD-)yE<~F7*MkN!r-V?lsZgem*3NSD*@BuNWD2U(%5}OL`I}bN(7Gkkw F1OSt=4I}^n delta 54 zcmX@lb)IWOD-)y2<~F7*Mx|XZvbv0BUhiOJ6kuRr-~(b#Q4qlkB+_~FLln|B3$fTT F0syWb46gtH diff --git a/obj/Release/Omnibus.exe b/obj/Release/Omnibus.exe index ac34235423d1bc963255845a062d96d06f25b77d..34012214813243cd0111e1d5f2498848379a5df2 100644 GIT binary patch delta 21209 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 Nj=&fHklJgs{{a+7yPE(2 diff --git a/obj/Release/Omnibus.pdb b/obj/Release/Omnibus.pdb index 6ba8cd433c0d5c145dcc8abc65e18ff42533548c..899454b5a25d1591290c47eab487eea183c28f7a 100644 GIT binary patch literal 58880 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 Q+MA=jC9t;yK1T`sKi|@wZ~y=R delta 15029 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 Bu=D@` diff --git a/packages.config b/packages.config index cee0916..fddf47b 100644 --- a/packages.config +++ b/packages.config @@ -2,6 +2,12 @@ + + + + + + \ No newline at end of file

    !)dy~YfW~*apE~ol!Xbt=p)v&Kj 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 ~;328wXMxoAnu_1s55hxcH>FV!Pc0 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̳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%0DTimDb$EFJ`pW`UCU( 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�G_3&3TLyE{btL@LfUBEO&i_c(IZ_K8%MfE>#|lN71!CH{*)zc{aVPo+y+ ztRKtosgwX)<@Zwl2W*w!OZgXg9{Xb?f1fU?mr|{r$Ul#*n!wL@llv$x;%)qX!J9ll zNhSV`>l>ClMA<@ob~}HbBYBu|0=Sr+XvM!@nLI*i7cR;xW~-<0|G!Bd9pJAq|Bo{v zJ=)hhd5kib_@{=#f8&(Bz}TOMCdVpAZ9FDViJ{DWO_e3Nl7F*z7L(GTx&1t z^RxT>{-f*2RK*(s^;3CiN>gB~ymVzWGL@I1B$6D<%LphhO9^>Sl!xbUrBb${0iSo2 z^Y0I>49-y+0bAo^j?&D=E|#OTv2n}le*RRD_?6d~G{C{)lk=30HhHO(uk^BUcu0XV z)W)-;3zff-8Gc`ID*q%V`uoSejMW@8RdEt0PZi%Uo~jtgEIWojPnSGZX+ZL!4>?#4 z=O;nS*NsjTdGC-e|$|;hI_}G`cQW+fyENURef=--ihg*{Ia(j_L9L%}bSL$fQrH(%#15A)AyQ zHl7{*v9br*c?tU8X60+*PoV#8R(?gM_}r}gMsoDmX5}xE7xfqYZ?h8oGU|i=+Z+%d zn*-uwv(gaKV}Co7{E2e22j&<4{VREk64kSkZzXS4mLZdUUnm=G93HY=d8rqqCwq1% zy@}DD9m;6pM@ESLw?mnRO!n{5ClQ-9l~L_~@F*#A~1?@?Cw!Sb-b?Nd(JcxUnfrFLJCQ-AwL(QJHw*f+}4 z$j+V5I#{igL&~$nXE?h!cR^s~Hda%ebTPfC}5sBi7J`Tr%R{H(+gH{#>V%PFUnE5Lgk|21;3!71mIru{|wJ&ud9{Qm$_ zE-K4`t^WPHa$$gwSMpZ_1^Zd~Qt|&rzbh5Md8|i${`^47WhE?H$n#iIQ$9bW{Gp5> zp7NeZ|EIEncp{(A(}Vv~DuCy(l^^j^Q?4it2SI&oS6%*oQOdP|{&_lXnL8kwUsOG&y@;v^2bqr5`jaaO2ME+aE6@CZs{S2^= zVSlaW6~xa2Y6|{5#p3cB;(J=*A=OD>O(5^FO`D4Zs7Bd4VU=;T~Dat ztp{B0!2C75ZHX~|u(yjXe|Si+w_la~HN7K=F@H^O4l(9;dZz*N_o3zre>orMhxI?; zy2AdNgDQDxp3wgR*Oq}29?+xTcoU2mj~ zPo#u;qiq}>B6(l8@wpVYx7fyirFgtMZ9F^L>uo#~>WA?ohN<3;$SjJlhi;~*-mq6e z&bsw=uuajbw?FY~z?wIQcr;&cY>L*s>yVv2VSG2dyNPqxi}kPJ{hqjMv4h=DF}x>< zalALY=a4C04DWT|d8`}n&q1k%chGR5&ph@xug{h0^R^x#*y_*qyd8n9^=3V9KO5g4 zR?i!Q%z~OY*rTcSz3DdI9^KG8$Hq^jhIv=oxK(Ns?+zPxNPWutgN^q^xAxw&aj(>8 zy`dw~f1g9)ZY8;x z&&pF@^Oo88Q0gde)6rPJkRMMS<84nop8K;Rb*y&)u;ssT-jOJ$`EQ&z&c=VFj`!x+ zI6NfQTV&&ZQYU&_jDh+no+f)=BL1N({~k>5$=?3R6kn6Qvtm#`jIYVwFNiU|;=GrL zF}~jLYGXxuKO2=Q&L`r%IlzTZjIVg_G-Ni2$JdeMc&}@mNRRRJUuwL!gjmE+?X)EC zW8;Oqm_1YAU`ATH_Zeh5U(E1!0=D8Q!<%H|`@=H4Ymgbv&zatjiEm^%*kfr^yxVNN zrf-(lH399#_{;XzxAFGqTyJX|cStSt_O$W7=;_|EHlCbX?9H}ucIrIuJ2rkIb+LD) zja#KI^?qjKUa22=zq9eI)YaaLHeQyx-pgXq-~T-6U{9od>;ee(?5B z6zS)%U3`7ABJG$r6?l*1)+FA4(~f&TCmzq^Z+qHF@7KVEtfG&D9gqISdy2R&kJsbT zzk06|x8URN@#s_D{3KC+A?v{V^H*u7y_bnuHvd2QSI>CydEDLAvAxcC?|^&`%YU4I z&nfM!*O`p^3H~9i!m9xnvxVIq?3c82-Y&@0A1-)HGDP}3b{p197rfhuTX21UOS|a3 zLVOP7m%N@#OdmRvu|Lv&_a+km^fsRl(k^>5iSKP->`vMr-qBMq{ZZh*yxWMM;p?e8 zX;;0TEFt%^$U;6Jr2p+*M;s1(!`mVo^FPJ+8+FtF^;SKvy6HXk7tj9Sy!NK|l#N~N zruU+aTUNj2oebq+{|^tjX*nY z=B8LrIMfrsbDUE?;p?Szhw8`?`p;pp{QThw&JWqRWqLKW9&jd%5sr=EOoGM=^<(y@kroW>M7tkY$@+Q zebQ^ISBP6~V(gXlP&FtI^&O--*r;@uTGii@+6Lr!KJ?uHN$mk_oe#Q^9vY@Pxq)1`Jz7l|KxB!q^RA2t^8i~RU1!8_o_L-Wsd3#MSfLX4(w+Y zyu7q@O-(AWmuIMXz^L!cai%&O<@7ydpSp|~zyJEM%9RoN)WGwudSt)#JX$?<3zp{` z&-=eWy`K6d@$ypsy~OnT>S^L9qQrRDK)non-XZ4endy(I{R@SD#q8k&j4euUq$W%S zrvBJi%>l;xR-`vp4+597u{_>BN`E3ipC{GWX(E4~^K@^wGM-bT-p2ed zb9QHRRA&L_v7wxO8J*RLnL=*)H)Uwe@XoW*qSf8sb!cR>}!@?S}O-2uO z&}_SYJ=H{DY|rO2dZ~FN$9U_l&LPI{4fj>8@8cl%d%&2!zq$g_Tm2(i-AMWI|L3CB zE5!JJs?loX9HEbueo%nF2C0KUp69%Dg`b~i3{poDV>}O5#}i{b4^b0=Eq}eDJ~LO8 zZ~5z0wG%Mf+cV=;^)=w~kVCxunuCU`amWRz=h8L8jJmN zvf7PU;_*`|C98vgt^eCgQI`{=|5F0|pZZ{Y!SNtfRp*QP&|lFR>1sP1 zz=h86{)~;x$W)_=gLwa`IVe*dPP`xXXPIguaT_?V%2Z2$^VrioK4W-11(4qP4BsE8X5^^#kXb{1o|Bs4SEESY7tRxM z)mKTb^7Ea#)pONY8~ZbI)y2S;|MJum#OS}g0RQDb&`m!l@jP+5dYu^06Q`@%V$`>+pEwVlu6826PCOo&P3QKk z44$rL5}%I}`+2UNS=J!$jyk{HdLCdkc zXIJo1I^!L6Iq*DIo1ga{NLk@^S8XYumtR$rvvwecSri_|AqiSn?2-N;z1MgW)7{Qs_+NsQy`5_KCe zj+YbC-%}5uoYp7rt4Dz?eLqkKtwwu~aev;;_(1LOVWs}zA*0Dp}HB^&!&zQ z|F5@JeQGVFXTQV$?X6YY65sz##P3@5dE$esMEtE)BZ=qo{K1)P)n&kb7S7k-FQ7;@qS*ukS|+@`hLVYDtN7Wh4`y4ME(ux*bPE%{r|)UwTu}5Phf-E|05x{zE@wW z#sU|!8gm${ow-TvxDo7u_6raBL@lwgC-YPFDl#k49qcc*MP;Rso_!?jVO!OP#3#6Z zzRa!aKg3^f4rZULY!m8-^W*1g#Adrb+tlz+1pC=1pNjIoQ2P_l6g;e7zg|tGe38k-?|bsoRCz z>W^pD6~x#dE7Y%mcUQl_*K=u^zp1B*4-|>_$1bRKc8L63enjYVQ5^|f$To6+W@TPd z#{=g97i9jf=8*geex5rs^G~&i_@@;9d_(46>L%cF`u~M1>JF0Q^F>$GAAzm-zoPyJ zjN{9a%&V$rr_iSmo)1`&c}?{p)A{GMfcCqlwg$P?et)YGm>$|EnEkCrQGW3}5C6iO zx|%rQOVMAiTkPDzpN|l{h2;1=+I4l0t-K|f*VTJAUYmJCZS$qj_k0MR@84280+*A% zx71i-jJI3r65v87{{QxEbuBUepYd&V3o-tm@ojYvG5%ltZS^~3uy0A`ZS}m3=k~c1 zpwC@3Xcxu@#{XTl1u^P#SM2~?=*0i8zo)*8Oy%EGQ*7LM^!aV6n*m!QA>RMHQ2WinLC;fx8(ZH7fgS1)1 zSbmVU1Q_G(^UNCBXOw^ZJ~5uu)V@S!d3?RKGPtI8q)Psp8gFd=E3b>~?bI${deYaa z{Y&}9eaN275RH`yd#v~l(XxRHog#k>tEEjP_Vf8Zyk;$JCh@mR#C%mtTa3(p;k+`q zmi8es)mKY93S18JN88NW+BsmWzB-y`Po+OgrMg;sWQP0mhqRu+R{n>y5w`S8GDEcu zHlEwZrBxt9f0@@?(k@rYFKJS_sBaGFb0E{LH3hcx@n}zdRjJSSnTj?J**R*h=zoUx z2Jx|LjGf6ev^3%fzW=$v*-v~pQ~1l!ihwQs4b8E)(%)?}O{=|Xi2L0?Gkp&j@9%wD z)$q>uh9^FD~ z{SB}a%WtLiAzlanKi^6lMm#izucCXm(k2i$AB&tyoIvs%;tnLAM%;0Rc%H9Sfc~wt z5|CT^x6;apQU6xjOqF_qeYN08#4qyow-7&6LhsGP3hq9{-V3BDE~yWBk52hDB7{86Cbk`DX+-6E|t)NQ& z0a{6w`~$TuKUUf|WJ}Nli5~rOaJ}?0Dk3J6h*<1WRa1EEo5-%Z6 zM0W0j`6f=w1h)Jar|tMz@PF5ACcL3@aIhJSCZp- z%uMY9u+_dZwV|gg{kJ4@mNw7E{0qX`N64(}JmHVo+Lypq{@L15TlyuLbF_|UD$9E~ zYp&KCnT4lu`?KEB1_4|7-_aHUqy0^@=4qvv9^&PhtP<@r%8&6;qLmS2e3WR3XTiS= z&$kw6n~CxKcA<6}82ud{vQWE%4Dr)GYms)iqEg=_nTxav8@t$I?H)3V;_Hh>>|ISe zhxOt3{cgbeVTtwx$gTEWqIE{5{mW9VH!{QLW0q<|i5K$oi5Dg;)xNRi@07JvJ7(j^ ztYuo4^Pn%?C%>=FwQ*F|2ig^2KkLlbH^FR$mj9bbf8K%Xn-$t=VAM~@FWQ*@-}XRXshFM@rLJ}qm5*4D=PS*6-=WTqAI|EH+2S&Oyt%&bqe&uv_i^*^lw*w0?R zF5ZvdqSd=3%J;J^wH<6})@NFOVzC}vll8e)@dwlo{@t9lUHi+%QCT~+yTFz|cWGPx ztkic&<}Pj8U%+slyDe+Cwg{QI`Tg~n>Sfw;lAq$=V~k;Y9x$H2?a{WAJm)jvzdhPF zl>bY`PjYzfu0f9?5wa=c@hVkAVL1M?nAhQ*&Og^w*Ni zD_VVI+Rt6pniJ#x?W)!unf7m2wMdeS{oW_7u4+R_j^o2sEruA!hpPemldD<^%Aq|K zc2%1O%rBXG$H8R`C&x59BSJ(UB#QKKji|75S>qCjp^LTzcs=A&JjO8!Mtgg?u z@r>*seKV!s%EyzEtQva6Ei4b;#|qY80rs;$_<8H1;F|he;^0@s_~+C&+R~RwPW_6F zBZEWq7PqlHF<#BhuA{$>Oz~V-k0-|UT3tPx7}sBQ^&(T{)>{Fi ze@nC7I*s2n|9JE$DqqCc=h+^;%RNy)|32Dd4z?>>(F=jGza7Z->YI_tKbpRcSnMa4 zMrnE(n3_DVzHk6q*W8WBQfrWo9N?_Ssz#*HPQ2lo4+LXKTUL2LzKs# zcjo8Go*XU*E+l)K=|#v4*N4sYWhBqw`}r_OGyN!WqfN-a665-^nSPl#pZ|Yn3~Q!e zM`p1+{nDsrx~nGG!}@j=<9#zdllXbQo)>(9xDj8E7&*=KNGGQMcpGE&a+>QU#JBkQ zNm$NPx-$gjcliC*mOd@?d}2JGYoRYE#`tWZkEo65qqD_)-cmmWJdZtgm;e7zPE~H7 z(^|g{@?!SGdtccjo|5{bDpijqjDnj#UL+cJxUyGVonF$S+_EM^PG-V zxP8tGx)0=-zI#qreHx_~`lRG^)34j|r{uh>7ln%Qtow+b`f^~5x4fL5`eu}~8$7;e zUP3JT%hH^_dJ8w^e}~7@s+@j$ zi7Xi7y;SP2uL8#UzZf_`-(r)8hYZwXJ&>L~&Y!2akQJ@x*!ZKIXuX1XKR?ge(r1u< zofzA1knT}1Kepc>Jrj5y8_&!8G-t5x^a}Yr_Bwxld1OkV|T=|4jM)W+cL-ZN zKe2j$1N{-j^Z%JMQ7vql?dRH3<`4jX(Hdg&syGIUlr#m z>-9avxc*wNe@Be#ul4$I;;t~Btk-`dZVKbcdi^@EpRMKb+pflXeR+M*kA?F3GyEI$ zL5~S8W*2z>$n$@s?*%TT`E8Saff)U}N#EN@q@TyWn88?)|6~2cOXt*A;k0fc)HKO zN1sUCil49Z^|PL7lON*pQ^YHvf0gT3h%tW3b=Q+vKH68VZv&pkw(#^n_`lM-G(r1> zy=VOU^u5H(dHpy1-{?b|qC6e=u>Lu))!)9;zXi7JJF1_uad^o0`gI$x>HCAeu^H$? z{q4sGjQ#CLeLu>nzx}A6u(6TzqyC$XkK`QFuiN-|&T;)hbF^3Z?~wnb-s34`_t*Ts zEcX}v6fyR6c}`ET zu_yPuKE=jn?r-`gU_U$0=V$)?4E;E8AB**i{+xlxHZ_LkY!W_4CKgq@UVPx)YeJ-&$KNP$Q z*w4Z`J6JEyn@Nt(*WA&&v_X3?KJMtFi7`Iz=q12@7Q+28DEF>@6y-3Uj>x^IH*bsi zH}L(+_}u^W2ph-eI*fJ1*nUAqIk44!HH_QD*nYuAopz!;Kda8~cNYZ*8;=7QGLgSj zs%f;gab&R5$RV!a_D;#IZIlq-1g>LjBrfOAJLTurHBJzV=c%UWK4duCqyDXVdlqvJ zv+<%_mr-KlRk?0sgN;AV^%y&WE&nLSUE-$24z?}VYlKChJ^lFi3BJnJjGn|8Z-!As zjPd3(4gy>2qlb;3fN}i!KKEhcnvGB9K4R2*4)llpNJZ|Wh6fq;BNe&zjE6~%^MCyZ zjN?&#qb134KT_X#j`DxFkg?x$>l=NE!`~JBm=Qz#<1z=kn%l^jLi{d|-hi0g2^pWD>fM*Q_ieqNB*+&DrU1>C~8L|p4NA%EI%binrM&(|k)@>&~S;*UkY>dFxC?P4g04a#zEq~+`l6I zb>eBnzD`*FChp(pgdRp0;ugfQ#21L?5=U}>$FLs8HsY_jzZ-F`ApV21(5FskEI)*& ze}(JsN2d9&k}=+T81H~QkA1dU+;{Xa-bDs~KAhFVSV!dv|Gk#i)3`u9>~qE@E#`gcXSc;EKDylCSqVwIo2t8)5{#gy~0r%-D{+p+=W(f{R(V zhZ$4jhZ~u|^VsYQ;(eeI#-#2-j^o9M+>ypAWQODOC}XpY<8xm(8omtaVSHT_Jl5y{ zY>m(3jCf)kpT`^d#5g{WHjY{jx{2BVEH)yPBz98*P%}PEdXw`s1618dX_-gM>GY$820L zZ@SSAxR{0U@$O9COye}loy`^r`)3>1ky&dVkB!)DqiG)~k2U1aR|!rfew5qC?~{zZ zz^Lz~Jf0ur&|h{>nPdECjL*rc=-^^WWY(%E^UT--2i~5RL0r%(M!Rw6kZ%|I__wB|H#1DNV%HMAMg3Q+P z`{$Lx+l}*>pWdI@Zd@lht}nM6bp~R52!6iCcB38flblxu?=WJ4&odmqcNm$(cz?LV z;LhZ~@*2+TZ{SkNb`3ZO`|LAGxNVRB9YnhDg1lk`MZo% z;?GVC-fgTyhV|5A`DMlql8gJH$MW|Wdr6M#sqzPm^IN%b2IS`*ac%kgxUAf$`o3Pd zQT2Vja--_|dS4l}1_^!9p74-;hK}rP@g844OxXXx{e{ZY}}`@;vEZ=-kwle;+UZyzwr`%N^N#J-IUYys-kfjG?~gjm^Yp&w1k)Oi%v$ z?LoX?`M()AKyJkcmk$^El{4}D@Zg#kj3{7~^ZmUs$i^KW`XwV4cpek>FUY@a zRM>b~{vXE35u$v29)&-_ZX^MhQ~$YQqMSs0&Y(S><=r!Y0N{{{Zno$O9`Rkg|dZf^&jG@1-8OwqF%+2?68}t7*z5*^_ z*#E8@KLA_tcjJLSMSO3`zhRsOIoiLSv-X-OA9+vyKgL~P%l?~&YZUmK?7w9^3~bqd z%V>o15VZG}(T?P3?`@+KGTD2_=tk+$-aE!1WXE8>{vI23$CyFsg+CAF-!V#nEq~lG zoTKgjxMQROTmHCfEGB;UjQIcdd&V)~0(N$RxL^9u_~3Ps-}2Xg#wK9PU(Dn}{wuG6 z{$l11kX!M`%x`SmcYwpZYvWR>y6GAt%FkmlUorN5evlbQ{16}SPUP1xoiQk1!P}!E zzouCNT<*a7LQLN{A@{TOC&lyoA!Y<{9-9H2%+Ip97`TwN;rfR;WE20ts*vS>hP;a8 zUGl~JC!0Glzr+2MgFRFroAoD%`Yit{mVfJF`46}TrdLed?^yj=HD87N$le0gi~+{| z?IQ)cIR*GU`Oh@pBF6F5G~Wld<}cG+3ykFr9^fjKidrV^G(d!W?ho=L%Ywc{YBbpru&^jP2jO;AwLaur(jG zGFKC0`?oTy&L6Ez7AN$v=8x896!1KDnfI?g1<#lb;lPE?>+t;9U^52T8t(?1laXos8f>m6M*UtfF9Tcl zykZ6=VLajcXhY4##QVMw>$Blzz2r)L`VJUw4n%hLJS5~J%@M%X`)wo5Q^Z)_NHZ=4 z@-s0%t_&V+-UhbfX|!20wX*yf1*6S|z}Oy_UW+lGvhltAab|>#YZOc{H`~}-Fv)C@ zCd%`({(L-J7Z+zH0vEEI;IB8#Ok#Y$H- z*lMqMQ%e{1S@ThXIf5AHqeQa=*v}7_`1`R1iDttLk$w&n|5x_hfMjzT@en@#g^x@z zPXgooxV#|Mtdl9yBd;w;Gdlxg`+ZW7VU7ewfBiCXikV_#{{2<6(8hhDa?FLuOw_kB z*l)g%?A*ZhiD712cE=9m|NE&t3hnP1e8`d%)WW45sI-vx8c zF~H~#{zitGW8=Af=9_bETq>2AA0X5FOAE}6z?QxX%$>lNz6;Gu#HjBg^Csqp{o;^< zMdr2KO8?v|SZvnLtK_J^sQYW>`_BebWk$n!|uC`+hJd+StW@G*fImyYQI#5wKZ0JSNN}a9@rXhZkpGD{jB6I#(pZiWp*hR^&_7uykl+#w)DSe_MI){R(swz zM-XFs-Y0#m_WaMB3-V&to1gc$=>MNNe~!p+wFmR92DbVO^Of4TPn5&A71*l3nr|O4 zzMp%su)6PiV6^9YVNG8Ju(cm^`YsdW`q}AgH&@h;^@WExeO-Y4Fdpy|e%~VCJpQpk z@%&3I-)A6uNzrf%Dn!3bEf-d^y174m>YZe1~n^ zC(7%)VBB76l@KHfh>_+|iG<3)sTAuz^si>VR5y*6$;^*P^tU@N|#_tjZkX`hRA z^gRJ=#d9ZLOJK`ioqU}zJ;irtUlgzv&z*hgD2MU=Uj7Tdd>hv&c+of0#{7vf-!fpU z{BAz;U7-)^-)U-hUk@8cPJP*z3vB7%)3*%R(zloI9?D6-UcS&JqCBhoUcP$3mcG4x z-GQz4kMfNI#_}({7Ui2{;~52geG8E3d|`m^J!0{Fh!{4&_u>E1b>Hz-6yM|U_e#6L zLJJyj%j_-+0xC*ZKnz8yHw2K-q)ViWlt>RHx#)t{w)<_@Ah1j>u0gzaDBZ7~3Bl z*+ZS-aL>pPbt4$_tElu+E9Ux^-vLi=wE-B%+v-Yv)OJ`-$E$tS-sFe;`G9rx`>JEW z;fgq39TeGDO~!IMKJKUP%7gmd@9^ngQ~Ifg$zC{q?x&VnD9XdBzx%0`!Lq&m)EZ#f z-u~*xWITQtp!NpK{n-F@5E$D(EOLOF?C=+n1J&JNx%>yK=Nzu63{n3B%kl7;>RyEX zi~G;d)OW!$zoBX;Fvgo48LDn@cxL41Y5`cr8?OH5a7AT=dJ`<;jZ`0CIrYa#we(^U zU&b4$`h#VEj8a>Wu|G!tZ+*x61wP~U!Drkaj8;3s{J6Y>yN^~!qm^79wW{)kIvpIY z3@H-l-(%IS;6eqjKaExOB_cn0eQLbg3>>bUgX>%4)vjRK{_$!bhnxCMP=|nbJcsvR zC#qw~c>gs_oeq}c@hdeE9Ik9zEB4=$)JNb#y8k^%eSRtCgZHy1tJTo-J+jGaEwJp* z$?6oatbd9c3zqdyRZD1oyni)SE%&vv{%LAeG}S*%tpS$xPgBFdvVW(m@mOA}H(cKf zS5v|K|4g&R|69V<^&uFaP~G2%>GAqXpeIJ%4o*_uTgdMhM#iegz!B~yL&f=docae@d|yZSGFf~- zNcblC!vW|A+s zi7e0Wlhjh*`r5xgGD-D!_(bG9^)oQmcQ!IvO$W>Nr>Z4b?jFaFC%r*ws**42i*WaT zhkx&QVw&m(%Xn#OO)Q7~)78i{wWY&>o(wgb<`?g06$j5(=aOIJ^%Y0XSLcIeee=~# zj`<(*^5YH%da~4BD=?p$6Z?-y+e1hM9D~`-ohmqeaj~)k>^=GR=j5mjtcUdJ{ zJrCtcN-Dpe_9Cy({hg>^?!WR>Wfk`4O8$Ic(WiN8J@UU^MX5PP{?o_lN6!%hV&}EhEMC zBx%{cW$HyoeQk#sPEKH4tE>1TJ7WT;8E+;i)c5-+pOLoi}mTX!JE~4WAfzw=ql?W9_6=LRlzd9&1w#oyG8%J>)lM-|AI2lk4EG2m&b#f)g3rJ^v9MV zo7LYOZsOgdUZ?uj&*Rsx25(b~!7|=9wd@98`vbk()T$1*_x_;1?QmD`cJ*U4T#u+T zc&8cymi6saBOTKxciE{fb2xEaq59EA5f8VYfu7y!m*5EZ)f#-f2k%iQlW~0PQD=c= z{d=An|9jNsP@bxY|0RCv-J`B|c!+neT0p+Z&xhMi*hllr{@btC*d+3i>&t#M=m%lk zo{jMCS98E}`*J}21B~PUOYcGT9@_m`tk^yrQXiAU9`oy`A&1m5KZ^Qf{)f~WWISF! zq_zah_=nW~V2nT2dq^GQaHRK$dKHZE9|j*)|8baK?^0jfF5+Q%y!W_T7cBexcXc7S z(9iBB@;#|8$LV3brF&1RYq6ZJx1Ll3e)9E4HZT9i;U(Tv>UuE7Tj@Qc9(8!V_YbuM z?JoN+f1kyBR#kp>_QzS(4aW9v8-Ulq}zpQQmWBnJsSJZuI_nCarUsu&5Xyq=y9~2sN zRXtDTbwl{mL*A?ERj`bARrM?I#kfZ@;(~lKXZM z`QKHSliwcXQZl&Lf@OQ|s-1p;{9yaG;gh>+e}{X`DOT4y+$8Fr>Mnxm;r){jqVB7& zk{|N#gKq2lK&=JF{%IHWKurY8{wPsz;PephOYcAG^SgZUJyHLvHd<-$nM?U3>XF(I zEc1P&wkG5H{Yd=|jPd&N>9;yOH0nRK#%@tRUT+QbJW=<8aeUkeRy1{wFaD?~mp0Ae z$x)@Xcktzx>M5@^0L%82 z*M1~pd&+Ak!PuTOKL2%x^P*nRLiUOJWq-b?odjchswyvOw;gsV6|{=KLOx1nV{txG zQLBk|59Rx-R8K{%C0OQDQOhJ_J{7f6`^Eg2&$6hBS|x|qL{-)rfMq^av{Z0}dkgfWl_*Uc zjOO1ib(MV7WgvwF-xQ{rO*%sWFG$(Y7`kjP0oqT|@JNWqV)OPGh#M7^ z21n5I0d=)5V4S{gbX~2#!;PZf(pG_G{%>n_kNNUx9$imsk9POv$M+qg>uX)eJ;e5` zcYUoVIUcqT^|irZnNNM~78#dkeJ%aCs6SjeKa+pon%8#=jQRD9ZmcOML^*m;bW<%D zjQ#z1_Ip~W!z;bbw6SRS@fG6wS#xa?IW(K!PxCg{W;&)H7TsLi1eW==&<>C>zZP1z z-<|oj(DK2U&lk~w+E#}rN4M7ePWt*QaBv%~30U@LJ8e0Z!})Zor@gj;jNjjFuN9E- z`?c-0gJ79od+i@E#-AD8UUQ%F^-pYcM{NXH#_ObA2V;NDi|(v7Iql1DdGN>DUbOOr z-;Y`l?a@w?+qW0r&k53QqUm}@koE{H^9j;QpYhe#(-WjscX(lR7pub;I=n(BaaD*G5|Lmm&l5u(V(mH|V`rb>s4h~mp@#hadDAP;x zKQHPFS7!XdpWmL?TMHtuHHAOb(#fg3d`t8I?Kt_wB$x72^gylRpE!R(ZBaf%Yj;6d zw*ND2Fc|aS9sQZM-rb&$UwypNt-+m4M~)8m@hKQPdxy+~nuWe@2hc zx`JiA5n6vTj?WR=Ua*{hg!bqX%n#f5tI;F1H!l0UD0qz40F3!Qi2gzgbl4U1r8Wqs zcmKXdoPUhdhLeXDi}TNMS_FAAITtMR8>iK{BI05F?wE0!7mV#67Cl}&1(x|v&|?1b zhrvtU`@bgkJ9U;i|XnXbh<+%jf{mI;>qGgEu@Z(sj(h?%9mgNE~=q^LPs zQ}Q2Y#r3c`+K1%QQR4Vwj@Ah*bNJJkNbM2M594P@j8`jtOT?G? z#A}zq5$;O-|3tN13EE9^?WyPo(wD^XSc3M1yp77s-NydA!;jB8L?>t!$fIEYk)XW- zmiZ=VjEv(wL2Gaa@}d1j0v(TFeifB@S~`@={dcm~^RAd4+xulqvK9}<<>^vVw1r@t ze^%dAZ6jE2Ptr72?3;g5OqwTNKTaM$MB(|4mX zwL#>nmdj_6_QC^SzIic=wccP^ z{}OGAqkLJ+675%qSH>*WPJuDrrkG`#e+je)@(J|hYb(M0d02ivTM)BC+dw`RB+hSF zXg`wY-4Vw-E3{w85&VBE-k=rQ0kF(xh1TF7XZn|4-5?i-ivC`sm4IcuHCpqBzWxmKtkF6-yy27YwGyzLe(f{kYpv$@ zub5wsuXWlRV9Yn(yH5MS;fl%ztv^^UpN-m9Fy?w^^$T#`5zqo3&)H zoPUev{}}Rj5C2YFpV+FY_M!wIFzg!^&+Fi8L8ty+A zXfHg0`juSnvQrAQFtE(OKs!#x^}j$Hskr~QK0k~p(55(CI<`>T3&!?s9Q=#c%q6Cm z`R&s3z!CJl?%moqWc*(EZf!MK#^0@-0%QL?AG=$t_nfo7Jz6dp<8Aw7ueKH}=ijG2 zS4vDD;TG2~Hg?&kRRCjsm1Fm5%waWlzm|s6L;tU?bU<6{aL29(wIYXa1plU;Leu&A zA?*TK#y_Op2B#{Q`TAkU9?~9>3&DrAPNhYDNpL<=H};4Y4aWQ$#2(es9c~eOT-yZ3 z_O^*Vp&fR(Li9=P7FhQ8X)UM>wja-b&S)WM_@2_}pflPqDxWo0?61yfW5F{2Gg>kj z^YO%<(Jp|o{$bI7XwAz){m@^Z#GchUfeZcWRORp2gq+v9k#&B)BHRZ}*C)?wv%y$@ z|Jd`|A+XHGXG0j2pH?18hc6m8Z7I- ztgU}){wvyEoZmH($D1AdmsZs+;>r5{(ljvE7sJczIGhrDP3r`f*K4n9OZ~9_@%q9I zZ8Ld$fVkdvL;IPG*WYevyUBQc?uPao8Lvm&(0(UZSud_f+|bUGd~^IHVh^KNM6$#^~QhE^FY+kZn-v7GitH?&Bae&Ysl z{PVY#K>iK#`CCgPV|{;Xd%?24zqP|)?9a^DzqJbvFO9vWHF#d+C;RiZmiU6RKksOZ z$=IKFw0tu5-yLl&8T;>!wv~+6bM9ybWW1hpN85|0>q&Ps^F@fK;Ps?CS~Ij8+jB>2 z4VLY>qjdsfdsf8W(R$+a&|i(_6l=*2AMo7M9yzAp5PM%6_!7nw|8savd7vee@%iKj z+9R-x_dqLMK};`?mmX*@fN}fqL+k_1a=0k=AFZXsfu4W0vot^64}PRItqAcU-?GXh ztt(pjo?lu}`##4j+qE^f}}VK0Xe_ zy7YL5kHtQxXOb83@!Qi=N?$@A%g67H;L`dka=VTEedypadf!UUe9P!F(MlG-{(UC4 zj2=V2y_tUxIH;_?#^H;xZhaRS+vlhMM#lD)*H4l~`xbhh*DsJo`>w~npx+>i_FRvB zQNK@~$=9b@eP7a_kl!E7^BGVaMDoFD~Dg_44G({QBpy*jMxb@<-qRy{@DDKx{R=p`-jjY<0Z_Id{EF3G}?G_jkB- zoT`s;xI&zvPjR?#&d1G zkc{oEqwgnUd+X}Q$zpjQi+xkS z$Gds}c>|1>`npNR@!mkMOUCv!)CZGs{5R5r7#}`#eo|Ixq#v#(;>qLVM*2lCj<1Gs zjr6+?e-PJ1_pk2jpSE#L^-!=JU(NL0Snh5J>sxdEH!|+en(Kd%asSm^zfQ*OZFBt} zGVZUM>t$bscy8QZHP@?_3lQ&&2s##`Euc$9eQ3@?t)Jd|Z%zgglyjh8#n_0uEQi^eKG$P)pR8q#Rr7QnKQ@ z=&@+}zDuw^tOmxz|E~q>v&mC=e)WQb^&*Gg5ALq(ufgZL3#P}&4KUoiJtFTwS^DCp zSid+weLX%>-|(KWJRXYDcY$Xst@!gqZ^lRIr^pqv`1hTa7@bcnrZ0ori&)y8%H&|65Us*B?0CFg`&y-pBYi`15uAeMr3t8J`DCdZxZ4eM~cGAC3PcePeTB9B=Q( zC+T_%s1L?ZVEkOY9$0P<=INUq-0nM|Zap#{9$i{C&VO|6F}L7?-CvK2N{saC-a_-LEyaXW=MCSrWfYuS6E#mn|2v zOs_^Ba7646mgy$>G;iOxeEPazneVb^mj5z67RqJ5%k&r8`0`!N=bsJ6{P-1Y{cndW zD$8}VE#`OoE3tq2R)2?lo}2&gR&PblvRwKy_dxENbB?vu#C6vnenksUk2r}zt`y{V9e)8 z{5ri;dtdxO&wBl)!>8gm=w&+i${z-A()}Gi8NFGz(eACUi|e0T^g3u|LuYaSXp7ze zEc4r5jho`4?aHh7Lar-ln%kyJKdG<^6-+jr<(k@AyFvdi72sJ}!?Z@jvNrfaUh?XT3T2k_(?t-=TK^%ldab z)89Mv{!pHztP5*sJ$*B?RkJ4)X7_mOZF%Leuv2u)Y(F`8V}DtRDs!x~onV{dYt^M-Jup z8-@QSNAdGR;eW~R@#hhnmOG-mdy064?qx3iy#ns4>~C?r*(%|p{uMaFZSnV)OHaI{hm#Zd{#ZDQynHA+87!CgB|V^zuf7fm zm-JAujCWbz2F83UL|@Slq20LsysDo>D_c{<_xi5te}ZNGS9Nz^U;SMYuIeFRS^qV? z-KU})>kmn|u7{)H{$%NixAiD;NwP~Bo^V@FBFFRXS8?!dJ%e1x?+=OT^T_G^dgT{< z`ftd1edo5m7A*6-t&i#F%Woo|ej8ZkcSpYi#{8xw+|}LvAzydsbpAcL9{2Q$_5f0 z1(xmO<%2~2@_Bc~s5lr*>u)Ke+YsSY1)p~>Wy~i3>lM$tmo`?Aw{nl@QpPACfcI zsbEwaF6PJbcyC3c4H)w&NT_T~#Bz7{?qdH?#h6aU=d-IAUa*W`#W(<#@v9j62&iAl z-QeQio2X*E=kT5cei}?^=I$fRTZw^RWP9jl+i$0*t*5|DI6Ixa4rh zuGI}?q_2JadXb?yoZLkn?;T@0liS7TBggVAy zu-u;1HEK+N{($9k(fg+H9-5w)e%lBnX1g5A?iaw3+D3r)uK6MsKvceK#?F8yJJgOMl|up9pGT3f>dKu;6ny)cNcJP^;LBsMhy(Qdr{)YRxe z#_LZ_jbN~h-_)1_#`sP7{CjbFh}SalJ%fEE>X-fB+}Hw^&u_Odc98LUSPNqh8Lx-6 zFbG)|)3WBK!X#leBbpXB%W z_hHh#fyQ;PtUu6bJlVH=I*bl9LLCnDv@!Oe>G`_0#&I$}PuJGCNIp4`XX$BcJOa!5 z+Zvsw`10?T*w)Ad%ltnw9)mIe-ihsux28fqlz&I#L$Z2XoUe5>x{*bDiX%H3Q^7J` zM+fh>$LV2tRfz6nxTpE@2~GUi=mF;6?|}L}MnAODaf~>g@fah(vVM;dgXK_P zyw_u-faU$HF2*V_F0avv!NwDu-d&Gh{}>(A)p%jLh%f8wYSabe^b-=h8dJbB|8B-! zF!oP-Pj}<8!&4J`7?06z@%-M*pq@sV8Q6c3{Qgeqi9L-M!7^S?qb^wH+w+eXr*4Pc)opr@d1^K|5c}Y1{m$Y zGM@oPJ{aR=^ZAvTqCOdKpb-SdcxOfqGRB~({vpOxv>WRmVnl;w{X>j=FxI~$afqSJ zf_!251$sU+=Azy2@#i)36Neh}$^Y={D{HtHf@OU}jRG*%w~?0z%y!lnYQ#ExX5{Ba zzQgUx4mW;AQ~slj{bSdu(Rz+E-Y8?4!#^gDHhw_6bCVTi zSK=2&AvvBO&+X?v0G9QAVdxRQ`p%5}!e|MW{r{zr2*&mvNgQYVfz!KFhKS`k-nfpY z|ACJ;{sGJS$3L?_8*i{k5l`;V#v8xH31j`I62}`?z_`5sOq^icb@)bNm{BoaOfU1B zZ0rR`(DUF^jKgH{|I*PxQ;bt&+`djRE`VizQ;d%ieDNP9PBEr{G5+dGQ;kH2uMV7M ztOCpUGmKJ+V*UvC?1y4`g&Wn;)F0tSU9gN7Zp;8M*Z zIpf6}m6Nf3-T3)VswcsyPR8eZ5)6x+57&zljN0V?%8UL;Fy1BKtb%@zy#GaXAh}Uh zbO&<1IE>c~Eb~t=u7I)sswO2E@1^+iEvqCNqa0R~5{+bs13k$`k5p_Ap1-CT{m9sV zDaKIpP`>_^o|s~cCZFKn2NDhg%Y0IdpfpjR?9UV<6O8>?H8I859#fu8xs z+v%9kpIyZMdV$fH{ML4HJhZ_0fc&JJI6hclv;)id3ye%K_D9pC1;#a;9>z<{q)dZl zi2CJtU1&T4%j1(pM(Oz&|2=-a`=)o1@dCLIzaFb0hG2i%@+=B1VCM4w> zpOBkCf8-mVlJWV-eB(3nhy~*KAm128j)47pzA=H^jpm;LmiguzEX$YQ#=-eUONRqJ z-x-N$Iv!eSWRdZBXr-|nEbCkO%=T}kaTv&2jh5( zOIl;7IbwRbJl7i$;0Wa^KVHd7+92&dN=~Kn?_qne!64J|?*?Njm5cv>d4v9EHy#gf zFxFG~DE@r%yHWqMdmw-QShxtvWqUUmujl&Ovxw)@z~L21n~VrBwr6e9W+NXg+w+6L z@}U1|`}U(zi<}DA=YKTnk=q{Q>r3R1MiVk#|M<~p36}Z%XncX?w0-^2h;g`J;EzV0 z!;fcgH#RyvEc$2Tg@wNM6eR61J_XD7Ckl+u$l`iXy0^d>1(xv(jM-RD+wTIS*&=M; zSpGcsxA8lT*5s!A{!ZzMJB?1{o^ZWpr_l{8>)ZLvc-m=PfpR&Xb{gL-_T{@LX{WK# z;Uh`E80D8he8}fiQjzf%SoZ&J<8v%``}6yUmy-4vUy%2$;?KiyPXWt(_83KA9KUyX z`EiFICG9h6FZIPMHTPHJW3Y^Oz=+3kcP#I}7v~-{Qpu;g^ZSL|xnLRZpz-wkX9ta^ z-#`1!aDVM-Xi~xu2xkrp)U>tw7=N>iU!7`uY#x5*(f0OP~UKx18I7pt&pZCcK zI$@jw%Y054wU+tfHJE$CNC#v69lQSilzVzk8oxQFe}C>N;}3A5Ya$=dOUs@yly5|R zg?@NEf5uSJ^8XY@TQK%_o4IFv&h+_U)ohT`B0 zMm_Rb{y(YW$O}djux#H2qX(F_-*Yb*p$_+-d&$_0^TT)=I`^`1+2KiZuN#lRGX5=N z=eHOix9_)&edM&Rit@w2+r|;{@Nn_`^=;!cxd-3>yc>1fxJZtN_mgiMx4<&r+eTu( zs9&xRw~Z_?<{v%xwvq2}^4z<|e_-sd>#@a#dj;eN?O8DQo>3Pp^M7EBz;gH3uzr>p z*hW*YJca8*VFT_(ZJ!Ya~~NYU>W~EBM!^q zeU+I(PmC1ux`yI-_lc1Umhqn$7r_|6aPAYM*x>_nU99a&U;JZppJQDdJ~y{Civ`R0 z<=6!*r~QYUT_@xF?`~F1#{GkvJp#*o+^owgU%bEPy4ehe13fRYW~)Ux=IfgG66@sf z^YbdQY;c5o9KV0~%D_r&DcOI9OQ}4s68nxUo(Dbdt;E)o#q*%TKafLV{8VB^V3}Vf z)?tk=egLm8#9?b*6}B9VNc{_HSV_RlLU>w9P)UB3@tOUS4B{dreN09!#;bH#WL zVC%@EVEYolwu5Cp0c`AAQJ);o0W64d{_px%0Q3HTmSaBrf9~u7mc#dG8qEt}{_C9e zRcCv_^7>_U_K^IqS6rWel|8p!OrNT3?&BcpRqew?#An7j6Eb*%Mkld#-7{ktFO&G#@+#AeP>3R ztQ%M^ADb=4aymb&!PcYQ;(U9kQiBzNW&9fKG8o5Wr+GEl%UeV|tbcW-*H~?^tp9b^ z8Oy2unrtvw)>reH17S z*Hh)SpDC}+COuVN=b3!!uw*Eg`TXDVhChh-|NrIvpDo|+TRy$!)nPec>aX~^>^m^# zUr~9J{R}Sj>-e8|p5!gI8%_Jax7cwoE{_58-ePrs67|def17!K7RLHQ=hb7&!G(Uk zH;VTc>a#WETHF)n)n{9AdPU>sFH^W1>=5(Icyu5UQGhPEW35@Zg=QU)B zU^#zdb`DMP8?)#Q`;ET`?{l+svcc~My&Kh>6_D}yp62Wp7~?JD z^SA!R7cbD$f~^K)`&Z8UfSmys`ibXDUQ+_uH8MV5639x(_F~CBtym&hF7Gz%$}X7S?@PEJ)|TBOS6?KaH)_jD$c6lP`!%I4Q+A8#G2dV2 zwPg$}dwum^nD;Sj4leYo!u$6% zr3-6AuFQ`Yy2f{5oyq69T_IgqcXHQX#QU{fSbsE)|1PZJK2bmBb8}u7HW)1XBbdFp z-xvS>ysj)1EZY~tv;(5N&~Nwi;`}&-y++3MA%xXKyDs$S&+EsBuqotq@H}V;J51C6 z79iRa!cKu@e}%Au-+cM`C5NyohlJ(&-ji8i>@WU(Ox6fo==aA#vA*|aEzs27-mDWC z+gmZYH_HXf_V!`QVPAVIME7OQ&~*OTkF_T6=I4(~%l2cRfMtL5V^hFb|0~J;*m;Nb z&+n^guQMjQNib8pOspTq}7nn~jF`?VaS$SSDI|%+F_*mi>&CfMxv8SnH#{ z{%Xvp4+YEi4P^nxeC_)rG?X;~7y9Az+MlxySgy1Sb19#Oe$IM;la#Xj_@YJf=WH-e zPyIQJdBND;_Q}IoK3K*Z&K`lWeL=}1*ek~&zWWhh-b0m9>lYt@$5L3 z!|_(CX9BxOewjbNRW4)#yMb1Q9aWUD%5vQpA(_Phg*dvHdrd32X*f z<`>2efU*DPB!9(j8#8j(BJO8W%={m$QH2RsU1eFPCpTs|&{d+?O2BW`J>d1$q)# zwF}OC64_f0|CBtJbwIn{;^VnoNDBK3P5Gp-@2MQ~Nnu;TGM^My`l7Et4kxFu5U`A& z%62+@GC7T%LM!6>-}&TpR_hYvr;P33QvTwe0+#isvjQ--?-nl)xa?~W|9&T%#LD`I|G{{l7}jP;jES-_5iiNCZE0tEaT;|X4ic2J_%jO`a8TlcoAERRt5%(?ek*x z7%bbf_?hj&V)o*7QJ)+yi&-Zy#(yhiG0O$Z<+X&>zTu0{zxT-+IJ`UNYt|d>ei9_E z_k6!U-Oj*Hx21mH< z*TnOA-?81~K|J2*pzqjWu#EQ|Q*Zj_Zs0J)-w*5&7~2<<@*`vSeEBR7-pR@EGwa_TR_h-TPp*G_elX^9fzPi#bmp^{C4(`aYbpEKMzs5DxSqM6Z6}NC znd|EBXZyf1{(g2HjP)0%>}M_ib=H4?-2!9%|E3&d{*OdCdU^0~EEKH_;nzn?r5Q49=-=b)ELg@n z&g%Uq>c@Ds`1G^Ea(y_#UV7ro|Cf~CS%AZDr=DcZ(C*t%|7q5mjQg|GtP@zqJIxk= zF<#Tu)9hEA9*!qgS31LPIoz@9AM8cN?|=Q*GW9I0ji&wkIo1KK%-Jr^7tXQaU>WZm z^MWznN2%x7DX?tcdDhM4tG`0@pDf1Vk5ezQZD@*jne9YVyvyu2u#9(^6@xKeNa|(Q z?m1DvjCX}?0ps$E_x{E1pxv*+_ffC0hvb)Mi|y|<_FO43zpVcns{zLP`=wrEVPIMR zb#@Ib>%YOQ($GHlP^kYVt4)3r>c7d}1Ud3GtEaN|68^IWV zJuiRZd1rjZTmi=Z-j?bzH#+=FYALhy3%>l0q?R=&qTNw7#s1dMoKAk7A0MAf^)tO_ z#qV?ey$J48V407f+2BP{ALjEnFHZ(z{IW`UbCJXMQp=m$(e6xs{ryqu^JWoP*7v-5 z0gUxMm-f8b;3Z%CdX{^^Oa^29{CdB+$l;w`UNYB!3;i2!j=uuT%H$-W{nWGWZW z>(@@JX8uCP>;2Wu6XdOY{t;bXHLsDy_563zRP&L;@2BZzr)toCJikjb%zURkubHi@ zLpeQ9@w(ZC{8}gR%QNLV1ZwrTY47Xj*OaXS94?+dNF=qQAzZ)iKLyI6d}HU9%cl^v}e! zH_ciOho`-5jtAp-@ut-?^T9IT24-y?`==&1c8I-Hx<*t~)B!}9t%t%+IU@anYp%mxPJL+9(w%?PyH9U-_5?8KcszN4h3WXgaoxTCpaAM4K!oHg?{4t zc5!fPGnp*j?@#x(HZ#$*y=ZN20n2!;%`0H+kDY04%*LiK{@%24_m`J90d~|5`si z#0(m$8P z4;jB-(aY>XZo{v~w@vS5_9Nr-`Mu1c7 zDf&BH*>p}(=5piy2$y$RCDc5D<+T2XnpeO$KC;t4HyhXTjgKYi!^}?LLf7f9#dsTT z#-XWyhCj2v8*b)8x!nE^H(R~oTmCEf{DZ-Ae2g%Qz?k3K^pWNnhqt7UddfS~$C%}7 zi~0)v#Ph-X)5n^X$;KFQd7;*WdFTleVJ-bB)>Y3Z@(j_n$yV- z`1Vvx??qF7Q_bhz6!CGql*^cEGBk~k8D=^d^R1i_Ze9V)?b}Q<=q)inmRHM|Y372l zy~CnsnXkU>Yah#){ggX)ontn2lvh+_1ytK`TGrK!{Y;J-%99-!4u!~qeN#>X2eXu-|%*kkqpJZl&W&b6af$#d_ z1!c@NyMZxYuZ(1K7+CgKiaC~y{gq-)LR0-IW+GU&FU71?-&g;Dj8t=?!=V{z<{U7_ z8=H|~E(90)9m?bPUotYy<>cl3`b@cyOmhtxpFhnsx1uS2rdhXvh$rJ`nybLrzjHFO z%qL)s7n_l7R&6MzN2g}wnsva1em@vuf44P8~fsK%~)nm1{eDIKNim$ePhl>)BN91H9rGm`}p-=bFRY|y(`RRXnNmprMZfX?;EZ(H-hE*ztTJg#(bJY ztu!y;^sxQtHD{Ii5RA+BV8&|m)utjJIsY2d24g-OK3QWnak$r<@6BZnH;Gzn-gfwS z#yYd~d!oK@MSM^0kBs%^IB*2~@9t8@2J<^K{J-Q<#zu1^dENy@xtX!a40&J7A3@)9 z-)!zhEBJqt&E_dGzCXL!T-yw$R}6kXxFln<`4f3D|DM5r+-J$}{H!SD=WjJ1p`kyj z%-?2)HHUm@`?}LiZXt~Q^Y;8gbFsrs=NFl`!4dR4+Ai}Svi71&X*qwF>G}ZkAHko0 zx#`_y`jO-Q7TcR$W+gH{U%$(&MxMgo5127wmuZsyC*b^Vkj498#gV(rcgSy3c{8wF ze!I+OEiwO|{P?IX&qw_b@`3hsp1<2{hNk@Yn61%DJ;;BLxrIEP=f8jU9pP-7d(2ewDxQD0`FqU6WQ*q~=C9QXr(e&v2gQ+l%s%7~s5~Eyzm988iPk)8FAq^ADQ?z;byUF+V5c@;G9CLB{2A#Qciu@ zaeYXef5HrNIB)(*b0V9akB_ja%xKWEII9ewr3d;c&;qv?MAIddWz-{(DN z&H&5&&Y620^LL(q&b;^3{O8TbXyw6NmvUtGdGqB?zIZF=|7kXGIM8#+j0I!9TjyUk zPhdIabHzMI?s!|QUsue($gxS{`0&#Hpy#eRB}kNGe%Iy~o3Rexn}6Rt0ha6k z1M?gi*Z&9RUu0bWADFkvnBN2QA2R0mz%1QG#FPE|z?=)l{bA?%56m@a8lNTRRy3{O zC1(9#Xpe&HcZoTg+z{695;LECllRB|*(K(`Xz1@p^GnR~UB&#^zr&*cF>8Ub{iPN> zG$(=!{pKX_{n>(l&FN_B&wtHy$Mh9>`7y9OzIbGo>IV5iy!M{Qrta|6#3yD0G`;`q zvYL_cdVtGn4VL}mvIaTke`SHo@;V&oDQ&&gUBtuu?FD75W)8o(pqv#2j&MH_*V`lA zRuXyeI`MqD+sYuf<>!kH7Pzg&U>VZ~G|&tKQ! z&;^yOC16}0hY~7VYaRYQp^CKw?H2Fnjb7ky?IAzvrYPgN4}oPof9t+u{>i+&R*19x z0oG11wm)V;HS4g$DGOe;%$_hkwO_T~AeUI9bgsa6q|!}3|k>kH`R%+IjKfib_83z+p2mQy~awToPlkB{{WOzR*S{WiX)6-pj5O5w+&HLWpVxx8yy(;e>EwU!m<@Sz27Sc@F~eL?M~ z=5I8o4q0v=>RQKOdd&aaf;X*Vhp#Po+nU-Jm+wM;y(-;X&zeKV@m0^tBiprH%AE!E ztRv)(Yxwar_i6ITe01ecp+9JQQ_nKM*uMYx^i3QN^t@~R1IGN^ne{DqKQTYLa%MxT zJ2=9P@545-`jYW|*hW?;ST2u7)_yF9@l+wYk#*H!{(Tbb<^I0z>@#%pHfI_9sP+043w(?k3~Pjjo<0O((Eytjq*Hrm|; zzQ@82js;%vM&u!|!LdvHrp7-Cg1S zaa+qZ5b|+nZWqhDt>p)n@!DFoupILJIJK?S!QsHncGftjJsmCgAYXraGCNrT4)@Ib z*ct+s`(KYWlDz+x=wFXDo{a0O$C^sU_0?l}!7@LObq6fhPmiS!_Qmg?8D!OUcvxnz zH4Tj8?~BZ?Rx%p?w>vqryOl}Cc-^hVU>UEwwZk$0p@i<%Zw`0t`pHw}jpp>QN}wE< zM|ft4HF5~{_m*j5`_R*xO2+lAr}Yh3#_MUV$8zX@Z)Q(xr^5-Ey{wZCr)KuHZabWn z*~cpP8N`G67iac;s=h{ZKDFvXIp+6mWE^{e~S%u=G)(@M}C3dzexA?w^o3| zl`{N!-Zh#1tu0`g{{X89r-%4kG6z@}9bR2&uyxDfR~8Jh{6l^D26{rR&0x&0DD!ix z$l>2Ihg(%Y$Na?hs5o+jrIGP?V1)G=dDu3E9}kSM>Vai`Bdjnm)_)>%gjIyoL%wG- zM_NsWiTcA8aejO^bF9^WIC^h2MJbat!74(-^nspQj}jOi|5mX$Bc&hl^{6ZpJZ)CL%c%?ldL@s zckDX(sq#j1rdYS29P_P`HPsq22Kx)whiTS$GOiEPtW2=SmqmHHTY7*$9$Xfcprjs`_pKS*BasQ0Z){5*fIS_S<%*e<1qiP4vOd7 zW2_NmF}~N;kFgGeWxN>c6qdvCnA;=9x(1fp$5@Mv_vQ0(R-E-AxX=&3pBQhoCoj9G zDBZK-t!`-Af5%%%V9dWaFE0Sg`sZ2`C-~|go;A-(2N(JsJSC2IlC4~Dggb;E?~Kh# zww96cds4~PDslsUz7odEH{$#hKiN_ziuy5L=lRK2J{bFVT2_j63M}KLS{KL|FV(tE z7V+lIPPK~BuJ#Zw)iT1MzoGx;WTjefIUJXjX0-#$_NH4!V2q!fm0=xqI6G^B^#EMx z3gq{fmt^s~$6ty1I0lUYlx6g17h)XD|R`IlNPr}*YS zpY^qs0LK3MD{GlG-{D(X-&i}rg?>xYT*~9Dd}|+B+;1$Eoo^i>|Ht=Ne%xo#6hGez zn(FJHVbS^4Mlj}IA$x^YZki~^_%COFXVq}{&-9hnhu}iL5$i>Nt+Lva&+vRoWv{Zj zpef!eD-0~#yUHp6V>~T;wN+)hFJ6u8HCAhIp)0wKOR1N=)=DIgTFbX*+=tOr|5~f= z3}1T!J!`E3FxKB9d!1D!+*f~_?DZCN*pt1{8UdEi6Ku7{k@5ShTdgVN(G6TmzwE8n zY&6B+YMlkk_HDJ^o#~4=Bzv0`?C_}UAFU~1%x_Zm&(|4(kvZpKsV< zog@eI>(PUI?65ANDgF+t?ks2fcUWF9)*qf-U>yS&`aQQx9DnY#&Z24lomPw4zI=Cf z*=colczjTy6$ZxoyxG547s32`3t!%~Tt(I`@;L4(K}A*x`AoWap03DJ=7{>``dMTJ zG0y+JUtVO@g>rd)w#fQ1!r7i8>i`(zCuHxkSR~ZvI>y(pg{ix(0cdK^ZfgWsE|1;T zUNFv|n!U$*)$40-R`y=&b%z&c@3Xpq3;hN_e;=@VlCLF+=S>b+1IX3*^ChdZ4_G76 z6#szr16amCU>yKs{0-R$EhEYo|A*|~tOnph*Tb(}N@4aPYdo6jJ7i4-%lZykv0$uk zU-n_^BpBD%AF_{Fw{U){@2K@oH1rqMchqVMmh~OAMu4%t!`a8IEnuwgVeoP5pu_Rr z6V_#Lq2DSvzdC8%B)9rWoL`-^O3)PVq}4J;#Fz0-T1u=i#ygpP%JP8u_el8nSqAqw zZS^2e;p6AmtkYJ1w5tdI9#FmP(^ft?Hk-dM#9e}>c&DunaS#ulFDaLC+6qO({w~mS z);bQx_H2ef}!^eyWXFy%A*wlxl%r0nO*)6BVR?N7q~5YM{}Rqk2G z$ap{Cp7jTs;@z|Ef-zp5oO>32KNagQtK7Gm&V~AD`uo zvF3uY{&#aqtXzkiw4mtl>3&C>x^~A~t%jNyVdXy~UVSZh56uV=JFMddl%kB-v=?CSM zw!^@Mehn&#jyUoBKsh^+oX6kSIqofIr;|^@cr9n=lDm7v{-d0| zj9j0*irj^t4~X)OZ?$PS4vPm-Din?r=)ZEA~S2%e+70asur24yWW)v$vD~ z;QbSqQ{6u7a7xar_8Ibg-d|tmsP+}|>%6~KTq zs=AcDIm`}l_(+av_owN_^K*aXSoYJ~H_Hyo5cSFN_?mqmjN|cQ&g=Fo^L_n)J*TGK z#^J{~b?hzwVBe5>a+uqT6Y{WWtN+KJ#o*ZHL`<&E4%_CYk&-^e}z#`f3a z<(D1SBO2Q!V64A!ZWH^XOz3|<@%&M$r>WfyP4zXk`+()~NK<<~80T-1+te;_xLxl1 zwttqde*-e|)gFIPA%7VIOt4M{Y~I1P$N&PxZ92%Va}+?oIsv6|1vb*)Nhm z~w~KIkS217SQMny#zdXpF^66k#0?YY3*bI#GC+2pv$Kdp?Sv-DPZYO*7 zQ}cJSH$63fC;N(H{_Nb&cH@Q6|FFL-pZl@h87$X_AiFym*M}gxFPicTvZsJ$enECI z81q|_+r@6R2$zRA-pS7mwmXvXcq7>EN}j{_KgYenc5m`pxc?Vy4z-w z{9wBPEaL~;kH8pzO>S4a<6>X?HsyA+dpW#4x4Zp0xX`aLKfbM>-oyTa{5f|lz?P&+0 zss5hNZ0~y7t7v-hJkuY!ee5EKujKZ%?XR)E9sK%Eac)1m8Ch&UALsVBkAmg#Nq@W2 zGBLf(zrW4En189f0rqGxPG3H6pgkL0=t|+^t8(5TdncOm9b`X!ely5E4&`!tBFkm` zL3ZqN5#Lunm2a2C`m^_YMd=(g$X<@+N|nCowcv2&AAWtZtTM>1_^p^9>uc&a$S$2P zJWtup^Q)FO*sez&$!+F+X7>RXD)_&cP`d~muB_qjfAHt8?RqPqKa_1}(8_n{SIB+H z!#88O%&()Li{~5qzkJ8={fE42% zFZ1nx-Y`3x+z^i6hS|Hw?T3l!huOc8->)c+_lDc2$agxslsEH++Z$J5edRtD{WsPw zScCp$uE=MsowxxV0qq@Y7i~m$YlYGZLvIP3p%DFdMo)ID(|!v%O_F! zMsiL5{v!Y-jHLPhS-ukEbE@43@|ELrs=X1M ztPJ7*3u=}()n2w;v`3EDaC@!8!QE%t8-K#~;{S?f+bw^_{tD#dtE@7|9#kMK|DQC+ zP6S6NS^Ry(vPy)#8!Y=T!afF;<2%B3@5K6Wd`H+JWE|fSwtpd(+y7#Hq2%;-{C$qR z2zwD3$7_sTK*sSLYuEb)=btiyx6+EWi^$FR_~m~{v=5V8@bT+X5^S>wr|-tcZ-kX- z*Cns-A=*3FPW~0k)A{yGcoq3@2LB&!xw&@T16UqYSvbWWOJ2$E-*m}Kw-d?5+=1m5 z*hPnM`ak&mWtD7u`*Czn81LD3{}bqLPeiMa-XTzi=8| z0Qu(1@kQe`SB@tduZ!gPQE{DlgR*QIiP8n55{&p2Mc`QLcP@%oLdpT?`t zI9|Vz@o2n$V>gC)a{Ig7ZUdgB%;+H6yWIYme3E-8cMtMU`8_$RFe+m2!quunZ=nwRR%l50$3@juy(_G&D5Pnf~q&ndOh-cHkt z=Z{C`ZL}+%7y01x&?ECU+3mFP7SBFGfTEl~uOdKRXU@8P}(Cb}m?MFE7~t zfN^|n&bw&4FG2hL@cEBR_J906V%{HqIkQ|!sOyp)faR{?3l!z&iI?meV4VM_yvufb zu#A7r?m@=**X^NT8ULo81IG3o%)4dpeQN%D_U}*4f8W0T)cpV0qc4kmG5&?ThxQ!s zCCdMi9Y@CeAKB?>%Kwo)_=$Mz(!od1bElZ^8}v19)qd+!7H^>qG^U#~y!_kHL7 z8)YG@xcT&7DHGB{bZe^{YPqo3~M2 z-D~PE@5Jj1Wn;?g4s!nG{66^(=attT=KPzTf2jE>$Lq`a+so_9HhO+-Z?CA^-TdXY zKU-DT_Y>i}-(FQW^bMi^dnDg4zT(0*b?IB;H+}AV`xoj4s2}CAd)-jyxAOR6-B|Ub zJUZ2_dt2gPLsR-kbU1IH^_yK*(C-1Q>guZAk#LMZ_Nv=m{igrnw|B1V@4{_7*{yD7 z5q-BhdRO9qmqzgS5l^9>b&smw`_ye#zomab ztG;z3HXHx@I?8(9eszn~kMZq(b>;v3r2PBU%~b!TG=%35Kh5{6W8wJk_qjWHem&;) zes%Y2IKKaMVBK$wUhDITw;x!yR{fXj_rZ4i_Q7@Q)&G04_y^Ywde73!UCaAbQ@>m{ zN&P18obL>*o94oe{*byQ|N12TVRdh+-}H0n@IiHzTO|DN(PVyKXUX)#>&|fgFSGxQ z5r@~Er+%aFcg5j#vy14DsQZ`te;*nB5q1AozsYm@?MKx0ec#fz_M^UTrt_P<99h@< z0|`g@46U1>erx~obX46W7hZ7&pLd*bRNZRzqyIaq5&edMe&~n7KbyWm!hI{^xm!Mx4&>xa+oBtRM_xv9&LBBen@0Tm)KS=%7 z9{p_OQFWu#kMZNMp#2zDH%Y^h{;;~Ii}*FB-w@D$CI89v8`C#vxaa?93Hmhw{Xu2h z=08HiJ^x>opkEQtcPrmE|A89r`Tw{C{gQxww^rNc-%GcGx!mjvDUy zUs{5GPC)-*3HsU!N#FB7Tm5Jc8r#E+fd2Io^i)~Qf0FvM`A-k%Hd)5C^nm`KCFm>L7W2PI{n`9y2lVfips(CH;IIB|@DJ$YFKk<%?KIr$b4CgJxdDA; zyKVFDsNtUf#U==-)0uU%qRx{?Ai?w*F@Z^skqor`?MA ze_Q?8{HF)>e=9-1HK0GOeX%}mf5_%*c^X!Cv4-3D=e*m8)m^3jzem0KJVEDZc->9T z-}y>eUmISx!2GT9e7<)Ahs!GD$9#4`;NsgDP)sr3GD9&i_)drP><6H|`YGMn=Mjn_~GKmCqkhLpev#wL<*a=9D=k`Y zy&XUg2Rl1GhS!EAUFaL>03sde1?97_gXsfuqWlmK5c1vskfrlQSI>=KOn0mkd_rv> z5$Nl|9qYvJ@sPuy&mYo9dVnkMm-sPlQTtB#Qz|BJ)A*DI^BHtWKMa3ooW(o7&LHyB zQu$j-pH-fF^0#3mU#Qp6dzK!u?B%(mEx&-1T)Wv)IX^8u>@MU3e3l+UyM|p(Jj}}J zC0Bn9#J4!TDtRS?NJ8$eBg= zdEt@%&Sy(LW4fNt28-N)$Oqb2!^dR)#Pwr*KP1PIcqk9}Kks}&{;cx1{@%Ce_pX=x z#dJU4@hgEc zTDb9#Y1T;d-_Gy+2%o)=_+&VrqvgHdmf-j9D)cc~z7yJk&k{<%J>XvqnEz$71;*5W zoj~t5y(F~1_OmIy^L%mmVm>1z^l$T75Q+b)!h|*{^n5_~O>JLdI#I{VNg;jI!#1jS zUr!AmJNY7dM91wh9qr_pG0)Pi!no4qAG29O!Hn5n9#2-u=I-Y5f%Fr`pHb8PpN~_=jhuSKTmJFak|m_ zc(*$Kn~K6?GCNA>&1Z$5r-z&!e{K3Y-{lkf1|H=A|Am80e)F@Q+;|)1hk6szKjF%0 z2Jb0~9*)s@M@p|~`R3>?<&&r1s=tiDANFtlgu?V&%Gdan7x*KcVi;4XhswuHe@53> zuf_3UuQ9dKdX-uf(6yUmHaJ9353uPoqNniFOq2j?%Nxi@5XeMw)dWXeMgD!=fitBc`$BR_%sJI|M#@K0Au>J z>1N3pri*!xL7y)CrUyPp?c{_W0JG9*sXn^8^#FsuJc|8EK`&YIWa&Fgo-FyHCzJ!~ zvq7&X)N5-e<3c+Ly&3fM@S`0s_WS&yeMLCh?JynmCul$0xq5WTd1klGg~!h_JI#t8 z>bs?S&Z7Uk_*#0teaK25<&1F^=0z9fO@FVsc~dcr=>b0LCiT|v7zc&^gsh$L<08;U zt{;To_$359>fe=a+yOnIyu&r4z)T5b&6H zJmJPkSXa#Tws;8tom+RoI23e%#pCXnX1{9frr~3!=fsWU(jYt>uQxwF#xKoFC#H_N zj+4-QHx5KR$ZIgBmv!ASp{I9}e5ACH&kjrf_N`6=A#Y=Tw|+_V7Sjc8T@7|(<)6^H zKUjR=A67s5sgzFEael5qm&MQMTFx&lC)g>**UbxWe)$yh^Lm56q5onzynVE^e8D%= zujQ|?ew#~IO3vnnf4=g0{i2;J)_+`Rzq0T(ms!34;!n&@_c+}A^K|_wrk!puysb<5 z^#_|L@P3Sr`+d7!D8KH;2kjHqQ^NJF4;EPcvH7ZB_X_Dkf5^|~wQ*rwZT^Tt{=gSQ zzn}4M?RWXTjdhamPtOnOKwt1@$%T9YhIGJNyA~JL35)TOYxe+s{w$s^H^kd^I@#rt z6%XYVmVZd!=}xl~>=(W1<^h0KUn8n^{qv+C}^Z4gvi}xD8b1VERbY98(cFG_7sR^C$+J!89|7j-2 zVqKR{2>kBmyKaSVw=;}C#tk9Fx})s}@_bGAffCx$?bEhb$oojT4w4m~qkYsq^3(%% z;?~#B;dd-Wj&BV%xQyS)694o3E}_6(SDAdHPdAvA&knUlAC605=R5M*cHxKoVBal- zu-6cVe82DP2KEYA<@U*T;j`sp{~zhNCZ$98-C9Zii3Wq9`8UHD^v@wfagtN1TIL%v$iK^eB1b~s(e;Fs+PeL7+c!pe#0C8z-m$ul14k zb?d6EKTS7w>GJ-cOV{!jlj+f?k9=M`(ewg60AfG{B+H4 zOi$}NY(lNoA31+q@S~pq-BRt>dAz0TD7k{YX3<$XT+XT&9#3e0pSXA_^`2((m_5V= z{g{4Zr#GxeN3?9Z&~v^4CqEJG>rm)%H83R{U<4@Cn0@*LE(Yau<&B2ETiCe*y3Gf=vSPSgEy@6QVViJR9Ue2ePc z#~-2Vj1eI`uk%MAzQ0=+d$+>U-?NRth(f>7#q|7(O^45@wD_^Ygf3M+Dedd{A$`b$ z{K1cK$b)eBk^a?gK5X$~g8!H;mVSdmpWiHfws-OlRrwM+jw2&#JJITUrS7Bo zelFzu7gs;`SY&blUh!S?gKsD8NBR5dql|CtVCvEd`NBU*_XlFP50}ti-FVIBB{@1m z+y6XGxl{O-xpOJJf9S?o;<)Kg!dKDsMzt=~=q53rG9y$9vb$k$j}|>LP(T*WTx8iyN09{&;tO;e&4o z9k0v$%JPqNt>5tdm-TBoGX8nTzs&V(D2fk^0NeXsQOy4-Y1Ks{+F&)p7n#4Db|3{tQr1YoLto%bhEzJ+?*W#i48>gGa z*W^ga${4_@Xw;$1EM+#BQ9E6vjyypKbcPl%uzA8=vJG(Y@a! zotF#ci18oh6Q)N$@4&bR;mFU^uD+svp`L;+j0gYkHJ%^$hJKVI=tF*}=Y~&QJCVBa zE9+JH=Ux3SbM?EtP`|5P`n}xzhul85otsGr_%m-2J;xN{v0jdL2lLh+9b@H(c~Aab zi$CL60u$=TcOgpq_QZ7pbA@*6v!eTJt)(BH1I4*YoTtV*gPk9Y$ew_j94bV5%g|Z;dL%px(!}%PFJ10KX&0kF)F+HW{ z8E`(@`^UTSL@8+Pc|^r@G5!8ND;LAZ^nv;l>hH#-A$|9si@or=-WviThd;-JbuF`} zgsQJMyE6H6G)d=w`NFxW_sb+arcoCPzr^J;b#%D`o#`ba(-Yr&>-6)=%@QvngFJ3= zdV>9%eaAF;2g@h?CPz}hLq7&%XJ>x>0QJUTOja+vyf{bPT)G2y;lnBWKfKASBZ{^Iz4 z-vM+u9~{z|KQ6rAfc08~9-k$@?Zd}p>(6YL^F%Ig|BtqE2>nP8;gAO~D?eG`#vkia zfH7e`EKBYze3qX2oNM~diWlZH)C=VA>ej($>i#Cb$K(1t_>05&{MePE$Fy+nub94Z zIO1D7lMwnH#0&A4jI{DXI{`ZQ4aW52=PduBANsfTYpmmQzo_*lb^SMwv$X$?2=-{{ zAphC$9H%d|+u#E^Lp{bQNHnBd1b8k{4+IV14Ns<&Bq*lE}v z+;qF8AL7w&0V03!V|~V;f1e>M{m%-Yl`i(tufU1>Y4r$raA2@3zV0v-eFro$-$- zD?H?ba-Hn>*}RC)3AHo3G`}BzEqck)edh}nzL3W&VwYjOuspFphW%VX)b|72dURMm zS4FT{iW0ETkIj<64U%VLwe<~D<<7xtcA zM96=9wuPe{Fdl>*f^WHw*ZDgzZvO@Ehe4iQ^jvO4H|jVkra6xb--N#I&NpMcX8Y$c z^>O=Nn5P=_=V8%~WZ`X{3*%DGk6W)a`o{fq8kT!@GC0Z~q%w|w#W z3eBI-cjyN_puK;=??Jly@JW5hyrAoCX8$HnM5|_5{y~p(um~@fJ1Lz1{v=<~|MiZq zokx!wrEh$AKVJK_)P-|<^lK}ZFde){f^g{R)uVkcvHYU`pxi=;_*r;_hw!RX zgg?(iv|UJO_yqB%h4{3b*|7`n%Q#*mFW(`%uz}2Tr!c0WE_|YcXs@hY z;P)4GzV6#qgad-k?7`Q=x7_&x;Bo#C_6WN{`Lq<@SI-Th{fHQ zwzX$j=^yuP(N{tySL)i09Ig7X@j*JTs~>dyez8l(`a$lGZV*0R&+tD!#qcPns~sKu z+Y3=1=!XGO4@~};EPp(%Q2Ap*KJcE}*He*??}^w!U{c7p=?m}8CiH=hL%n{iob&E| zHP0XEnciUMJ{;xnm5Gv`$77rayGQz#j_)t*+$qY(r;l>7c-}sW^x+s6Muax%D z_17Hjq~ppweMjxX^Rsp=a(eXVh@ala?5v`f*$wUuKzX3w{X(6EV|^ay?l3+F#QsFn z?;H623cPm^#w*6BWPJSl2;dL8eO-Hi_gmKe!O92nfU^TwD3Ms zm>%>9*gSn^>CfZ;x7acCR$M>uo*VK5=*tD|Q*peA`s(=~zaAdigS{W06yB>w`k~%Y zPw+lyOwc4fj!Q z{+-oJ>=(dqknf9e@AVaj^ZWM>4|?pUG!OEAty|a2YPVXdM;qtGg!@E_{dn({zc+Qb zjVlcDK9<&ZjN?nk|KoTYzgYaze2ddb$l`x`Ig0Za%3oTp=Enb@l3%=Uf%muY-m&eQ z`u9oqbMp;bU-s*|XcrJ4>)3d25d7PXu=2h1D61e$_E~4WX z8o%q@{NgXV@1MB$qWE4Ohd)8A^is4(wN3dBaX30^Zt7ziyB6G<;+GY4wch?P#~YjrPvU zf$!~6JkG12Tw9($oX^*k4#qDCZYcUkUw5A)hn8N%WVafeQ0vcFE~si1(VIM>`)7();@dP!6Z6{WmTLg#SDv+{Onn*?m@6-}U9Yy?mjUrt4|* z%M>vC>I+Qc$Q7_LuzBrw5y%F~| zVqQME!RQUf1v#x;asCnewvpSX<@0VX9>yo;=Y1TPPsB$!_H)s`9C57W&*Vu6_+omb z?;-AQvTqlQbH@8KuKWzfw5zV) zM^qf1WZ-en3(vcBKgI78hW<^wmMH6qrr($<_55c-4?kl4+Kty*cyT@9cHZ^Z&9$!+ zo;7~Pr}=gXdoQl%zW#sK?E=ziuj4b{J^}w(wM%HfLcQ8}AuXJ*ZmxdA_Q}RWjqk;R z-G%+K*)PAxvBk;>{ZSS@*5C1-?3<^Uoxopg_mR7Qf$yLCFQ$Y1NVk;#-};_|moxNZ zo)ALt4e{`I|G@MLKj=;Gd~U?)CB&m$F4z5~gzP*V)(s*ud`y3QS@`>K+>;f?H@ejE z$r0$#E}&fP-jbNsoNwj&p&MTqzsBn{=r;{EUa!FV2*zh<$MGI~xb716YvH;N=BuFl zua4i+^lZHs=VZ5Ef1g!3v{Zgumx25V&Cqj8DRuk4*+fo9r{*VfvJ-}=j6#3_=ffe zeQa;}mnv`QDNMJy>3vV{6~TO$$6@YV@=Xqg=Lc~P8RNqH+u-b3zu0nRrAmf~aQ zq+{CX)>{z|uvB~tZ+su|csIW~_(rSG;0IWWuZ`3AzKcgCpSZs#rL&6WccsJsyWDfVaU$IdJHc*XwgcxJbJA5`$(7tRxe~gTKF*8~m`&13uty_{Ql15BjhiaDEW{;RikV zqufCk;z1ws5A6@}n`?)m{h_>Z{xwXmxV|;kb1AzE<%J*l0}SPdAK`#ueX{w7Z{MI- z!>287SCCGaFZdCDS1RoszJn1_>yym?l0vVizPe6=d%O}l)a{ctjZX{f_XtpLfVcf@&j`6?!|_`c>KWki@5hs5I$$H=@skf z6Av-}&F*~#(>H&oLHFyqA9w3&sK2N`4SJs)uVZRFZ2WbK{0Q z4LC*gT}IvX9DOGe5sq zUuJfT^2N9g5bF%KZkc@#u+d|^#Gm8CdMD27ect&j#Xl?G$S2OTnB4w6QW$RcA~!$0 zRJ!3k%V)TG0_3stRgLczws<^l(|Q*bzI%fCP$)OfX~k}R;0GEnq21iPz51`8w2zqH z(s@Q>I|=!IUiyL^0wUed${w@IW$HPm2c%c3d`#ahFCXj|hy3k*cz;d?_Zwrq5a-y# z`ipW0g#4xS1^JE6*Wax8M(6Dg`og;E8P`d>f^~ggPp}?k>EYau-_On}56FS~VCj3l z#r1{vqxC#Ezen{|lLPf5)ED@MbjAE|exc>%Yx#+(lUql~N-ASE9CC!|gz>_1vHmWi8uwnLh4cB02CH8P$N4Z@pYq=uKsX@QuZkhYKm0zK zu5>B)<+g^v| zkNY=D$$y#JandLs#rX6y%8y?+h2E@QVq6LRMAUSBja>cr?bPnSv~eNye2KgF5#!QV z^t=`BW#Roc&F=Uq34#CFVnz|8epuH69`smGLi$9^G z^y>*BKdk52K5pZ69^kQ#XL9)UYg-55`K+6-<9s{ltv+I0$MXWWeq-&Nzjp`uwsksx z4-fA9LU>kw!|={}@2xL~;`OA&-J6{j_Sv^DJff!Kg?jY+Q?O4!$Q|yRX4x(1aX$g< zZMs|ES*ho#czxaZ(Vp4)*Vx_v#OqKx-j3XP7T_cLrMt%h?+akv6#kaJZ-9KFKbhtF zHMA>#en{-okH?VCXO-?}%@6k%EclkyE1O@Xbi2NvkaOdQd|`gw&8?4pR&reF_N8D4 zp*&XKQ}?~foLg_o6Xf``^x!l32rIWsU3nI#8xg|oeuad3>?HIlb=Up>T;Y3~unV(? zgsv+ZKjFJLJYJh-<1n04!F%0k2SbQ;KAV5Ed_4mDv3Tz!^iOi{`vU%Nmkav)uh!f4 z&JR!dhuPl+gKRu^$j##S`@+}iIw`Lg=sYr^!McB*(gW&`s8qP=1MiFDyt?<_biJg@ z_l@ZN9SN1Y_Yte~eW@H(x%ZX+yXcTV?6W`f1Jjr30q0(EFJ(+;>b`qIot@k`$2&2= zqr5Qx3CG*kZ)L9&gyGF(WWDZb9_Oa6z#gm7NyygK85p+b+pQ}2Pq_uYNHv;HnFeE;mT%I7tQnH<*t zCUnbJ#GjJoGgpwexpXZpuTT4)Ec9S7rnhxn*1w0@Qh8SC{M>(Ep|3k%gn0?pYixbX zuVa@=2lM-%-fsHFer2h6S?wRznX=ZGY`w~_FNN|JuV?x7C8P7}OD1pQb_DIJ?ZYR9 zd)P|hv9AicVt-aTz~g?e(&Mvj?>Bt<_@Vq)U2Elfpc~&}9jduFHIaZ!!gW6a+_(hm^4O>A_-moVI+kC*4Z}~+@jt)6=-wj_`%CQCHEoBD`Df`B_aB>H ze0gC!QH=NbMn8`Av0}UQ>o148_Zc=;n4a6V5s2@E@^`%SdtovC&Ygc~IzL`dVZA~- z66zI#T=#xPxbE=b5Nn@+zsar30-{}f!@WP$ zQacRSK|(*|0tA2PH@wFOdTA~l?$18jop(b#=sk-+#_6X2#_e-fypTWQhxUMe)a=!d zBg1_v>whA$^Jg*j((~zwy9d(uv*<^RZ)thM`;b0dWaEip>&zYit-c@~zYc=->P%fH z;rGkjxCi|>;!St+pZ3~sCxvyq8y()ld7N4$>850KeD8CK@TT=#x;;nzN52{Ro7*0Q z^)hUCN`~t=z|ZrrE^PZC7$^K+xV3M5FOiOeQ~Ljkep+h3Hja!7_kowPua?q>@`UYG zXy51;O3{@H57Q0v6^_4=F6!y_uJ54UN43`8&2a6F-Q(-qJG5h;6*PN}-98I{*F9ss zC)7*WFNAtRe`5Ob{fW^<6vhwvmntXdy%b%kaGVPX(_iJr7h%3i&09lyj1Q0w&X?f5 zzhZwv-)yjcFT{^|#`+_KLtcza!h9m#mg2*G+*0p9qJKsHAQ#3np+2@(f2HonYML+K zhxMG*C$mF;4(B{whlr?Ud@;|%J`MI$_?*3tH~2nYeJ?TR&QW>#Vm&lI&t~Bf*}g1) zheP*gBL`!LZ>hW(e?&A*_xt#~k=yq}d(*P@vg~#!)GzcJ;*rl{efV`1obv?)pJIAn zu9%-%f8f^%!*r2foCmXemvLWkQs~E8ivOQ3UsirFPYc@zjMq({zP@~3`9!(2%nq^c zT6&!q>t0Qd+j4H+k}ur*`G54*&)B&3)9dGdtKDST<^R_F{GVNawszf8eg1E?o9(R! zVgH-e5499uN{?Z>S@LfipFPg`uTCH7h55?D->dh!g!^k4hhjYF$6Hx^F)zgVu~OqU z==0=%*m%2?AM3l8z8|+`jn_}_DSTu4MOT4*E_P3WDV@?uV2(a3*92k8AbjmO_OKmO`?n}1d4`YhkqwLts{eeW{Em(l~~JwKQ%>Boe7q=3i$ z@TL4XKWh88k^BC6R9LTUIzE5*L=M+-9 z#@%~|aHLo4=Y0!z-vZM8hWq|3Ao3MYGI=g@?Hlk9xO>WwuS;CMKo5xg%zjn)@H+Z% z;|G6!g!uV8fes(Lefdy7NEh-VUCUp#oDI2jD%#_e%lIeq;LL zO(xGgwda`ZJEchhkNw2(JHVyhm&mz%HkS_fOj-H)d#i4`&Gd|Z(fV_&kMVc8be|-m zGu?ak-?~QV`Mj?4-*jZLAK~?`T>%X7h=*`MyJr{o%6;4PW%Nt;eK>1BBf8;k$yZF~=XKu)#LwrxTz?0@-KUvt_psN{uCwfS(My)D z*{}Z&0q{-RagMCNi>TK=l3#DvXy4yI!tj8hy{~iaW{9_TjnBPggd4uJ-4^pHZC~K~ z^Z=2Y$9D=F+gHff=<|)}VK-qufG_6b(?K}o$*P|rU6$OSD^4#*S#raEOVPJ|LF|U_ zhtzQgU|g_U^v7nm2~B+clk~B(cW>vQw|W44T8IZd0)qZ7tv4Zk&ea>fN6y(%gB!Q) zrS}qHe+BP(M6^=RWyG|1Ta&XeUUBE5(f;<=em17zdVZDTxq7?58z*A_ZIWwG+buGF zhr9k^59j~b`JqQ^=lI?QH}0_h+TUMWR&MoacbA`vdBzw0zK!oO|3d#1)01wTi+kcj z|Bu}K)4qq|>Ce&o{bNG-D9sLF{b0WDOvleDp*@0r0ry@ha&UX=#={+NG`TPj0c;x2^YfvvfszYy!H z@9qUbegQFWo~Z9(M-)QvM|*1Dhf3%;U3cVr zay0aE3HSL0Kg2gWzNhM4q2u<-jWa?z^z+m2Fgmnj+e?S_V|+I=76$%UnlB(A$9kr=4gsr4-M)5He2XZGWwjO z&ll*!{Dkp8uXN72OXTAGX!(14F#E{S$EQnpp0+A1qb_=nNO_^ZdHVy4Z+sHRCv|p} zb9R=e!+$Dt+aKTLD06a@J2_ev|31I8=R2jrNf<7UtIG1otZ_36$JE&Z^+LjQvOJ%fA?Oy1h@KdOC2 zu3iDg^r6-_@5lTV`mpe%u>J_V(fR&j#;;5+gE8&n_BGKiy;EUwpdA1n{ip3)`F^q( z@B35a6Z*kDNq|}Thn|uChQ4Me)_(f-%EosI**!@qAsqXs?dDrPkp3qjTQ#*A%xiCK z|NVHqK-S$)|GLqi`--lWM`)+f9S8PTi-xAhJM)dTrJO-W^^=u z;19kSr+v}wLmG@}>PuE0#r}i_y7n3J01iLK=po- zXg^kc&)N-x+%C9r9@-uBi-4v2$K|^SKVIi@{eqP{`U#wWK>y+WHr_#f_vgljj5YbN zUIe*tZUXB=m`@|UV!ywS68YFRY`mUk^)@QhTg=a`eerTz|Kj~w`9eO1=zJh{-&>Ce z{*$k;d}rws{eRZD1M{An-M$0--L;+e^P+d27yC%)OgGO4-38kJd%DnnoZCMJ{iP?F zyv_ADxN!>T(Lcf8`5uwWr~lD~#r{KX5}?>2!c?e~a4Pan?jz}M`i@%#||o9Q3> zTa95Dj(OUlZvMVxlF5Pg1`u`{+AYQn#gM5D!1>6zw$d@!8CV%Nc%z<6JTDAsy@& z>y%k^u*(@O({PFcx?xpmD`ha!aEO}A?F^|ZiLw#