getDatabaseConnection()->getQueryBuilder(); $qb->select('id') ->from('mimetypes') ->where( $qb->expr()->eq('mimetype', $qb->createNamedParameter('httpd/unix-directory')) ); $result = $qb->execute(); $row = $result->fetch(); $result->closeCursor(); if ($row = $result->fetchRow()) { $mimetype = (int) $row['id']; } else { $mimetype = -1; } while (!empty($parents)) { $qb = \OC::$server->getDatabaseConnection()->getQueryBuilder(); $parents = array_map(function ($parent) use ($qb) { return $qb->createNamedParameter($parent); }, $parents); $qb->select('`fileid', 'name', '`mimetype') ->from('filecache') ->where( $qb->expr()->in('parent', $parents) ); $result = $qb->execute(); $parents = []; while ($file = $result->fetch()) { $children[] = ['source' => $file['fileid'], 'file_path' => $file['name']]; // If a child folder is found look inside it if ((int) $file['mimetype'] === $mimetype) { $parents[] = $file['fileid']; } } $result->closeCursor(); } return $children; } }