Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Info

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.

Zur Aktivierung des Features ist eine Beauftragung seitens des Kunden notwendig.

Funktionalitäten des/der [Moduls/Features/Funktion/Schnittstelle]

  • Die Location API ist der API-Endpunkt zum Auslesen der Ortsstruktur

  • Es handelt sich bei der Location-API um eine Public API

  • der Kleinanzeigen API

    • Erstellen von Kleinanzeigen

    • Editieren von Kleinanzeigen

    • Abrufen von Kleinanzeigen

    Inhaltsverzeichnis

    Expand
    titleInhaltsverzeichnis anzeigen
    Table of Contents
    maxLevel4

    Detaillierte Beschreibung

    Basis URL

    Code Block
    languagetext
    https://yourdomain.com/api/v2/cad/adverts

    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

    Allgemeine Beschreibung

    Die API-Dokumentation ist als interaktive Dokumentation für berechtigte Admins direkt im jeweiligen PORTAL unter /admin/api/v2/doc?module=classifiedad erreichbar.

    Das swagger-File kann auch hier heruntergeladen werden (Stand: ):

    View file
    nameapi_module_classifiedad_swagger.json

    Image Added

     

     

    Verfügbare Endpunkte

    Classified Ad

    • Status
      colourBlue
      title

    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

    Code Block
    languagejson
    { "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" ] } ] }Create Classified Ad
    • GET
      /adverts: Gibt eine paginierte Liste an Kleinanzeigen nach den gesetzten Filtern aus.

    • Status
      colourBlue
      titleGET
      /adverts/{advert_id}: Gibt die durch die ID spezifizierte Kleinanzeige zurück.

    • Status
      colourGreen
      title

    postUpdate Classified Ad by
    • POST
      /adverts: Erstellt eine neue Kleinanzeige.

    • Status
      colourYellow
      title

    put
    • PUT
      /adverts/{advert_id

    • advert_id

    Delete Classified Ad by
    • }: Aktualisiert die im Request Body angegebenen Informationen der durch die ID spezifizierten Kleinanzeige.

    • Status
      colourRed
      title

    delete
    • DELETE
      /adverts/{advert_id

    • advert_id

    Request Body

    Code Block
    languagejson
    {
      "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

    Code Block
    languagetext
    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 Portalreihe
    • }: Löscht die durch die ID spezifizierte Kleinanzeige unwiderruflich.

    Ein Kleinanzeigenmarkt kann im Modus mit Print oder “online-only” aufgesetzt werden, daher gibt es zwei descriptions: description_online sowie description_print.

    Verfügbare Endpunkte für Classified Ad Categories

    • Status
      colourBlue
      titleGET
      /cad/categories: Gibt eine Liste der im PORTAL hinterlegten Kategorien für Kleinanzeigen zurück.

    • Status
      colourBlue
      titleGET
      /cad/categories/{category_id}: Gibt die durch die ID spezifizierten Kategorie für Kleinanzeigen zurück.

    Im Gegensatz zu anderen Modulen im PEIQ PORTAL 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.

    Status
    colourBlue
    titleget

    • Get All Classified Ad Categories

    • Get Classified Ad Category by category_id

      • category_id

    Response

    Code Block
    languagejson
    {
      "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

    Code Block
    languagetext
    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

    Setup & Konfiguration

  • Zur Aktivierung des Features ist eine Beauftragung seitens des Kunden notwendig.

  • Die API 2.0 Dokumentation ist in jedem Portal vorhanden. Zugang erhält man mit der Berechtigung “Zugang zur API Dokumentation”

    Trouble Shooting bei HTTP Status Codes

    400 - Bad Request

    Insert excerpt
    API 2.0 Dokumentation PORTAL
    API 2.0 Dokumentation PORTAL
    name400
    nopaneltrue

    404 - Not Found

    Insert excerpt
    API 2.0 Dokumentation PORTAL
    API 2.0 Dokumentation PORTAL
    name404
    nopaneltrue

    Verwandte Themen

    Filter by label (Content by label)
    showLabelsfalse
    maxCheckboxfalse
    showSpacefalse
    reversefalse
    cqllabel in ( = "api" , "api-dokumentation" , "kleinanzeigen" ) and space = "PPSD"PUPKB"

    Include Page
    Disclaimer der PEIQ PORTAL - Produktdokumentation
    Disclaimer der PEIQ PORTAL - Produktdokumentation

    Nur für PEIQ-Mitarbeiter:innen
    https://peiq.atlassian.net/wiki/x/pALQAg