Beispiel #1
0
        public async Task <bool> GetFiles(string subPath = null)
        {
            _siteSettings = _publishSettingsService.GetSettingsByPublishMethod(PublishMethods.MSDeploy);

            using (HttpClient httpClient = new HttpClient())
            {
                httpClient.Timeout = TimeSpan.FromMilliseconds(10000);

                var requestUri = $"https://{_siteSettings.ApiUrl}/api/zip/site/wwwroot/";

                if (!string.IsNullOrEmpty(subPath))
                {
                    subPath     = subPath.Trim('/').Trim('\\');
                    requestUri += $"{subPath}/";
                }

                _localLogService.Log($"Grabbing from {requestUri}");

                var request = new HttpRequestMessage(HttpMethod.Get, requestUri);

                request.Headers.Authorization = new AuthenticationHeaderValue("Basic",
                                                                              HttpHelpers.GetAuthenticationString(_siteSettings));

                var response = await httpClient.SendAsync(
                    request, HttpCompletionOption.ResponseHeadersRead);

                if (!response.IsSuccessStatusCode)
                {
                    _localLogService.Log($"Error: Count not get files from {requestUri}");
                    return(false);
                }

                var result = await response.Content.ReadAsByteArrayAsync();

                var saveFile = Path.GetTempFileName();

                File.WriteAllBytes(saveFile, result);

                try
                {
                    var dir = Directory.GetCurrentDirectory();
                    if (!string.IsNullOrEmpty(subPath))
                    {
                        dir += $"\\{subPath}";
                    }

                    ZipFile.ExtractToDirectory(saveFile, dir);

                    foreach (var f in Directory.GetFiles(dir, "*", SearchOption.AllDirectories))
                    {
                        if (_fileWatcherService.Validate(f))
                        {
                            _localLogService.Log($" - {f.Replace(dir, "")}");
                        }
                    }
                }
                catch (System.IO.IOException ex)
                {
                    _localLogService.LogWarning(
                        "k-scratch will not overwrite existing files. Please 'get' in to an empty directory.");
                    return(false);
                }
                finally
                {
                    File.Delete(saveFile);
                }

                return(true);
            }
        }