Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion IONOS
Submodule IONOS updated 1 files
+0 −1 configure.sh
8 changes: 0 additions & 8 deletions apps/settings/lib/Controller/AppSettingsController.php
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,6 @@
use OCP\Files\SimpleFS\ISimpleFile;
use OCP\Files\SimpleFS\ISimpleFolder;
use OCP\Http\Client\IClientService;
use OCP\IAppConfig;
use OCP\IConfig;
use OCP\IGroup;
use OCP\IL10N;
Expand Down Expand Up @@ -75,7 +74,6 @@ public function __construct(
private IInitialState $initialState,
private AppDiscoverFetcher $discoverFetcher,
private IClientService $clientService,
private IAppConfig $appConfig,
) {
parent::__construct($appName, $request);
$this->appData = $appDataFactory->get('appstore');
Expand All @@ -92,12 +90,6 @@ public function viewApps(): TemplateResponse {

$this->initialState->provideInitialState('appstoreEnabled', $this->config->getSystemValueBool('appstoreenabled', true));
$this->initialState->provideInitialState('appstoreBundles', $this->getBundles());

// Conditionally set developer docs link based on configuration
$displayDocumentationLink = $this->appConfig->getValueBool('settings', 'display_documentation_link', true);
$developerDocsUrl = $displayDocumentationLink ? $this->urlGenerator->linkToDocs('developer-manual') : '';
$this->initialState->provideInitialState('appstoreDeveloperDocs', $developerDocsUrl);

$this->initialState->provideInitialState('appstoreUpdateCount', count($this->getAppsWithUpdates()));

if ($this->appManager->isInstalled('app_api')) {
Expand Down
5 changes: 0 additions & 5 deletions apps/settings/src/views/AppStoreNavigation.vue
Original file line number Diff line number Diff line change
Expand Up @@ -91,10 +91,6 @@
</NcAppNavigationItem>
</template>

<NcAppNavigationItem v-if="developerDocsUrl"
id="app-developer-docs"
:name="t('settings', 'Developer documentation ↗')"
:href="developerDocsUrl" />
</template>
</NcAppNavigation>
</template>
Expand All @@ -116,7 +112,6 @@ import NcLoadingIcon from '@nextcloud/vue/dist/Components/NcLoadingIcon.js'
import APPSTORE_CATEGORY_ICONS from '../constants/AppstoreCategoryIcons.ts'

const appstoreEnabled = loadState<boolean>('settings', 'appstoreEnabled', true)
const developerDocsUrl = loadState<string>('settings', 'appstoreDeveloperDocs', '')

const store = useAppsStore()
const categories = computed(() => store.categories)
Expand Down
127 changes: 2 additions & 125 deletions apps/settings/tests/Controller/AppSettingsControllerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
use OCP\AppFramework\Services\IInitialState;
use OCP\Files\AppData\IAppDataFactory;
use OCP\Http\Client\IClientService;
use OCP\IAppConfig;
use OCP\IConfig;
use OCP\IL10N;
use OCP\INavigationManager;
Expand All @@ -46,8 +45,6 @@ class AppSettingsControllerTest extends TestCase {
private $l10n;
/** @var IConfig|MockObject */
private $config;
/** @var IAppConfig|MockObject */
private $appConfig;
/** @var INavigationManager|MockObject */
private $navigationManager;
private AppManager&MockObject $appManager;
Expand Down Expand Up @@ -84,7 +81,6 @@ protected function setUp(): void {
->method('t')
->willReturnArgument(0);
$this->config = $this->createMock(IConfig::class);
$this->appConfig = $this->createMock(IAppConfig::class);
$this->navigationManager = $this->createMock(INavigationManager::class);
$this->appManager = $this->createMock(AppManager::class);
$this->categoryFetcher = $this->createMock(CategoryFetcher::class);
Expand Down Expand Up @@ -116,7 +112,6 @@ protected function setUp(): void {
$this->initialState,
$this->discoverFetcher,
$this->clientService,
$this->appConfig,
);
}

Expand Down Expand Up @@ -185,31 +180,14 @@ public function testViewApps(): void {
->method('getSystemValueBool')
->with('appstoreenabled', true)
->willReturn(true);
$this->appConfig
->expects($this->once())
->method('getValueBool')
->with('settings', 'display_documentation_link', true)
->willReturn(true);
$this->navigationManager
->expects($this->once())
->method('setActiveEntry')
->with('core_apps');

// Test that developer docs link is generated correctly
$this->urlGenerator
->expects($this->once())
->method('linkToDocs')
->with('developer-manual')
->willReturn('https://docs.nextcloud.com/server/latest/developer_manual/');

$this->initialState
->expects($this->exactly(4))
->method('provideInitialState')
->willReturnCallback(function ($key, $value) {
if ($key === 'appstoreDeveloperDocs') {
$this->assertEquals('https://docs.nextcloud.com/server/latest/developer_manual/', $value);
}
});
->method('provideInitialState');

$policy = new ContentSecurityPolicy();
$policy->addAllowedImageDomain('https://usercontent.apps.nextcloud.com');
Expand All @@ -235,31 +213,14 @@ public function testViewAppsAppstoreNotEnabled(): void {
->method('getSystemValueBool')
->with('appstoreenabled', true)
->willReturn(false);
$this->appConfig
->expects($this->once())
->method('getValueBool')
->with('settings', 'display_documentation_link', true)
->willReturn(true);
$this->navigationManager
->expects($this->once())
->method('setActiveEntry')
->with('core_apps');

// Test that developer docs link is still generated even when appstore is disabled
$this->urlGenerator
->expects($this->once())
->method('linkToDocs')
->with('developer-manual')
->willReturn('https://docs.nextcloud.com/server/latest/developer_manual/');

$this->initialState
->expects($this->exactly(4))
->method('provideInitialState')
->willReturnCallback(function ($key, $value) {
if ($key === 'appstoreDeveloperDocs') {
$this->assertEquals('https://docs.nextcloud.com/server/latest/developer_manual/', $value);
}
});
->method('provideInitialState');

$policy = new ContentSecurityPolicy();
$policy->addAllowedImageDomain('https://usercontent.apps.nextcloud.com');
Expand All @@ -274,88 +235,4 @@ public function testViewAppsAppstoreNotEnabled(): void {

$this->assertEquals($expected, $this->appSettingsController->viewApps());
}

public function testDeveloperDocumentationLinkHiddenWhenConfigured(): void {
$this->installer->expects($this->any())
->method('isUpdateAvailable')
->willReturn(false);
$this->bundleFetcher->expects($this->once())->method('getBundles')->willReturn([]);
$this->config
->expects($this->once())
->method('getSystemValueBool')
->with('appstoreenabled', true)
->willReturn(true);
$this->appConfig
->expects($this->once())
->method('getValueBool')
->with('settings', 'display_documentation_link', true)
->willReturn(false);
$this->navigationManager
->expects($this->once())
->method('setActiveEntry')
->with('core_apps');

// When display_documentation_link is false, linkToDocs should not be called
$this->urlGenerator
->expects($this->never())
->method('linkToDocs');

$providedStates = [];
$this->initialState
->expects($this->exactly(4))
->method('provideInitialState')
->willReturnCallback(function ($key, $value) use (&$providedStates) {
$providedStates[$key] = $value;
});

$this->appSettingsController->viewApps();

// Assert that the developer docs state was provided with an empty string
$this->assertArrayHasKey('appstoreDeveloperDocs', $providedStates);
$this->assertEquals('', $providedStates['appstoreDeveloperDocs']);
}

public function testDeveloperDocumentationLinkShownByDefault(): void {
$this->installer->expects($this->any())
->method('isUpdateAvailable')
->willReturn(false);
$this->bundleFetcher->expects($this->once())->method('getBundles')->willReturn([]);
$this->config
->expects($this->once())
->method('getSystemValueBool')
->with('appstoreenabled', true)
->willReturn(true);
$this->appConfig
->expects($this->once())
->method('getValueBool')
->with('settings', 'display_documentation_link', true)
->willReturn(true);
$this->navigationManager
->expects($this->once())
->method('setActiveEntry')
->with('core_apps');

$developerDocsUrl = 'https://docs.nextcloud.com/server/latest/developer_manual/';

// When display_documentation_link is true (default), linkToDocs should be called
$this->urlGenerator
->expects($this->once())
->method('linkToDocs')
->with('developer-manual')
->willReturn($developerDocsUrl);

$providedStates = [];
$this->initialState
->expects($this->exactly(4))
->method('provideInitialState')
->willReturnCallback(function ($key, $value) use (&$providedStates) {
$providedStates[$key] = $value;
});

$this->appSettingsController->viewApps();

// Assert that the developer docs state was provided with the correct URL
$this->assertArrayHasKey('appstoreDeveloperDocs', $providedStates);
$this->assertEquals($developerDocsUrl, $providedStates['appstoreDeveloperDocs']);
}
}
Loading