Example #1
0
        /// <summary>
        /// Get all releases of economic data. Corresponds to http://api.stlouisfed.org/fred/releases
        /// </summary>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period. </param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, defaults to 1000. </param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <returns>All releases in the FRED database.</returns>
        public IEnumerable<Release> GetReleases(DateTime realtimeStart, DateTime realtimeEnd, int limit = 1000,
                                                int offset = 0,
                                                Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
                                                SortOrder order = SortOrder.Ascending)
        {
            var url = String.Format(Urls.Releases, _key, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order));

            return CreateReleases(url);
        }
Example #2
0
        /// <summary>
        /// Get a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release
        /// </summary>
        /// <param name="releaseId">The ID of the release to retrieve.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period. </param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, defaults to 1000. </param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <returns>The requested release.</returns>
        /// <remarks>Note that release dates are published by data sources and do not necessarily represent when data will be available on the FRED or ALFRED websites.</remarks>

        public async Task<Release> GetReleaseAsync(int releaseId, DateTime realtimeStart, DateTime realtimeEnd, int limit = 1000,
                                  int offset = 0,
                                  Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
                                  SortOrder order = SortOrder.Ascending)
        {
            var url = String.Format(Urls.Release, _key, releaseId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            var root = await GetRootAsync(url);
            var element = root.Elements("release").First();
            return CreateRelease(element);
        }
Example #3
0
        /// <summary>
        ///   Get all releases of economic data. Corresponds to http://api.stlouisfed.org/fred/releases
        /// </summary>
        /// <param name="realtimeStart"> The start of the real-time period. </param>
        /// <param name="realtimeEnd"> The end of the real-time period. </param>
        /// <param name="limit"> The maximum number of results to return. An integer between 1 and 1000, defaults to 1000. </param>
        /// <param name="offset"> non-negative integer, optional, default: 0 </param>
        /// <param name="orderBy"> Order results by values of the specified attribute. </param>
        /// <param name="order"> Sort results is ascending or descending order for attribute values specified by order_by. </param>
        /// <returns> All releases in the FRED database. </returns>
        public async Task<IEnumerable<Release>> GetReleasesAsync(DateTime realtimeStart, DateTime realtimeEnd,
                                                                 int limit = 1000,
                                                                 int offset = 0,
                                                                 Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
                                                                 SortOrder order = SortOrder.Ascending)
        {
            var url = String.Format(Urls.Releases, _key, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order));

            var root = await GetRootAsync(url);
            return root.Elements("release").Select(CreateRelease).ToList();
        }
Example #4
0
        /// <summary>
        /// Get the release for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/release
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The release for an economic data series.</returns>
        public async Task<Release> GetSeriesReleaseAsync(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.SeriesRelease, _key, seriesId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            var root = await GetRootAsync(url);
            var element = root.Elements("release").First();
            return CreateRelease(element);
        }
Example #5
0
        /// <summary>
        /// Get economic data series that match keywords. Corresponds to http://api.stlouisfed.org/fred/series/search
        /// </summary>
        /// <param name="searchText">The words to match against economic data series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="type">Determines the type of search to perform.
        /// 'full_text' searches series attributes title, units, frequency, and notes by parsing words into stems. 
        /// This makes it possible for searches like 'Industry' to match series containing related words such as 'Industries'. 
        /// Of course, you can search for multiple words like 'money' and 'stock'. Remember to url encode spaces (e.g. 'money%20stock').
        /// 'series_id' performs a substring search on series IDs. Searching for 'ex' will find series containing 'ex' anywhere in
        ///  a series ID. '*' can be used to anchor searches and match 0 or more of any character. Searching for 'ex*' will 
        /// find series containing 'ex' at the beginning of a series ID. Searching for '*ex' will find series containing 
        /// 'ex' at the end of a series ID. It's also possible to put an '*' in the middle of a string. 'm*sl' finds any 
        /// series starting with 'm' and ending with 'sl'.
        /// optional, default: full_text.</param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, optional, default: 1000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <param name="filter">The attribute to filter results by.</param>
        /// <param name="filterValue">The value of the filter_variable attribute to filter results by.</param>
        /// <returns>Economic data series that match keywords</returns>
        public async Task<IEnumerable<Series>> GetSeriesSearchAsync(string searchText, DateTime realtimeStart, DateTime realtimeEnd,
                                                   SearchType type = SearchType.FullText,
                                                   int limit = 1000,
                                                   int offset = 0,
                                                   Series.OrderBy orderBy = Series.OrderBy.SearchRank,
                                                   SortOrder order = SortOrder.Ascending,
                                                   Series.FilterBy filter = Series.FilterBy.None,
                                                   string filterValue = "")
        {
            var url = String.Format(Urls.SeriesSearch, _key, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order), Extensions.ToString(filter),
                                    filterValue, Extensions.ToString(type), Uri.EscapeUriString(searchText));

            return await CreateSeriesAsync(url);
        }
