PORTAL und PPS Knowledge Base

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 12 Next »

Mithilfe der PEIQ Cloud-Connect APIs (engl. Application Programming Interfaces, Programmierschnittstellen) können Verlage Teile ihrer bestehenden Systeme und Produkte mit dem PEIQ PORTAL verbinden. Alle Cloud-Connect APIs sind nach der REST-Architektur aufgebaut. Der Zugriff wird dabei über die Standard HTTP-Methoden GET, POST, PUT und DELETE gesteuert. Die Zugriffskontrolle erfolgt hierbei über eine Implementierung nach OAuth V2 Standard.

Die API des Kleinanzeigen-Moduls kann zum Erstellen, Editieren und Abrufen von Kleinanzeigen verwendet werden.

Funktionalitäten der Kleinanzeigen API

  • Erstellen von Kleinanzeigen

  • Editieren von Kleinanzeigen

  • Abrufen von Kleinanzeigen

Inhaltsverzeichnis

 Inhaltsverzeichnis anzeigen

Grundlegendes zur Kleinanzeigen API

Die Kleinanzeigenmarkt API ist die API zum Erstellen, Editieren und Abrufen von Kleinanzeigen. Ein Kleinanzeigenmarkt kann im Modus mit Print oder “online-only” aufgesetzt werden, daher gibt es zwei descriptions getrennt für print und online. Zudem hat der Markt ein integriertes Modul zur Abbildung verschiedener Preismodelle (PaidServicesBundle) im Kleinanzeigenmarkt, die über den API Endpunkt definiert werden können, bzw. beim Anlegen von Kleinanzeigen auch definiert werden müssen.

Verfügbare Endpunkte für Classified Ads

GET

  • Get All Classified Ad by Filters

    • approval_status (Available values : none, verified, pending, approved, resubmitted)

    • payment_status (Available values : free, notpaid, paid)

    • date_filter_type (Available values : created, updated ; Default value : created)

    • date_start

    • date_end

  • Get Classified Ad by advert_id

    • advert_id

Response

{
  "total_results": 234,
  "total_pages": 12,
  "page": 1,
  "page_size": 20,
  "data": [
    {
      "id": 1,
      "title": "Advert1",
      "approval_status": "pending",
      "payment_status": "free",
      "service_fee": 12.99,
      "description_online": "Lorem ipsum dolor sit amet, consectetur adipisicing elit. In, consectetur, animi, culpa beatae optio quod ea rerum impedit magni modi vel totam consequuntur porro voluptate unde.",
      "description_print": "coming soon...",
      "pricemode": "pm_free",
      "price": 85.99,
      "contact": {
        "phone": "+49 821 312312",
        "email": "max@mustermann.de"
      },
      "hide_phone": true,
      "url": "https://www.example.com/cad/augsburg/c-sachbuch/advert1_c4",
      "billing_information": {
        "firstname": "Max",
        "lastname": "Mustermann",
        "street": "Example Street",
        "street_number": "32",
        "city": "Augsburg",
        "zipcode": "86159",
        "phone": "+49 821 3125123",
        "email": "max@mustermann.de"
      },
      "created": "2019-03-07T00:00:00+00:00",
      "updated": "2019-03-09T02:00:00+00:00",
      "expires": "2019-03-27T00:00:00+00:00",
      "category_id": 8,
      "zipcode": "86150",
      "city": "Augsburg",
      "street": "Maximilianstraße",
      "street_number": "23",
      "cs_print_consecutive": 1,
      "cs_print_disabled": false,
      "meta": [
        {
          "k": "test-key",
          "v": "test-value"
        }
      ],
      "location_id": 1,
      "product_ids": [
        1,
        2,
        3
      ],
      "images": [
        {
          "url": "www.example.com/path/to/image/1"
        }
      ],
      "print_options": [
        "option1",
        "option2"
      ]
    }
  ]
}

POST

  • Create Classified Ad

PUT

  • Update Classified Ad by advert_id

    • advert_id

DELETE

  • Delete Classified Ad by advert_id

    • advert_id

Request Body

