示例#1
0
        public IMessageReceiver CreateMessageReceiver(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == Constants.AzureQueueConnectionPrefix)
            {
                connectionString.GetRequired(Constants.QueueParam, true, out string queueName);

                string invisibilityString   = connectionString.Get(Constants.InvisibilityParam);
                string pollingTimeoutString = connectionString.Get(Constants.PollParam);

                if (!TimeSpan.TryParse(invisibilityString, out TimeSpan invisibility))
                {
                    invisibility = TimeSpan.FromMinutes(1);
                }

                if (!TimeSpan.TryParse(pollingTimeoutString, out TimeSpan polling))
                {
                    polling = TimeSpan.FromMinutes(1);
                }

                if (bool.TryParse(connectionString.Get(Constants.UseDevelopmentStorage), out bool useDevelopment) &&
                    useDevelopment)
                {
                    return(new AzureStorageQueueReceiver(queueName, invisibility, polling));
                }
                else
                {
                    connectionString.GetRequired(AccountParam, true, out string accountName);
                    connectionString.GetRequired(KeyParam, true, out string key);

                    return(new AzureStorageQueueReceiver(accountName, key, queueName, invisibility, polling));
                }
            }

            return(null);
        }
示例#2
0
        public IMessageReceiver CreateMessageReceiver(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.queue")
            {
                connectionString.GetRequired("account", true, out string accountName);
                connectionString.GetRequired("key", true, out string key);
                connectionString.GetRequired("queue", true, out string queueName);

                string invisibilityString   = connectionString.Get("invisibility");
                string pollingTimeoutString = connectionString.Get("poll");

                if (!TimeSpan.TryParse(invisibilityString, out TimeSpan invisibility))
                {
                    invisibility = TimeSpan.FromMinutes(1);
                }

                if (!TimeSpan.TryParse(pollingTimeoutString, out TimeSpan polling))
                {
                    polling = TimeSpan.FromMinutes(1);
                }

                return(new AzureStorageQueueReceiver(accountName, key, queueName, invisibility, polling));
            }

            return(null);
        }
示例#3
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == BlobPrefix)
            {
                if (bool.TryParse(connectionString.Get(Constants.UseDevelopmentStorage), out bool useDevelopment) && useDevelopment)
                {
                    return(AzureUniversalBlobStorageProvider.CreateForLocalEmulator());
                }
                else
                {
                    connectionString.GetRequired(AccountParam, true, out string accountName);
                    connectionString.GetRequired(KeyParam, true, out string key);

                    return(AzureUniversalBlobStorageProvider.CreateFromAccountNameAndKey(accountName, key));
                }
            }
            else
            {
                //try to re-parse native connection string
                var newcs = new StorageConnectionString(BlobPrefix + "://" + connectionString.Prefix);

                if (newcs.Parameters.TryGetValue("AccountName", out string accountName) &&
                    newcs.Parameters.TryGetValue("AccountKey", out string accountKey))
                {
                    return(AzureUniversalBlobStorageProvider.CreateFromAccountNameAndKey(accountName, accountKey));
                }
            }

            return(null);
        }
示例#4
0
 public IBlobStorage?CreateBlobStorage(StorageConnectionString connectionString)
 {
     if (connectionString.Prefix != Prefix)
     {
         return(null);
     }
     connectionString.GetRequired("username", true, out string userName);
     connectionString.GetRequired("password", true, out string password);
     connectionString.GetRequired("bucket", true, out string bucket);
     return(new PassiveFtpStorage(new NetworkCredential(userName, password, SelectelFtpDomain), bucket));
 }
示例#5
0
文件: Module.cs 项目: zihotki/storage
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.AzureFilesStorage)
            {
                connectionString.GetRequired(KnownParameter.AccountName, true, out string accountName);
                connectionString.GetRequired(KnownParameter.KeyOrPassword, true, out string key);

                return(AzureFilesBlobStorage.CreateFromAccountNameAndKey(accountName, key));
            }

            return(null);
        }