Example #6
0
 /// <summary>
 /// Get the series in a category. Corresponds to http://api.stlouisfed.org/fred/category/series
 /// </summary>
 /// <param name="categoryId">The id for a category.</param>
 /// <param name="realtimeStart">The start of the real-time period.</param>
 /// <param name="realtimeEnd">The end of the real-time period.</param>
 /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, optional, default: 1000</param>
 /// <param name="offset">non-negative integer, optional, default: 0</param>
 /// <param name="orderBy">Order results by values of the specified attribute.</param>
 /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
 /// <param name="filter">The attribute to filter results by.</param>
 /// <param name="filterValue">The value of the filter_variable attribute to filter results by.</param>
 /// <returns>The series in a category.</returns>
 public async Task<IEnumerable<Series>> GetCategorySeriesAsync(int categoryId, DateTime realtimeStart, DateTime realtimeEnd,
                                              int limit = 1000,
                                              int offset = 0,
                                              Series.OrderBy orderBy = Series.OrderBy.SeriesId,
                                              SortOrder order = SortOrder.Ascending,
                                              Series.FilterBy filter = Series.FilterBy.None,
                                              string filterValue = "")
 {
     var url = String.Format(Urls.CategorySeries, _key, categoryId, realtimeStart.ToFredDateString(),
                             realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                             Extensions.ToString(order), Extensions.ToString(filter), filterValue);
     return await CreateSeriesAsync(url);
 }
Example #7
0
        /// <summary> 
        /// Get the categories for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/categories
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The categories for an economic data series.</returns>
        public async Task<IEnumerable<Category>> GetSeriesCategoriesAsync(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.SeriesCategories, _key, seriesId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return await CreateCategoriesAsync(url);
        }
Example #8
0
        /// <summary>
        /// Get the series on a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release/series
        /// </summary>
        /// <param name="releaseId">The id for a release.</param>
        /// <param name="realtimeStart">The start of the real-time period</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, optional, default: 1000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <param name="filter">The attribute to filter results by.</param>
        /// <param name="filterValue">The value of the filter_variable attribute to filter results by.</param>
        /// <returns>The series on a release of economic data. </returns>
        public IEnumerable<Series> GetReleaseSeries(int releaseId, DateTime realtimeStart, DateTime realtimeEnd,
                                                    int limit = 1000,
                                                    int offset = 0,
                                                    Series.OrderBy orderBy = Series.OrderBy.SeriesId,
                                                    SortOrder order = SortOrder.Ascending,
                                                    Series.FilterBy filter = Series.FilterBy.None,
                                                    string filterValue = "")
        {
            var url = String.Format(Urls.ReleaseSeries, _key, releaseId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order), Extensions.ToString(filter), filterValue);

            return CreateSeries(url);
        }
