package rest import ( "fmt" "net/http" "gopkg.in/ns1/ns1-go.v2/rest/model/data" ) // DataFeedsService handles 'data/feeds' endpoint. type DataFeedsService service // List returns all data feeds connected to a given data source. // // NS1 API docs: https://ns1.com/api/#feeds-get func (s *DataFeedsService) List(sourceID string) ([]*data.Feed, *http.Response, error) { path := fmt.Sprintf("data/feeds/%s", sourceID) req, err := s.client.NewRequest("GET", path, nil) if err != nil { return nil, nil, err } dfl := []*data.Feed{} resp, err := s.client.Do(req, &dfl) if err != nil { return nil, resp, err } return dfl, resp, nil } // Get takes a data source ID and a data feed ID and returns the details of a single data feed // // NS1 API docs: https://ns1.com/api/#feeds-feed-get func (s *DataFeedsService) Get(sourceID string, feedID string) (*data.Feed, *http.Response, error) { path := fmt.Sprintf("data/feeds/%s/%s", sourceID, feedID) req, err := s.client.NewRequest("GET", path, nil) if err != nil { return nil, nil, err } var df data.Feed resp, err := s.client.Do(req, &df) if err != nil { return nil, resp, err } return &df, resp, nil } // Create takes a *DataFeed and connects a new data feed to an existing data source. // // NS1 API docs: https://ns1.com/api/#feeds-put func (s *DataFeedsService) Create(sourceID string, df *data.Feed) (*http.Response, error) { path := fmt.Sprintf("data/feeds/%s", sourceID) req, err := s.client.NewRequest("PUT", path, &df) if err != nil { return nil, err } // Update datafeeds' fields with data from api(ensure consistent) resp, err := s.client.Do(req, &df) if err != nil { return resp, err } return resp, nil } // Update takes a *Feed and modifies and existing data feed. // Note: // - The 'data' portion of a feed does not actually // get updated during a POST. In order to update a feeds' // 'data' attribute, one must use the Publish method. // - Both the 'destinations' and 'networks' attributes are // not updated during a POST. // // NS1 API docs: https://ns1.com/api/#feeds-post func (s *DataFeedsService) Update(sourceID string, df *data.Feed) (*http.Response, error) { path := fmt.Sprintf("data/feeds/%s/%s", sourceID, df.ID) req, err := s.client.NewRequest("POST", path, &df) if err != nil { return nil, err } // Update df instance fields with data from api(ensure consistent) resp, err := s.client.Do(req, &df) if err != nil { return resp, err } return resp, nil } // Delete takes a data source ID and a data feed ID and disconnects the feed from the data source and all attached destination metadata tables. // // NS1 API docs: https://ns1.com/api/#feeds-delete func (s *DataFeedsService) Delete(sourceID string, feedID string) (*http.Response, error) { path := fmt.Sprintf("data/feeds/%s/%s", sourceID, feedID) req, err := s.client.NewRequest("DELETE", path, nil) if err != nil { return nil, err } resp, err := s.client.Do(req, nil) if err != nil { return resp, err } return resp, nil }