Difference between revisions of "NATS4 REST API Bulk Import Adtools"

From TMM Wiki
Jump to navigationJump to search
m (updated paths and url protocol)
 
(2 intermediate revisions by 2 users not shown)
Line 2: Line 2:
 
| show_api_admin_section = true
 
| show_api_admin_section = true
 
}}
 
}}
== '''POST /adtools/importdump''' ==
+
== '''POST /adtool/import''' ==
 
'''Description'''  
 
'''Description'''  
 
*[[NATS4]] now supports an [[NATS4_API|API]] action that allows you to import bulk adtools. This lets you insert your custom adtools into the [[NATS]] tools through an automated process by running a cron that calls the bulk import API for your adtools import. This API sends all the standard information for the bulk importer (the dump, what the separator and fields are, etc.) so NATS can process the imported adtools as normal for the bulk importer.  
 
*[[NATS4]] now supports an [[NATS4_API|API]] action that allows you to import bulk adtools. This lets you insert your custom adtools into the [[NATS]] tools through an automated process by running a cron that calls the bulk import API for your adtools import. This API sends all the standard information for the bulk importer (the dump, what the separator and fields are, etc.) so NATS can process the imported adtools as normal for the bulk importer.  
Line 8: Line 8:
  
 
'''Resource URL'''
 
'''Resource URL'''
*<nowiki>http://domain/api/adtools/importdump</nowiki>
+
*<nowiki>https://domain/api/adtool/import</nowiki>
 
*Replace domain with the nats domain
 
*Replace domain with the nats domain
  
Line 40: Line 40:
 
**'''''required'''
 
**'''''required'''
  
*'''line_ending''' -- the string that separates the lines in the dump ('none' or '' mean that a line ending itself is the separator)
+
*'''line_ending''' -- the string that separates the lines in the dump ('none' or <nowiki>''</nowiki> mean that a line ending itself is the separator)
 
**'''''type: string'''''
 
**'''''type: string'''''
 
**'''''required'''
 
**'''''required'''
Line 63: Line 63:
 
**'''''type: integer'''''
 
**'''''type: integer'''''
 
**'''''required'''
 
**'''''required'''
 
  
 
== '''Example Request''' ==
 
== '''Example Request''' ==
Line 69: Line 68:
 
'''POST'''
 
'''POST'''
  
<nowiki>http://domain/api/adtools/importdump</nowiki>
+
<nowiki>https://domain/api/adtool/import</nowiki>
  
 
*Response:  
 
*Response:  
Line 83: Line 82:
 
$curl = curl_init();
 
$curl = curl_init();
  
$dump = 'http://www.google.com/hatz|hats|morehats'."\n";
+
$dump = 'https://www.google.com/hatz|hats|morehats'."\n";
$dump .= 'http://www.google.com/bags2|bags2|some bags';
+
$dump .= 'https://www.google.com/bags2|bags2|some bags';
 
$fields = Array('url','name','description');
 
$fields = Array('url','name','description');
  
Line 100: Line 99:
 
);
 
);
  
$url = 'http://domain/api/adtools/importdump';
+
$url = 'https://domain/api/adtool/import';
  
 
$headers = array(
 
$headers = array(
     'api_key: 44b5498dbcb481a0d00b404c0169af62',
+
     'api-key: 44b5498dbcb481a0d00b404c0169af62',
     'api_username: tmm1phrvezsbu'
+
     'api-username: tmm1phrvezsbu'
 
);
 
);
  

Latest revision as of 00:18, 25 May 2018