Example #9
0
        /// <summary>
        /// Get release dates for a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release/dates
        /// </summary>
        /// <param name="releaseId">The id for a release.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="limit">The maximum number of results to return. Integer between 1 and 10000, optional, default: 10000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="order">Sort results is ascending or descending release date order.</param>
        /// <param name="includeReleaseWithNoData">Determines whether release dates with no data available are returned. The defalut value 'false' excludes release dates that do not have data.</param>
        /// <returns>Release dates for a release of economic data</returns>
        /// <remarks>Note that release dates are published by data sources and do not necessarily represent when data will be available on the FRED or ALFRED websites.</remarks>
        public IEnumerable<ReleaseDate> GetReleaseDates(int releaseId, DateTime realtimeStart, DateTime realtimeEnd,
            int limit = 1000,
            int offset = 0,
            SortOrder order = SortOrder.Ascending,
            bool includeReleaseWithNoData = false)
        {
            var url = Format(Urls.ReleaseDates, _key, releaseId, realtimeStart.ToFredDateString(),
                realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(order),
                includeReleaseWithNoData.ToString().ToLowerInvariant());

            return (from releaseDate in GetRoot(url).Elements("release_date")
                select new ReleaseDate
                {
                    ReleaseId = int.Parse(releaseDate.Attribute("release_id").Value),
                    ReleaseName = "",
                    Date = releaseDate.Value.ToFredDate()
                }).ToList();
        }
Example #10
0
        /// <summary>
        /// Get a source of economic data. Corresponds to http://api.stlouisfed.org/fred/source
        /// </summary>
        /// <param name="sourceId">The id for a source.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>A source of economic data.</returns>
        public Source GetSource(int sourceId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.Source, _key, sourceId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            var element = GetRoot(url).Elements("source").First();
            return CreateSource(element);
        }
Example #11
0
        /// <summary>
        /// Get the observations or data values for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/observations
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="fileType">The type of file to send.</param>
        /// <param name="filename">The where to save the file.</param>
        /// <param name="observationStart">The start of the observation period.</param>
        /// <param name="observationEnd">The end of the observation period.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="vintageDates">A comma separated string of YYYY-MM-DD formatted dates in history (e.g. 2000-01-01,2005-02-24).
        ///  Vintage dates are used to download data as it existed on these specified dates in history. Vintage dates can be 
        ///  specified instead of a real-time period using realtime_start and realtime_end.
        ///
        /// Sometimes it may be useful to enter a vintage date that is not a date when the data values were revised. 
        /// For instance you may want to know the latest available revisions on 2001-09-11 (World Trade Center and 
        /// Pentagon attacks) or as of a Federal Open Market Committee (FOMC) meeting date. Entering a vintage date is 
        /// also useful to compare series on different releases with different release dates.</param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 100000, optional, default: 100000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="order">Sort results is ascending or descending observation_date order.</param>
        /// <param name="transformation">Type of data value transformation.</param>
        /// <param name="frequency">An optional parameter that indicates a lower frequency to aggregate values to. 
        /// The FRED frequency aggregation feature converts higher frequency data series into lower frequency data series 
        /// (e.g. converts a monthly data series into an annual data series). In FRED, the highest frequency data is daily, 
        /// and the lowest frequency data is annual. There are 3 aggregation methods available- average, sum, and end of period.</param>
        /// <param name="method">A key that indicates the aggregation method used for frequency aggregation.</param>
        /// <param name="outputType">Output type:
        /// 1. Observations by Real-Time Period
        /// 2. Observations by Vintage Date, All Observations
        /// 3. Observations by Vintage Date, New and Revised Observations Only
        /// 4.  Observations, Initial Release Only
        /// </param>
        /// <returns>Observations or data values for an economic data series.</returns>
        public async Task GetSeriesObservationsFileAsync(string seriesId, FileType fileType, string filename,
                                              DateTime observationStart,
                                              DateTime observationEnd,
                                              DateTime realtimeStart,
                                              DateTime realtimeEnd,
                                              IEnumerable<DateTime> vintageDates, int limit = 100000,
                                              int offset = 0, SortOrder order = SortOrder.Ascending,
                                              Transformation transformation = Transformation.None,
                                              Frequency frequency = Frequency.None,
                                              AggregationMethod method = AggregationMethod.Average,
                                              OutputType outputType = OutputType.RealTime)
        {
            var vintageString = vintageDates.Aggregate(string.Empty,
                                                       (current, vintageDate) =>
                                                       current + (vintageDate.ToFredDateString() + ","));
            if (vintageString.Length > 0)
            {
                vintageString = vintageString.Substring(0, vintageString.Length - 1);
            }

            var realtimeStartStr = (vintageString.Length == 0) ? realtimeStart.ToFredDateString() : string.Empty;
            var realtimeEndStr = (vintageString.Length == 0) ? realtimeEnd.ToFredDateString() : string.Empty;
            var url = String.Format(Urls.SeriesObservations, _key, seriesId, realtimeStartStr,
                                    realtimeEndStr, limit, offset, Extensions.ToString(order),
                                    observationStart.ToFredDateString(),
                                    observationEnd.ToFredDateString(),
                                    Extensions.ToString(transformation), Extensions.ToString(frequency),
                                    Extensions.ToString(method), Extensions.ToString(outputType),
                                    Extensions.ToString(fileType), vintageString);

            try
            {
                if (fileType != FileType.Xml && !Path.GetExtension(filename).Equals(".zip", StringComparison.OrdinalIgnoreCase))
                {
                    filename += ".zip";
                }
                await _downloader.DownloadFileAsync(url, filename);
            }
            catch (WebException exp)
            {
                var response = (HttpWebResponse)exp.Response;
                var buffer = new byte[response.ContentLength];
                response.GetResponseStream().Read(buffer, 0, buffer.Length);
                var xml = Encoding.UTF8.GetString(buffer);
                var start = xml.IndexOf("message=", StringComparison.OrdinalIgnoreCase);
                if (start < 0)
                {
                    throw;
                }
                start += 9;
                var end = xml.LastIndexOf("\"", StringComparison.OrdinalIgnoreCase);
                var message = xml.Substring(start, end - start);
                throw new FredExecption(message, exp);
            }
        }