示例#6
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "google.storage")
            {
                connectionString.GetRequired("bucket", true, out string bucketName);
                connectionString.GetRequired("cred", true, out string base64EncodedJson);

                return(StorageFactory.Blobs.GoogleCloudStorageFromJson(bucketName, base64EncodedJson, true));
            }

            return(null);
        }
示例#7
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.blob")
            {
                connectionString.GetRequired("account", true, out string accountName);
                connectionString.GetRequired("key", true, out string key);

                return(new AzureUniversalBlobStorageProvider(accountName, key));
            }

            return(null);
        }
示例#8
0
        public IKeyValueStorage CreateKeyValueStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.tables")
            {
                connectionString.GetRequired("account", true, out string acctountName);
                connectionString.GetRequired("key", true, out string key);

                return(new AzureTableStorageKeyValueStorage(acctountName, key));
            }

            return(null);
        }
示例#9
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.Databricks)
            {
                connectionString.GetRequired("baseUri", true, out string baseUri);
                connectionString.GetRequired("token", true, out string token);

                return(new DatabricksBlobStorage(baseUri, token));
            }

            return(null);
        }
示例#10
0
        public IMessenger CreateMessenger(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == Constants.AzureQueueConnectionPrefix)
            {
                connectionString.GetRequired(KnownParameter.AccountName, true, out string accountName);
                connectionString.GetRequired(KnownParameter.KeyOrPassword, true, out string key);

                return(new AzureStorageQueueMessenger(accountName, key));
            }

            return(null);
        }
示例#11
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "ftp")
            {
                connectionString.GetRequired("host", true, out string host);
                connectionString.GetRequired("user", true, out string user);
                connectionString.GetRequired("password", true, out string password);

                return(new FluentFtpBlobStorage(host, new NetworkCredential(user, password)));
            }

            return(null);
        }
示例#12
0
        public IMessagePublisher CreateMessagePublisher(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.queue")
            {
                connectionString.GetRequired("account", true, out string accountName);
                connectionString.GetRequired("key", true, out string key);
                connectionString.GetRequired("queue", true, out string queueName);

                return(new AzureStorageQueuePublisher(accountName, key, queueName));
            }

            return(null);
        }
示例#13
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.keyvault")
            {
                connectionString.GetRequired("vaultUri", true, out string uri);
                connectionString.GetRequired("clientId", true, out string clientId);
                connectionString.GetRequired("clientSecret", true, out string clientSecret);

                return(new AzureKeyVaultBlobStorageProvider(new Uri(uri), clientId, clientSecret));
            }

            return(null);
        }
示例#14
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.blob")
            {
                connectionString.GetRequired("account", true, out string accountName);
                string containerName = connectionString.Get("container");
                connectionString.GetRequired("key", true, out string key);

                return(new AzureUniversalBlobStorageProvider(accountName, key,
                                                             string.IsNullOrEmpty(containerName) ? null : containerName));
            }

            return(null);
        }
示例#15
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.DatabricksDbfs)
            {
                connectionString.GetRequired("baseUri", true, out string baseUri);
                connectionString.GetRequired("token", true, out string token);
                string isReadOnlyString = connectionString.Get("isReadOnly");
                bool.TryParse(isReadOnlyString, out bool isReadOnly);

                return(new AzureDatabricksDbfsBlobStorage(baseUri, token, isReadOnly));
            }

            return(null);
        }
示例#16
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.datalakestore")
            {
                connectionString.GetRequired("accountName", true, out string accountName);
                connectionString.GetRequired("tenantId", true, out string tenantId);
                connectionString.GetRequired("principalId", true, out string principalId);
                connectionString.GetRequired("principalSecret", true, out string principalSecret);

                return(AzureDataLakeStoreBlobStorageProvider.CreateByClientSecret(accountName, tenantId, principalId, principalSecret));
            }

            return(null);
        }
        public void Ideal_connection_string_parsed()
        {
            string cs = "azure.blob://account=accname;key=keywithequals==;container=me";

            var scs = new StorageConnectionString(cs);

            Assert.Equal(cs, scs.ConnectionString);

            scs.GetRequired("account", false, out string account);
            scs.GetRequired("key", false, out string key);
            scs.GetRequired("container", false, out string container);

            Assert.Equal("accname", account);
            Assert.Equal("keywithequals==", key);
            Assert.Equal("me", container);
        }
