client); } /** * Get the collection object that is used by this API endpoint. Every API * endpoint uses one type of collection object. * * @param int $count * @param \stdClass $_links * * @return OrderLineCollection */ protected function getResourceCollectionObject($count, $_links) { return new \Mollie\Api\Resources\OrderLineCollection($count, $_links); } /** * Update a specific OrderLine resource. * * Will throw an ApiException if the order line id is invalid or the resource cannot be found. * * @param string|null $orderId * @param string $orderlineId * * @param array $data * * @return \Mollie\Api\Resources\BaseResource|null * @throws \Mollie\Api\Exceptions\ApiException */ public function update($orderId, $orderlineId, array $data = []) { $this->parentId = $orderId; if (empty($orderlineId) || \strpos($orderlineId, self::RESOURCE_ID_PREFIX) !== 0) { throw new \Mollie\Api\Exceptions\ApiException("Invalid order line ID: '{$orderlineId}'. An order line ID should start with '" . self::RESOURCE_ID_PREFIX . "'."); } return parent::rest_update($orderlineId, $data); } /** * @param string $orderId * @param array $operations * @param array $parameters * @return Order|\Mollie\Api\Resources\BaseResource * @throws \Mollie\Api\Exceptions\ApiException */ public function updateMultiple(string $orderId, array $operations, array $parameters = []) { if (empty($orderId)) { throw new \Mollie\Api\Exceptions\ApiException("Invalid resource id."); } $this->parentId = $orderId; $parameters['operations'] = $operations; $result = $this->client->performHttpCall(self::REST_UPDATE, "{$this->getResourcePath()}", $this->parseRequestBody($parameters)); return \Mollie\Api\Resources\ResourceFactory::createFromApiResult($result, new \Mollie\Api\Resources\Order($this->client)); } /** * Cancel lines for the provided order. * The data array must contain a lines array. * You can pass an empty lines array if you want to cancel all eligible lines. * Returns null if successful. * * @param Order $order * @param array $data * * @return null * @throws ApiException */ public function cancelFor(\Mollie\Api\Resources\Order $order, array $data) { return $this->cancelForId($order->id, $data); } /** * Cancel lines for the provided order id. * The data array must contain a lines array. * You can pass an empty lines array if you want to cancel all eligible lines. * Returns null if successful. * * @param string $orderId * @param array $data * * @return null * @throws ApiException */ public function cancelForId($orderId, array $data) { if (!isset($data['lines']) || !\is_array($data['lines'])) { throw new \Mollie\Api\Exceptions\ApiException("A lines array is required."); } $this->parentId = $orderId; $this->client->performHttpCall(self::REST_DELETE, "{$this->getResourcePath()}", $this->parseRequestBody($data)); return null; } }