Example #12
0
        /// <summary>
        /// Get the release for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/release
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The release for an economic data series.</returns>
        public Release GetSeriesRelease(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.SeriesRelease, _key, seriesId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            var element = GetRoot(url).Elements("release").First();
            return CreateRelease(element);
        }
Example #13
0
        /// <summary>
        /// Get an economic data series. Corresponds to http://api.stlouisfed.org/fred/series
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>An economic data series.</returns>
        public Series GetSeries(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = Format(Urls.Series, _key, seriesId, realtimeStart.ToFredDateString(),
                realtimeEnd.ToFredDateString());

            var element = GetRoot(url).Elements("series").First();
            return CreateSeries(element);
        }
Example #14
0
        /// <summary> 
        /// Get the categories for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/categories
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The categories for an economic data series.</returns>
        public IEnumerable<Category> GetSeriesCategories(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.SeriesCategories, _key, seriesId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return CreateCategories(url);
        }
Example #15
0
        /// <summary>
        /// Get the child categories for a specified parent category. Corresponds to http://api.stlouisfed.org/fred/category/children
        /// </summary>
        /// <param name="categoryId">The id for a category.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The child categories for a specified parent category</returns>
        public IEnumerable<Category> GetCategoryChildern(int categoryId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.CategoryChildern, _key, categoryId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return CreateCategories(url);
        }
Example #16
0
        /// <summary>
        /// Get the sources for a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release/sources
        /// </summary>
        /// <param name="releaseId">The id for a release.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The sources for a release of economic data.</returns>
        public IEnumerable<Source> GetReleaseSources(int releaseId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.ReleaseSources, _key, releaseId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return CreateSources(url);
        }