示例#18
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "aws.s3")
            {
                string keyId = connectionString.Get("keyId");
                string key   = connectionString.Get("key");

                if (string.IsNullOrEmpty(keyId) != string.IsNullOrEmpty(key))
                {
                    throw new ArgumentException($"connection string requires both 'key' and 'keyId' parameters, or neither.");
                }

                connectionString.GetRequired("bucket", true, out string bucket);
                string region = connectionString.Get("region");

                RegionEndpoint endpoint = RegionEndpoint.GetBySystemName(string.IsNullOrEmpty(region) ? "eu-west-1" : region);

                if (string.IsNullOrEmpty(keyId))
                {
                    return(new AwsS3BlobStorage(bucket, endpoint));
                }

                return(new AwsS3BlobStorage(keyId, key, bucket, endpoint));
            }


            return(null);
        }
示例#19
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "aws.s3")
            {
                connectionString.GetRequired("keyId", true, out string keyId);
                connectionString.GetRequired("key", true, out string key);
                connectionString.GetRequired("bucket", true, out string bucket);
                string region = connectionString.Get("region");

                RegionEndpoint endpoint = RegionEndpoint.GetBySystemName(string.IsNullOrEmpty(region) ? "eu-west-1" : region);

                return(new AwsS3BlobStorageProvider(keyId, key, bucket, endpoint));
            }


            return(null);
        }
示例#20
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.blob")
            {
                connectionString.GetRequired("account", true, out string accountName);
                connectionString.GetRequired("container", true, out string containerName);
                connectionString.GetRequired("key", true, out string key);

                if (!bool.TryParse(connectionString.Get("createIfNotExists"), out bool createIfNotExists))
                {
                    createIfNotExists = true;
                }

                return(new AzureBlobStorageProvider(accountName, key, containerName, createIfNotExists));
            }

            return(null);
        }
示例#21
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == Constants.AzureBlobConnectionPrefix)
            {
                if (bool.TryParse(connectionString.Get(Constants.UseDevelopmentStorage), out bool useDevelopment) && useDevelopment)
                {
                    return(AzureUniversalBlobStorageProvider.CreateForLocalEmulator());
                }
                else
                {
                    connectionString.GetRequired(Constants.AccountParam, true, out string accountName);
                    connectionString.GetRequired(Constants.KeyParam, true, out string key);

                    return(AzureUniversalBlobStorageProvider.CreateFromAccountNameAndKey(accountName, key));
                }
            }

            return(null);
        }
示例#22
0
            public IBlobStorage?CreateBlobStorage(StorageConnectionString connectionString)
            {
                if (connectionString.Prefix != Prefix)
                {
                    return(null);
                }
                connectionString.GetRequired("username", true, out string userName);
                connectionString.GetRequired("password", true, out string password);
                connectionString.GetRequired("bucket", true, out string bucket);
                var s3 = new SelectelAwsS3BlobStorage(userName, password, bucket,
                                                      new AmazonS3Config
                {
                    ServiceURL       = SelectelServiceUri,
                    ForcePathStyle   = true,
                    SignatureVersion = AwsSignatureVersion
                });

                return(s3);
            }
