Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Regression: Apps and Marketplace UI issues #15045

Merged
merged 64 commits into from
Jul 30, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
27394b2
Segregate Apps orchestrator and routes
tassoevan Jul 24, 2019
74d244f
Properly handle errors on orchestrator
tassoevan Jul 24, 2019
4ec6b20
Add i18n module to handle Apps translations
tassoevan Jul 24, 2019
a8b4b61
Update apps template
tassoevan Jul 24, 2019
9af34c3
Update marketplace template
tassoevan Jul 24, 2019
1c7fb26
Prefer rc-button on marketplace list
tassoevan Jul 25, 2019
bac927b
Ensure that a subscribed app will be installed
tassoevan Jul 25, 2019
ce79acd
Update appManage template (temp)
tassoevan Jul 25, 2019
a497090
Break promise chain in appManage template
tassoevan Jul 26, 2019
d135b14
Alert admins about apps on invalid state
rodrigok Jul 26, 2019
01aa3e5
Implement ui for warning and error alerts in apps
rodrigok Jul 26, 2019
216d69c
Open detail modal on viewing subscription info instead of the subscri…
geekgonecrazy Jul 26, 2019
81328a9
Implement ui for failed state of apps in detail screen
rodrigok Jul 26, 2019
75a8161
Fix appManage template data loading
tassoevan Jul 26, 2019
ad1e070
Use a simple history.back() to dismiss app logs
tassoevan Jul 26, 2019
e10a039
Share install button logic
tassoevan Jul 26, 2019
e3b33da
Ensure marketplaceVersion field on appManage template data
tassoevan Jul 26, 2019
0b13a35
Hide settings editing buttons if the app is not installed
tassoevan Jul 26, 2019
cf77a3c
Better handle errors in the apps api communicator
graywolf336 Jul 26, 2019
81859b3
Update events in appManage template
tassoevan Jul 26, 2019
b55562e
Merge branch 'fix/marketplace-ui' of github.com:RocketChat/Rocket.Cha…
tassoevan Jul 26, 2019
8f02d4a
Add getActiveLocalCount method to Users model
d-gubert Jul 26, 2019
455a965
Split button and status (partial)
tassoevan Jul 26, 2019
bdaf2df
Merge branch 'fix/marketplace-ui' of github.com:RocketChat/Rocket.Cha…
tassoevan Jul 26, 2019
6db949f
Fix appManage template state
tassoevan Jul 27, 2019
7cb2b2e
Add failure alert support into appManage
tassoevan Jul 27, 2019
aec20b7
Fix action to get free app from Marketplace
tassoevan Jul 27, 2019
91aa9d4
Update Trial button label
tassoevan Jul 27, 2019
b0f3c0e
Update category tag style
tassoevan Jul 27, 2019
1944e39
Add small tweaks to styles
tassoevan Jul 27, 2019
6241f45
Fix admin notification routine
d-gubert Jul 28, 2019
ec544db
Refactor admin notification
d-gubert Jul 28, 2019
f131257
Refactoring
d-gubert Jul 28, 2019
8665660
fix sync marketplace update
geekgonecrazy Jul 28, 2019
f351dba
Show validation erros/warnings on app detail page
d-gubert Jul 28, 2019
79bc264
Add status column to apps template
tassoevan Jul 29, 2019
b6f01b0
Fix Cloud login verification
tassoevan Jul 29, 2019
09aed68
Fix stylelint error
tassoevan Jul 29, 2019
c72715c
Move styles from marketplace template to all apps templates
tassoevan Jul 29, 2019
f35574a
Warn app status change only after user action
tassoevan Jul 29, 2019
e59ce71
Isolate app state to avoid memory leak
tassoevan Jul 29, 2019
d6958f1
Add route to Marketplace app
tassoevan Jul 29, 2019
4c07b49
React to app updates on appManage template
tassoevan Jul 29, 2019
1cd147e
Fix alert dimensions
tassoevan Jul 29, 2019
dd2aa12
Merge branch 'develop' of github.com:RocketChat/Rocket.Chat into fix/…
tassoevan Jul 29, 2019
bc94274
Change app disable prompt wording
d-gubert Jul 29, 2019
faccf34
Fix disabled label on app detail
d-gubert Jul 29, 2019
8c44e97
Refactor appButtonProps and appStatusSpanProps
tassoevan Jul 29, 2019
c4cf86c
Fix typo
tassoevan Jul 29, 2019
984c574
Make AppWebsocketReceiver extend EventEmitter
tassoevan Jul 29, 2019
973ede7
Fix appErroredStatuses list
tassoevan Jul 29, 2019
581972b
Update uninstall modal
tassoevan Jul 29, 2019
1a5e529
Add missing i18n string
tassoevan Jul 29, 2019
bb0f010
Fix bug on modify subscription modal
tassoevan Jul 29, 2019
4dfed57
Add missing i18n string
tassoevan Jul 29, 2019
52b8de4
Get AppStatus structure from apps-engine
tassoevan Jul 29, 2019
82a6332
Fix uninstall message
tassoevan Jul 29, 2019
42a34bb
Change response to apps events
d-gubert Jul 29, 2019
1483021
Update app/apps/client/admin/helpers.js
tassoevan Jul 29, 2019
25eb1d3
Update modals
tassoevan Jul 30, 2019
2148c0c
Notify admins of disabled apps with valid licenses
d-gubert Jul 30, 2019
70739d7
Remove console.log
d-gubert Jul 30, 2019
a01e52f
Bump apps-engine version
d-gubert Jul 30, 2019
dbc1047
Merge branch 'develop' into fix/marketplace-ui
d-gubert Jul 30, 2019
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
8 changes: 4 additions & 4 deletions app/apps/client/admin/appManage.js
Original file line number Diff line number Diff line change
Expand Up @@ -137,10 +137,10 @@ const getApp = async (instance) => {
}
};