Example #17
0
 /// <summary>
 /// Get economic data series sorted in descending order of when transactions to update data values where processed on the FREDĀ® server.
 /// Corresponds  to http://api.stlouisfed.org/fred/series/updates
 /// </summary>
 /// <param name="realtimeStart">The start of the real-time period.</param>
 /// <param name="realtimeEnd">The end of the real-time period. </param>
 /// <param name="limit">The maximum number of results to return. An integer between 1 and 100, optional, default: 100</param>
 /// <param name="offset">non-negative integer, optional, default: 0</param>
 /// <param name="filter">Limit results by geographic type of economic data series; namely 'macro', 'regional', and 'all'.
 /// String, optional, default: 'all' meaning no filter.
 /// One of the values: 'macro', 'regional', 'all'
 /// 'macro' limits results to macroeconomic data series. In other words, series representing the entire United States. 
 /// 'regional' limits results to series for parts of the US; namely, series for US states, counties, and Metropolitan 
 /// Statistical Areas (MSA). 'all' does not filter results.</param>
 /// <returns>Economic data series.</returns>
 public async Task<IEnumerable<Series>> GetSeriesUpdatesAsync(DateTime realtimeStart, DateTime realtimeEnd,
                                             int limit = 100,
                                             int offset = 0,
                                             Series.UpdateFilterBy filter = Series.UpdateFilterBy.All)
 {
     var url = String.Format(Urls.SeriesUpdates, _key, realtimeStart.ToFredDateString(),
                             realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(filter));
     return await CreateSeriesAsync(url);
 }
Example #18
0
        /// <summary>
        /// Get the observations or data values for an economic data series. Corresponds to http://api.stlouisfed.org/fred/series/observations
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="observationStart">The start of the observation period.</param>
        /// <param name="observationEnd">The end of the observation period.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="vintageDates">A comma separated string of YYYY-MM-DD formatted dates in history (e.g. 2000-01-01,2005-02-24).
        ///  Vintage dates are used to download data as it existed on these specified dates in history. Vintage dates can be 
        ///  specified instead of a real-time period using realtime_start and realtime_end.
        ///
        /// Sometimes it may be useful to enter a vintage date that is not a date when the data values were revised. 
        /// For instance you may want to know the latest available revisions on 2001-09-11 (World Trade Center and 
        /// Pentagon attacks) or as of a Federal Open Market Committee (FOMC) meeting date. Entering a vintage date is 
        /// also useful to compare series on different releases with different release dates.</param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 100000, optional, default: 100000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="order">Sort results is ascending or descending observation_date order.</param>
        /// <param name="transformation">Type of data value transformation.</param>
        /// <param name="frequency">An optional parameter that indicates a lower frequency to aggregate values to. 
        /// The FRED frequency aggregation feature converts higher frequency data series into lower frequency data series 
        /// (e.g. converts a monthly data series into an annual data series). In FRED, the highest frequency data is daily, 
        /// and the lowest frequency data is annual. There are 3 aggregation methods available- average, sum, and end of period.</param>
        /// <param name="method">A key that indicates the aggregation method used for frequency aggregation.</param>
        /// <param name="outputType">Output type:
        /// 1. Observations by Real-Time Period
        /// 2. Observations by Vintage Date, All Observations
        /// 3. Observations by Vintage Date, New and Revised Observations Only
        /// 4.  Observations, Initial Release Only
        /// </param>
        /// <returns>Observations or data values for an economic data series.</returns>
        public async Task<IEnumerable<Observation>> GetSeriesObservationsAsync(string seriesId, DateTime observationStart,
                                                              DateTime observationEnd, DateTime realtimeStart,
                                                              DateTime realtimeEnd,
                                                              IEnumerable<DateTime> vintageDates, int limit = 100000,
                                                              int offset = 0, SortOrder order = SortOrder.Ascending,
                                                              Transformation transformation = Transformation.None,
                                                              Frequency frequency = Frequency.None,
                                                              AggregationMethod method = AggregationMethod.Average,
                                                              OutputType outputType = OutputType.RealTime)
        {
            var vintageString = vintageDates.Aggregate(string.Empty,
                                                       (current, vintageDate) =>
                                                       current + (vintageDate.ToFredDateString() + ","));
            if (vintageString.Length > 0)
            {
                vintageString = vintageString.Substring(0, vintageString.Length - 1);
            }

            var realtimeStartStr = (vintageString.Length == 0) ? realtimeStart.ToFredDateString() : string.Empty;
            var realtimeEndStr = (vintageString.Length == 0) ? realtimeEnd.ToFredDateString() : string.Empty;
            var url = String.Format(Urls.SeriesObservations, _key, seriesId, realtimeStartStr,
                                    realtimeEndStr, limit, offset, Extensions.ToString(order),
                                    observationStart.ToFredDateString(),
                                    observationEnd.ToFredDateString(),
                                    Extensions.ToString(transformation), Extensions.ToString(frequency),
                                    Extensions.ToString(method), Extensions.ToString(outputType), "xml", vintageString);

            var root = await GetRootAsync(url);
            return root.Elements("observation").Select(
                element =>
                {
                    var valElm = element.Attribute("value");
                    double? value = null;
                    if (valElm != null && !string.IsNullOrWhiteSpace(valElm.Value))
                    {
                        double dOut;
                        var success = double.TryParse(valElm.Value, out dOut);
                        if (success)
                        {
                            value = dOut;
                        }

                    }

                    return new Observation
                    {
                        RealtimeStart = element.Attribute("realtime_start").Value.ToFredDate(),
                        RealtimeEnd = element.Attribute("realtime_end").Value.ToFredDate(),
                        Date = element.Attribute("date").Value.ToFredDate(),
                        Value = value
                    };
                }
                ).ToList();
        }