示例#23
0
文件: Module.cs 项目: myso42/storage
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.datalake.gen1")
            {
                connectionString.GetRequired("account", true, out string accountName);
                connectionString.GetRequired("tenantId", true, out string tenantId);
                connectionString.GetRequired("principalId", true, out string principalId);
                connectionString.GetRequired("principalSecret", true, out string principalSecret);

                int.TryParse(connectionString.Get("listBatchSize"), out int listBatchSize);

                AzureDataLakeGen1Storage client = AzureDataLakeGen1Storage.CreateByClientSecret(
                    accountName, tenantId, principalId, principalSecret);

                if (listBatchSize != 0)
                {
                    client.ListBatchSize = listBatchSize;
                }

                return(client);
            }
            else if (connectionString.Prefix == "azure.datalake.gen2")
            {
                connectionString.GetRequired("account", true, out string accountName);

                if (connectionString.Parameters.ContainsKey("msi"))
                {
                    return(AzureDataLakeStoreGen2BlobStorageProvider.CreateByManagedIdentity(accountName));
                }

                string key = connectionString.Get("key");

                if (!string.IsNullOrWhiteSpace(key))
                {
                    //connect with shared key

                    return(AzureDataLakeStoreGen2BlobStorageProvider.CreateBySharedAccessKey(accountName, key));
                }
                else
                {
                    //connect with service principal

                    connectionString.GetRequired("tenantId", true, out string tenantId);
                    connectionString.GetRequired("principalId", true, out string principalId);
                    connectionString.GetRequired("principalSecret", true, out string principalSecret);

                    return(AzureDataLakeStoreGen2BlobStorageProvider.CreateByClientSecret(accountName, tenantId, principalId, principalSecret));
                }
            }

            return(null);
        }
示例#24
0
        public IKeyValueStorage CreateKeyValueStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == Constants.AzureTablesConnectionPrefix)
            {
                if (bool.TryParse(connectionString.Get(Constants.UseDevelopmentStorage), out bool useDevelopment) &&
                    useDevelopment)
                {
                    return(new AzureTableStorageKeyValueStorage());
                }
                else
                {
                    connectionString.GetRequired(KnownParameter.AccountName, true, out string accountName);
                    connectionString.GetRequired(KnownParameter.KeyOrPassword, true, out string key);

                    return(new AzureTableStorageKeyValueStorage(accountName, key));
                }
            }

            return(null);
        }
示例#25
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.AzureKeyVault)
            {
                connectionString.GetRequired("vaultUri", true, out string uri);

                if (connectionString.Parameters.ContainsKey("msi"))
                {
                    return(new AzureKeyVaultBlobStorageProvider(new Uri(uri)));
                }
                else
                {
                    connectionString.GetRequired("clientId", true, out string clientId);
                    connectionString.GetRequired("clientSecret", true, out string clientSecret);

                    return(new AzureKeyVaultBlobStorageProvider(new Uri(uri), clientId, clientSecret));
                }
            }

            return(null);
        }
示例#26
0
        public IMessagePublisher CreateMessagePublisher(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == Constants.AzureQueueConnectionPrefix)
            {
                connectionString.GetRequired(Constants.QueueParam, true, out string queueName);

                if (bool.TryParse(connectionString.Get(Constants.UseDevelopmentStorage), out bool useDevelopment) &&
                    useDevelopment)
                {
                    return(new AzureStorageQueuePublisher(queueName));
                }
                else
                {
                    connectionString.GetRequired(AccountParam, true, out string accountName);
                    connectionString.GetRequired(KeyParam, true, out string key);

                    return(new AzureStorageQueuePublisher(accountName, key, queueName));
                }
            }

            return(null);
        }
示例#27
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.AzureKeyVault)
            {
                connectionString.GetRequired(KnownParameter.VaultUri, true, out string uri);

                if (connectionString.Parameters.ContainsKey(KnownParameter.MsiEnabled))
                {
                    return(StorageFactory.Blobs.AzureKeyVaultWithMsi(new Uri(uri)));
                }
                else
                {
                    connectionString.GetRequired(KnownParameter.TenantId, true, out string tenantId);
                    connectionString.GetRequired(KnownParameter.ClientId, true, out string clientId);
                    connectionString.GetRequired(KnownParameter.ClientSecret, true, out string clientSecret);

                    return(StorageFactory.Blobs.AzureKeyVault(new Uri(uri), tenantId, clientId, clientSecret));
                }
            }

            return(null);
        }