const promptSubscription = async (app, instance) => {
const promptModifySubscription = async (app, instance) => {
let data = null;
try {
data = await Apps.buildExternalUrl(app.id, app.purchaseType);
data = await Apps.buildExternalUrl(app.id, app.purchaseType, true);
} catch (e) {
handleAPIError(e, instance);
return;
Expand All @@ -152,7 +152,7 @@ const promptSubscription = async (app, instance) => {
template: 'iframeModal',
}, async () => {
try {
await Apps.installApp(app.id, app.version);
await APIClient.post(`apps/${ app.id }/sync`, {});
await getApp(instance);
} catch (error) {
handleAPIError(error);
Expand Down Expand Up @@ -504,7 +504,7 @@ Template.appManage.events({
...this.purchaseType === 'subscription' ? [{
icon: 'card',
name: t('Subscription'),
action: () => promptSubscription(this, instance),
action: () => promptModifySubscription(this, instance),
}] : [],
{
icon: 'list-alt',
Expand Down
22 changes: 19 additions & 3 deletions app/apps/client/admin/helpers.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ export const handleAPIError = (error) => {
export const promptSubscription = async (app, callback, cancelCallback) => {
let data = null;
try {
data = await Apps.buildExternalUrl(app.id, app.purchaseType);
data = await Apps.buildExternalUrl(app.id, app.purchaseType, false);
} catch (error) {
handleAPIError(error);
return;
Expand All @@ -28,6 +28,22 @@ export const promptSubscription = async (app, callback, cancelCallback) => {
}, callback, cancelCallback);
};

const promptModifySubscription = async (app, callback, cancelCallback) => {
tassoevan marked this conversation as resolved.
Show resolved Hide resolved
let data = null;
try {
data = await Apps.buildExternalUrl(app.id, app.purchaseType, true);
} catch (e) {
handleAPIError(e);
return;
}

modal.open({
allowOutsideClick: false,
data,
template: 'iframeModal',
}, callback, cancelCallback);
};

const promptAppDeactivation = (callback) => {
modal.open({
text: t('Apps_Marketplace_Deactivate_App_Prompt'),
Expand Down Expand Up @@ -69,9 +85,9 @@ export const triggerAppPopoverMenu = (app, currentTarget, instance) => {
return;
}

const handleSubscription = () => promptSubscription(app, async () => {
const handleSubscription = () => promptModifySubscription(app, async () => {
try {
await Apps.installApp(app.id, app.marketplaceVersion);
await Apps.syncApp(app.id);
} catch (error) {
handleAPIError(error);
}
Expand Down
3 changes: 2 additions & 1 deletion app/apps/client/orchestrator.js
Original file line number Diff line number Diff line change
Expand Up @@ -152,11 +152,12 @@ class AppClientOrchestrator {

disableApp = (appId) => this.setAppStatus(appId, 'manually_disabled')

buildExternalUrl = (appId, purchaseType = 'buy') =>
buildExternalUrl = (appId, purchaseType = 'buy', details = false) =>
APIClient.get('apps', {
buildExternalUrl: 'true',
appId,
purchaseType,
details,
})

getCategories = async () => {
Expand Down
36 changes: 34 additions & 2 deletions app/apps/server/communication/rest.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ import { API } from '../../../api/server';
import { getWorkspaceAccessToken, getUserCloudAccessToken } from '../../../cloud/server';
import { settings } from '../../../settings';
import { Info } from '../../../utils';
import { Settings, Users } from '../../../models/server';
import { Apps } from '../orchestrator';

const getDefaultHeaders = () => ({
'X-Apps-Engine-Version': Info.marketplaceApiVersion,
Expand Down Expand Up @@ -110,10 +112,14 @@ export class AppsRestApi {
return API.v1.failure({ error: 'Unauthorized' });
}

const subscribeRoute = this.queryParams.details === 'true' ? 'subscribe/details' : 'subscribe';

const seats = Users.findActive().count() - Users.findActiveRemote().count();
graywolf336 marked this conversation as resolved.
Show resolved Hide resolved

return API.v1.success({
url: `${ baseUrl }/apps/${ this.queryParams.appId }/${
this.queryParams.purchaseType === 'buy' ? this.queryParams.purchaseType : 'subscribe'
}?workspaceId=${ workspaceId }&token=${ token }`,
this.queryParams.purchaseType === 'buy' ? this.queryParams.purchaseType : subscribeRoute
}?workspaceId=${ workspaceId }&token=${ token }&seats=${ seats }`,
});
}

Expand Down Expand Up @@ -392,6 +398,32 @@ export class AppsRestApi {
},
});

this.api.addRoute(':id/sync', { authRequired: true, permissionsRequired: ['manage-apps'] }, {
post() {
const baseUrl = orchestrator.getMarketplaceUrl();

const headers = getDefaultHeaders();
const token = getWorkspaceAccessToken();
if (token) {
headers.Authorization = `Bearer ${ token }`;
}

const [workspaceIdSetting] = Settings.findById('Cloud_Workspace_Id').fetch();

const result = HTTP.get(`${ baseUrl }/v1/workspaces/${ workspaceIdSetting.value }/apps/${ this.urlParams.id }`, {
headers,
});

if (result.statusCode !== 200) {
graywolf336 marked this conversation as resolved.
Show resolved Hide resolved
return API.v1.failure();
}

Promise.await(Apps.updateAppsMarketplaceInfo(result.data));

return API.v1.success({ app: result.data });
},
});

this.api.addRoute(':id/icon', { authRequired: true, permissionsRequired: ['manage-apps'] }, {
get() {
const prl = manager.getOneById(this.urlParams.id);
Expand Down
6 changes: 4 additions & 2 deletions app/apps/server/cron.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,16 @@ import { SyncedCron } from 'meteor/littledata:synced-cron';

import { Apps } from './orchestrator';
import { getWorkspaceAccessToken } from '../../cloud/server';
import { Settings } from '../../models/server';
import { Settings, Users } from '../../models/server';

export const appsUpdateMarketplaceInfo = Meteor.bindEnvironment(() => {
const token = getWorkspaceAccessToken();
const baseUrl = Apps.getMarketplaceUrl();
const [workspaceIdSetting] = Settings.findById('Cloud_Workspace_Id').fetch();

const fullUrl = `${ baseUrl }/v1/workspaces/${ workspaceIdSetting.value }/apps`;
const currentSeats = Users.findActive().count() - Users.findActiveRemote().count();

const fullUrl = `${ baseUrl }/v1/workspaces/${ workspaceIdSetting.value }/apps?seats=${ currentSeats }`;
const options = {
headers: {
Authorization: `Bearer ${ token }`,
Expand Down