NATS 4
Members Admin
The Members Admin
View Member Details
Add Member
MySQL Auth
Mod Authn DB
Multisite Access
Member Logging
Member Password Retrieval
OpenID Connect
Mod Auth OpenIDC
ID Numbers
SOAP API
API
API Best Practices
WSDL Cache
Add Affiliate
Add Member Note
Admin Get Adtools
Adtool Categories
Adtool Types
Affiliate Get Campaigns
Bulk Import Adtools
Caching
Decode Natscode
Expire Manual Member
Get Affiliate Campaigns
Get Affiliate Hit Data
Get Affiliate Loginids
Get Affiliate Nats Codes
Get Affiliate Payout
Get Affiliate Program Campaign List
Get_Affiliate_Program_Campaign_List
Get Member Details
Get Member Instant Upgrade String
Get Member Package Upgrade String
Get Member Token Rebuy String
Get Member Upsell String
Get Payment Data
Get Payvia Rule
Get Profit Loss Report
Ping
Record Member Login
Search Affiliate Info
Search Member Info
Send Email API Function
Set Affiliate Admin Settings
Set Affiliate Customs
Set Affiliate Defaults
Set Affiliate Information
Set Affiliate Settings
Set Member Details
Set Payment Status
Set Payvia Rule
REST API
API Overview
API Best Practices
REST API PATH UPDATES
Adtools
GET /adtools/admin
GET /adtools/categories
GET /adtools/types
POST /adtools/importdump
Affiliate
GET /affiliate/campaigns
GET /affiliate/hitdata
GET /affiliate/payout
GET /affiliate/searchinfo
POST /affiliate/addaffiliate
POST /affiliate/invoice
PATCH /affiliate/setadminsettings
PATCH /affiliate/setcustoms
PATCH /affiliate/setdefaults
PATCH /affiliate/setinformation
PATCH /affiliate/setpayviainfo
PATCH /affiliate/setsettings
PATCH /affiliate/status
Member
GET /member/authstring
GET /member/details
GET /member/searchinfo
GET /suggestedcanceloffers
PATCH /member/setdetails
PATCH /member/setexpiration
POST /member/addnote
POST /member/recordlogin
PUT /member/expiremanual
PATCH /member/forget
Option
GET /option/options
GET /option/rule
PATCH /option/rule
PATCH/option/text
POST /option/rule
Payments
GET /payments/getpayments
GET /payviarule
PATCH /payments/setstatus
PATCH /payviarule
Report
GET /profitlossreport
Get /transactionpayouts
GET /report/transaction
Service
GET /service/decodenatscode
GET /service/ping
POST /service/sendemail

POST /adtool/import

Description

  • NATS4 now supports an API action that allows you to import bulk adtools. This lets you insert your custom adtools into the NATS tools through an automated process by running a cron that calls the bulk import API for your adtools import. This API sends all the standard information for the bulk importer (the dump, what the separator and fields are, etc.) so NATS can process the imported adtools as normal for the bulk importer.


Resource URL

  • https://domain/api/adtool/import
  • Replace domain with the nats domain

Request Method

  • POST

Response Format

  • JSON

Authentication

  • HTTP headers

Parameters

Paremeters must be sent with the HTTP request body.

  • adtool_type -- the numeric id of the type (for FHGs, it's 2)
    • type: integer
    • required
  • dump -- the actual adtool dump
    • type: string
    • required
  • fields -- an array of the fields that are in the dump
    • type: array
    • required
  • separator -- the string that separates each of the fields in the dump
    • type: string
    • required
  • line_ending -- the string that separates the lines in the dump ('none' or '' mean that a line ending itself is the separator)
    • type: string
    • required
  • type -- the subtype of the adtool (the type field on the adtool)
    • type: integer
    • required
  • enabled_on -- the siteid it should be enabled on or a comma separated list of siteids it should be enabled on. -1 means no sites. 0 means all sites.
    • type: integer
    • required
  • publish_date -- the date you want it published. Can be anything you would put in to the field in the adtools admin the recommended format is YYYY-mm-dd (eg. 2010-01-31)
    • type: string
    • required
  • default_group -- the adtool group that you want this to be added to
    • type: integer
    • required
  • ignore_dupes -- if set, instead of returning an error if a row has a duplicate to a unique field for an existing adtool, we'll instead just ignore the row.
    • type: integer
    • required

Example Request

POST

https://domain/api/adtool/import

  • Response:
"TRUE adtools sent for import"

Example Code

PHP

<?php
$curl = curl_init();

$dump = 'https://www.google.com/hatz|hats|morehats'."\n";
$dump .= 'https://www.google.com/bags2|bags2|some bags';
$fields = Array('url','name','description');

$data = array(
    'adtool_type_id' => 2,
    'dump' => $dump,
    'fields' => $fields,
    'separator' => '|',
    'line_ending' => '',
    'type' => 1,
    'enabled_on' => 1,
    'publish_date' => '2010-01-28',
    'default_group' => 1000,
    'ignore_dupes' => 1
);

$url = 'https://domain/api/adtool/import';

$headers = array(
    'api-key: 44b5498dbcb481a0d00b404c0169af62',
    'api-username: tmm1phrvezsbu'
);

curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($data));

$resp = curl_exec($curl);
//dumps an associative array representation of the json
var_dump(json_decode($resp, true));
// Close request to clear up some resources
curl_close($curl);
?>