{
  "title": "Advert1",
  "approval_status": "pending",
  "description_online": "Lorem ipsum dolor sit amet, consectetur adipisicing elit. In, consectetur, animi, culpa beatae optio quod ea rerum impedit magni modi vel totam consequuntur porro voluptate unde.",
  "description_print": "coming soon...",
  "pricemode": "pm_free",
  "price": 85.99,
  "contact": {
    "phone": "+49 821 312312",
    "email": "max@mustermann.de"
  },
  "hide_phone": true,
  "billing_information": {
    "firstname": "Max",
    "lastname": "Mustermann",
    "street": "Example Street",
    "street_number": "32",
    "city": "Augsburg",
    "zipcode": "86159",
    "phone": "+49 821 3125123",
    "email": "max@mustermann.de"
  },
  "category_id": 8,
  "zipcode": "86150",
  "city": "Augsburg",
  "street": "Maximilianstraße",
  "street_number": "23",
  "meta_form_data": [
    {
      "k": "test-key",
      "v": "test-value"
    }
  ],
  "location_id": 1,
  "product_ids": [
    1,
    2,
    3
  ],
  "images": [
    {
      "url": "www.example.com/path/to/image/1"
    }
  ],
  "print_options": [
    "option1",
    "option2"
  ]
}

HTTP Status Codes

200 - Success                    Alles hat wie erwartet funktioniert
201 - Classified Ad Successfully created / deleted
204 - Classified Ad Successfully updated
400 - Bad Reqest                 Der Request war nicht akzeptabel. Das liegt oft an einem fehlenden Parameter. Checken Sie hierfür den gesendeten Request Body.
404 - Classified Ad Not Found    Die Anzeige mit der angegebenen ID scheint nicht zu existieren

Verfügbare Endpunkte für Classified Ad Categories

Im Gegensatz zu anderen Modulen aus der PEIQ PORTAL-Reihe hat der Kleinanzeigenmarkt keine flach nebeneinander liegenden Kategorien, sondern ein Baummodell. Ob eine Kategorie einer anderen untergeordnet ist, lässt sich über die Markierung “is_leaf” steuern.

GET

  • Get All Classified Ad Categories

  • Get Classified Ad Category by category_id

    • category_id

Response

{
  "id": "1",
  "name": "Leaf-Category-Test",
  "name_norm": "leaf-category-test",
  "form_fields": [
    {
      "name": "root-testfield",
      "type": "Symfony\\Component\\Form\\Extension\\Core\\Type\\TextType",
      "options": {
        "required": true,
        "choices": "{}"
      }
    }
  ],
  "is_leaf": true
}

HTTP Status Codes

200 - Success               Alles hat wie erwartet funktioniert
400 - Bad Reqest            Der Request war nicht akzeptabel. Das liegt oft an einem fehlenden Parameter. Checken Sie hierfür den gesendeten Request Body.
404 - Category Not Found    Die Kategorie mit der angegebenen ID scheint nicht zu existieren

Trouble Shooting bei HTTP Status Codes

400 - Bad Request

Der Request war nicht akzeptabel.

Das liegt oft an einem fehlenden Parameter. Hier ist der gesendete Request Body zu prüfen.

Eine weitere Ursache bei GET -Requests ist das harte Limit von maximal 10.000 Results. Wir empfehlen daher, die Abfragen noch weiter einzugrenzen, z. B. monats- oder ortsweise, um so die Grenze zu umgehen.

404 - Not Found

Der gesuchte Inhalt konnte nicht gefunden werden bzw. die gesetzten Filter finden keine Ergebnisse.

Verwandte Themen

Disclaimer

Für die vorliegende Systemübersicht/Publikation behalten wir uns alle Rechte vor. Nachdruck, Vervielfältigung und Verbreitung (auch auszugsweise) ist nur mit schriftlicher Genehmigung der PEIQ Publishing GmbH & Co. KG erlaubt. Wir behalten uns vor, die Systemübersicht/Publikation jederzeit ohne vorherige Ankündigung zu ändern und/oder zu erweitern. Die vorliegenden Angaben dienen lediglich Informationszwecken. Die PEIQ Publishing GmbH & Co. KG übernimmt keinerlei Haftung und/oder Garantie für Fehler und/oder unvollständige Angaben in der Systemübersicht/Publikation, mit Ausnahme von vorsätzlich falschen oder arglistig verschwiegenen Angaben. Da unsere Software laufend weiter entwickelt wird, handelt es sich bei den vorliegenden nur um allgemeine Angaben. Es handelt sich weder um eine Zusicherung von Mindestvertragsinhalten, noch um Beschaffenheitsgarantien im Sinne des § 443 BGB.

  • No labels