Example #19
0
 /// <summary>
 /// Get the dates in history when a series' data values were revised or new data values were released. Vintage dates are 
 /// the release dates for a series excluding release dates when the data for a series did not change.
 /// Corresponds to http://api.stlouisfed.org/fred/series/vintagedates
 /// </summary>
 /// <param name="seriesId">The id for a series.</param>
 /// <param name="realtimeStart">The start of the real-time period.</param>
 /// <param name="realtimeEnd">The end of the real-time period.</param>
 /// <param name="limit">The maximum number of results to return. An integer between 1 and 10000, optional, default: 10000</param>
 /// <param name="offset">non-negative integer, optional, default: 0</param>
 /// <param name="order">Sort results is ascending or descending vintage_date order.</param>
 /// <returns>The dates in history when a series' data values were revised or new data values were released.</returns>
 public async Task<IEnumerable<DateTime>> GetSeriesVintageDatesAsync(string seriesId, DateTime realtimeStart, DateTime realtimeEnd,
                                                    int limit = 10000,
                                                    int offset = 0,
                                                    SortOrder order = SortOrder.Ascending)
 {
     var url = String.Format(Urls.SeriesVintageDates, _key, seriesId, realtimeStart.ToFredDateString(),
                             realtimeEnd.ToFredDateString(), limit, offset,
                             Extensions.ToString(order));
     var root = await GetRootAsync(url);
     return (from date in root.Elements("vintage_date")
             select date.Value.ToFredDate()).ToList();
 }
Example #20
0
        /// <summary>
        /// Get the releases for a source. Corresponds to http://api.stlouisfed.org/fred/source/releases
        /// </summary>
        /// <param name="sourceId">The id for a source.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, optional, default: 1000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <returns>The releases for a source.</returns>
        public async Task<IEnumerable<Release>> GetSourceReleasesAsync(int sourceId, DateTime realtimeStart, DateTime realtimeEnd,
                                                      int limit = 1000,
                                                      int offset = 0,
                                                      Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
                                                      SortOrder order = SortOrder.Ascending)
        {
            var url = String.Format(Urls.SourceReleases, _key, sourceId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order));

            return await CreateReleasesAsync(url);
        }
Example #21
0
        /// <summary>
        /// Get the sources for a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release/sources
        /// </summary>
        /// <param name="releaseId">The id for a release.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The sources for a release of economic data.</returns>
        public async Task<IEnumerable<Source>> GetReleaseSourcesAsync(int releaseId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.ReleaseSources, _key, releaseId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return await CreateSourcesAsync(url);
        }
Example #22
0
        /// <summary>
        /// Get an economic data series. Corresponds to http://api.stlouisfed.org/fred/series
        /// </summary>
        /// <param name="seriesId">The id for a series.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>An economic data series.</returns>
        public async Task<Series> GetSeriesAsync(string seriesId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = Format(Urls.Series, _key, seriesId, realtimeStart.ToFredDateString(),
                realtimeEnd.ToFredDateString());

            var root = await GetRoot(url);
            var element = root.Elements("series").First();
            return CreateSeries(element);
        }