示例#28
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.AwsS3)
            {
                string cliProfileName = connectionString.Get(KnownParameter.LocalProfileName);
                connectionString.GetRequired(KnownParameter.BucketName, true, out string bucket);
                connectionString.GetRequired(KnownParameter.Region, true, out string region);

                if (string.IsNullOrEmpty(cliProfileName))
                {
                    string keyId = connectionString.Get(KnownParameter.KeyId);
                    string key   = connectionString.Get(KnownParameter.KeyOrPassword);

                    if (string.IsNullOrEmpty(keyId) != string.IsNullOrEmpty(key))
                    {
                        throw new ArgumentException($"connection string requires both 'key' and 'keyId' parameters, or neither.");
                    }


                    if (string.IsNullOrEmpty(keyId))
                    {
                        return(new AwsS3BlobStorage(bucket, region));
                    }

                    string sessionToken = connectionString.Get(KnownParameter.SessionToken);
                    return(new AwsS3BlobStorage(keyId, key, sessionToken, bucket, region, null));
                }
#if !NET16
                else
                {
                    return(AwsS3BlobStorage.FromAwsCliProfile(cliProfileName, bucket, region));
                }
#endif
            }


            return(null);
        }
示例#29
0
文件: Module.cs 项目: zihotki/storage
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == KnownPrefix.AzureBlobStorage)
            {
                if (connectionString.Parameters.ContainsKey(KnownParameter.IsLocalEmulator))
                {
                    return(StorageFactory.Blobs.AzureBlobStorageWithLocalEmulator());
                }

                connectionString.GetRequired(KnownParameter.AccountName, true, out string accountName);

                string sharedKey = connectionString.Get(KnownParameter.KeyOrPassword);
                if (!string.IsNullOrEmpty(sharedKey))
                {
                    return(StorageFactory.Blobs.AzureBlobStorageWithSharedKey(accountName, sharedKey));
                }

                string tenantId = connectionString.Get(KnownParameter.TenantId);
                if (!string.IsNullOrEmpty(tenantId))
                {
                    connectionString.GetRequired(KnownParameter.ClientId, true, out string clientId);
                    connectionString.GetRequired(KnownParameter.ClientSecret, true, out string clientSecret);

                    return(StorageFactory.Blobs.AzureBlobStorageWithAzureAd(accountName, tenantId, clientId, clientSecret));
                }

                if (connectionString.Parameters.ContainsKey(KnownParameter.MsiEnabled))
                {
                    return(StorageFactory.Blobs.AzureBlobStorageWithMsi(accountName));
                }
            }
            else if (connectionString.Prefix == KnownPrefix.AzureDataLakeGen2 || connectionString.Prefix == KnownPrefix.AzureDataLake)
            {
                connectionString.GetRequired(KnownParameter.AccountName, true, out string accountName);

                string sharedKey = connectionString.Get(KnownParameter.KeyOrPassword);
                if (!string.IsNullOrEmpty(sharedKey))
                {
                    return(StorageFactory.Blobs.AzureDataLakeStorageWithSharedKey(accountName, sharedKey));
                }

                string tenantId = connectionString.Get(KnownParameter.TenantId);
                if (!string.IsNullOrEmpty(tenantId))
                {
                    connectionString.GetRequired(KnownParameter.ClientId, true, out string clientId);
                    connectionString.GetRequired(KnownParameter.ClientSecret, true, out string clientSecret);

                    return(StorageFactory.Blobs.AzureDataLakeStorageWithAzureAd(accountName, tenantId, clientId, clientSecret));
                }

                if (connectionString.Parameters.ContainsKey(KnownParameter.MsiEnabled))
                {
                    return(StorageFactory.Blobs.AzureDataLakeStorageWithMsi(accountName));
                }
            }

            return(null);
        }
示例#30
0
        public IBlobStorage CreateBlobStorage(StorageConnectionString connectionString)
        {
            if (connectionString.Prefix == "azure.datalake.gen1")
            {
                connectionString.GetRequired("accountName", true, out string accountName);
                connectionString.GetRequired("tenantId", true, out string tenantId);
                connectionString.GetRequired("principalId", true, out string principalId);
                connectionString.GetRequired("principalSecret", true, out string principalSecret);

                int.TryParse(connectionString.Get("listBatchSize"), out int listBatchSize);

                AzureDataLakeGen1Storage client = AzureDataLakeGen1Storage.CreateByClientSecret(
                    accountName, tenantId, principalId, principalSecret);

                if (listBatchSize != 0)
                {
                    client.ListBatchSize = listBatchSize;
                }

                return(client);
            }

            return(null);
        }