Example #23
0
        /// <summary>
        /// Get a source of economic data. Corresponds to http://api.stlouisfed.org/fred/source
        /// </summary>
        /// <param name="sourceId">The id for a source.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>A source of economic data.</returns>
        public async Task<Source> GetSourceAsync(int sourceId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.Source, _key, sourceId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            var root = await GetRootAsync(url);
            var element = root.Elements("source").First();
            return CreateSource(element);
        }
Example #24
0
        /// <summary>
        /// Get the child categories for a specified parent category. Corresponds to http://api.stlouisfed.org/fred/category/children
        /// </summary>
        /// <param name="categoryId">The id for a category.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period.</param>
        /// <returns>The child categories for a specified parent category</returns>
        public async Task<IEnumerable<Category>> GetCategoryChildernAsync(int categoryId, DateTime realtimeStart, DateTime realtimeEnd)
        {
            var url = String.Format(Urls.CategoryChildern, _key, categoryId, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString());

            return await CreateCategoriesAsync(url);
        }
Example #25
0
        /// <summary>
        /// Get release dates for all releases of economic data. Corresponds to http://api.stlouisfed.org/fred/releases/dates
        /// </summary>
        /// <param name="realtimeStart">The start of the real-time period. </param>
        /// <param name="realtimeEnd">The end of the real-time period. </param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, optional, default: 1000</param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending release date order.</param>
        /// <param name="includeReleaseWithNoData">Determines whether release dates with no data available are returned. The default value 'false' excludes release dates that do not have data.</param>
        /// <returns>Release dates for all releases of economic data.</returns>
        public async Task<IEnumerable<ReleaseDate>> GetReleasesDatesAsync(DateTime realtimeStart, DateTime realtimeEnd, int limit = 1000,
                                                         int offset = 0,
                                                         Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
                                                         SortOrder order = SortOrder.Ascending,
                                                         bool includeReleaseWithNoData = false)
        {
            var url = String.Format(Urls.ReleasesDates, _key, realtimeStart.ToFredDateString(),
                                    realtimeEnd.ToFredDateString(), limit, offset, Extensions.ToString(orderBy),
                                    Extensions.ToString(order),
                                    includeReleaseWithNoData.ToString(CultureInfo.GetCultureInfo("en-US")).
                                        ToLowerInvariant());

            var root = await GetRootAsync(url);
            return (from releaseDate in root.Elements("release_date")
                    select new ReleaseDate
                    {
                        ReleaseId = int.Parse(releaseDate.Attribute("release_id").Value),
                        ReleaseName = releaseDate.Attribute("release_name").Value,
                        Date = releaseDate.Value.ToFredDate()
                    }).ToList();
        }
Example #26
0
        /// <summary>
        /// Get a release of economic data. Corresponds to http://api.stlouisfed.org/fred/release
        /// </summary>
        /// <param name="releaseId">The ID of the release to retrieve.</param>
        /// <param name="realtimeStart">The start of the real-time period.</param>
        /// <param name="realtimeEnd">The end of the real-time period. </param>
        /// <param name="limit">The maximum number of results to return. An integer between 1 and 1000, defaults to 1000. </param>
        /// <param name="offset">non-negative integer, optional, default: 0</param>
        /// <param name="orderBy">Order results by values of the specified attribute.</param>
        /// <param name="order">Sort results is ascending or descending order for attribute values specified by order_by.</param>
        /// <returns>The requested release.</returns>
        /// <remarks>Note that release dates are published by data sources and do not necessarily represent when data will be available on the FRED or ALFRED websites.</remarks>
        public Release GetRelease(int releaseId, DateTime realtimeStart, DateTime realtimeEnd, int limit = 1000,
            int offset = 0,
            Release.OrderBy orderBy = Release.OrderBy.ReleaseId,
            SortOrder order = SortOrder.Ascending)
        {
            var url = Format(Urls.Release, _key, releaseId, realtimeStart.ToFredDateString(),
                realtimeEnd.ToFredDateString());

            var element = GetRoot(url).Elements("release").First();
            return CreateRelease(element);
        }