use of com.liferay.portal.kernel.exception.SystemException in project liferay-ide by liferay.
the class UserLocalServiceImpl method decryptUserId.
/**
* Decrypts the user's primary key and password from their encrypted forms.
* Used for decrypting a user's credentials from the values stored in an
* automatic login cookie.
*
* @param companyId the primary key of the user's company
* @param name the encrypted primary key of the user
* @param password the encrypted password of the user
* @return the user's primary key and password
* @throws PortalException if a user with the primary key could not be found
* or if the user's password was incorrect
* @throws SystemException if a system exception occurred
*/
@Override
public KeyValuePair decryptUserId(long companyId, String name, String password) throws PortalException, SystemException {
Company company = companyPersistence.findByPrimaryKey(companyId);
try {
name = Encryptor.decrypt(company.getKeyObj(), name);
} catch (EncryptorException ee) {
throw new SystemException(ee);
}
long userId = GetterUtil.getLong(name);
User user = userPersistence.findByPrimaryKey(userId);
try {
password = Encryptor.decrypt(company.getKeyObj(), password);
} catch (EncryptorException ee) {
throw new SystemException(ee);
}
String userPassword = user.getPassword();
String encPassword = PasswordEncryptorUtil.encrypt(password, userPassword);
if (userPassword.equals(encPassword)) {
if (isPasswordExpired(user)) {
user.setPasswordReset(true);
userPersistence.update(user);
}
return new KeyValuePair(name, password);
} else {
throw new PrincipalException();
}
}
use of com.liferay.portal.kernel.exception.SystemException in project liferay-ide by liferay.
the class ArtistLocalServiceImpl method updateArtist.
@Indexable(type = IndexableType.REINDEX)
public Artist updateArtist(long userId, long artistId, String name, String bio, InputStream inputStream, ServiceContext serviceContext) throws PortalException, SystemException {
// Event
User user = userPersistence.findByPrimaryKey(userId);
validate(name);
Artist artist = artistPersistence.findByPrimaryKey(artistId);
artist.setModifiedDate(serviceContext.getModifiedDate(null));
artist.setName(name);
artist.setBio(bio);
artist.setExpandoBridgeAttributes(serviceContext);
artistPersistence.update(artist);
if (inputStream != null) {
Repository repository = PortletFileRepositoryUtil.fetchPortletRepository(serviceContext.getScopeGroupId(), Constants.JUKEBOX_PORTLET_REPOSITORY);
if (repository != null) {
try {
PortletFileRepositoryUtil.deletePortletFileEntry(repository.getRepositoryId(), DLFolderConstants.DEFAULT_PARENT_FOLDER_ID, String.valueOf(artist.getArtistId()));
} catch (Exception e) {
if (_log.isDebugEnabled()) {
_log.debug("Cannot delete artist image");
}
}
}
PortletFileRepositoryUtil.addPortletFileEntry(serviceContext.getScopeGroupId(), userId, Artist.class.getName(), artist.getArtistId(), Constants.JUKEBOX_PORTLET_REPOSITORY, DLFolderConstants.DEFAULT_PARENT_FOLDER_ID, inputStream, String.valueOf(artist.getArtistId()), StringPool.BLANK, true);
}
// Asset
updateAsset(userId, artist, serviceContext.getAssetCategoryIds(), serviceContext.getAssetTagNames(), serviceContext.getAssetLinkEntryIds());
return artist;
}
use of com.liferay.portal.kernel.exception.SystemException in project liferay-ide by liferay.
the class ArtistLocalServiceImpl method deleteArtist.
@Indexable(type = IndexableType.DELETE)
public Artist deleteArtist(long artistId) throws PortalException, SystemException {
Artist artist = artistPersistence.findByPrimaryKey(artistId);
List<Album> albums = albumLocalService.getAlbumsByArtistId(artistId);
for (Album album : albums) {
albumLocalService.deleteAlbum(album.getAlbumId());
}
try {
PortletFileRepositoryUtil.deletePortletFileEntry(artist.getGroupId(), DLFolderConstants.DEFAULT_PARENT_FOLDER_ID, String.valueOf(artistId));
} catch (Exception e) {
}
return artistPersistence.remove(artistId);
}
use of com.liferay.portal.kernel.exception.SystemException in project liferay-ide by liferay.
the class KBArticlePersistenceImpl method filterFindByG_P_S_L.
/**
* Returns an ordered range of all the k b articles that the user has permission to view where groupId = ? and parentResourcePrimKey = ? and sections LIKE any ? and latest = ?.
*
* <p>
* Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link com.liferay.knowledgebase.model.impl.KBArticleModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order.
* </p>
*
* @param groupId the group ID
* @param parentResourcePrimKey the parent resource prim key
* @param sectionses the sectionses
* @param latest the latest
* @param start the lower bound of the range of k b articles
* @param end the upper bound of the range of k b articles (not inclusive)
* @param orderByComparator the comparator to order the results by (optionally <code>null</code>)
* @return the ordered range of matching k b articles that the user has permission to view
* @throws SystemException if a system exception occurred
*/
@Override
public List<KBArticle> filterFindByG_P_S_L(long groupId, long parentResourcePrimKey, String[] sectionses, boolean latest, int start, int end, OrderByComparator orderByComparator) throws SystemException {
if (!InlineSQLHelperUtil.isEnabled(groupId)) {
return findByG_P_S_L(groupId, parentResourcePrimKey, sectionses, latest, start, end, orderByComparator);
}
StringBundler query = new StringBundler();
if (getDB().isSupportsInlineDistinct()) {
query.append(_FILTER_SQL_SELECT_KBARTICLE_WHERE);
} else {
query.append(_FILTER_SQL_SELECT_KBARTICLE_NO_INLINE_DISTINCT_WHERE_1);
}
boolean conjunctionable = false;
if (conjunctionable) {
query.append(WHERE_AND);
}
query.append(_FINDER_COLUMN_G_P_S_L_GROUPID_5);
conjunctionable = true;
if (conjunctionable) {
query.append(WHERE_AND);
}
query.append(_FINDER_COLUMN_G_P_S_L_PARENTRESOURCEPRIMKEY_5);
conjunctionable = true;
if ((sectionses == null) || (sectionses.length > 0)) {
if (conjunctionable) {
query.append(WHERE_AND);
}
query.append(StringPool.OPEN_PARENTHESIS);
for (int i = 0; i < sectionses.length; i++) {
String sections = sectionses[i];
if (sections == null) {
query.append(_FINDER_COLUMN_G_P_S_L_SECTIONS_4);
} else if (sections.equals(StringPool.BLANK)) {
query.append(_FINDER_COLUMN_G_P_S_L_SECTIONS_6);
} else {
query.append(_FINDER_COLUMN_G_P_S_L_SECTIONS_5);
}
if ((i + 1) < sectionses.length) {
query.append(WHERE_OR);
}
}
query.append(StringPool.CLOSE_PARENTHESIS);
conjunctionable = true;
}
if (conjunctionable) {
query.append(WHERE_AND);
}
query.append(_FINDER_COLUMN_G_P_S_L_LATEST_5);
conjunctionable = true;
if (!getDB().isSupportsInlineDistinct()) {
query.append(_FILTER_SQL_SELECT_KBARTICLE_NO_INLINE_DISTINCT_WHERE_2);
}
if (orderByComparator != null) {
if (getDB().isSupportsInlineDistinct()) {
appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS, orderByComparator, true);
} else {
appendOrderByComparator(query, _ORDER_BY_ENTITY_TABLE, orderByComparator, true);
}
} else {
if (getDB().isSupportsInlineDistinct()) {
query.append(KBArticleModelImpl.ORDER_BY_JPQL);
} else {
query.append(KBArticleModelImpl.ORDER_BY_SQL);
}
}
String sql = InlineSQLHelperUtil.replacePermissionCheck(query.toString(), KBArticle.class.getName(), _FILTER_ENTITY_TABLE_FILTER_PK_COLUMN, groupId);
Session session = null;
try {
session = openSession();
SQLQuery q = session.createSQLQuery(sql);
if (getDB().isSupportsInlineDistinct()) {
q.addEntity(_FILTER_ENTITY_ALIAS, KBArticleImpl.class);
} else {
q.addEntity(_FILTER_ENTITY_TABLE, KBArticleImpl.class);
}
QueryPos qPos = QueryPos.getInstance(q);
qPos.add(groupId);
qPos.add(parentResourcePrimKey);
if (sectionses != null) {
qPos.add(sectionses);
}
qPos.add(latest);
return (List<KBArticle>) QueryUtil.list(q, getDialect(), start, end);
} catch (Exception e) {
throw processException(e);
} finally {
closeSession(session);
}
}
use of com.liferay.portal.kernel.exception.SystemException in project liferay-ide by liferay.
the class KBArticlePersistenceImpl method countByG_P_L.
/**
* Returns the number of k b articles where groupId = ? and parentResourcePrimKey = ? and latest = ?.
*
* @param groupId the group ID
* @param parentResourcePrimKey the parent resource prim key
* @param latest the latest
* @return the number of matching k b articles
* @throws SystemException if a system exception occurred
*/
@Override
public int countByG_P_L(long groupId, long parentResourcePrimKey, boolean latest) throws SystemException {
FinderPath finderPath = FINDER_PATH_COUNT_BY_G_P_L;
Object[] finderArgs = new Object[] { groupId, parentResourcePrimKey, latest };
Long count = (Long) FinderCacheUtil.getResult(finderPath, finderArgs, this);
if (count == null) {
StringBundler query = new StringBundler(4);
query.append(_SQL_COUNT_KBARTICLE_WHERE);
query.append(_FINDER_COLUMN_G_P_L_GROUPID_2);
query.append(_FINDER_COLUMN_G_P_L_PARENTRESOURCEPRIMKEY_2);
query.append(_FINDER_COLUMN_G_P_L_LATEST_2);
String sql = query.toString();
Session session = null;
try {
session = openSession();
Query q = session.createQuery(sql);
QueryPos qPos = QueryPos.getInstance(q);
qPos.add(groupId);
qPos.add(parentResourcePrimKey);
qPos.add(latest);
count = (Long) q.uniqueResult();
FinderCacheUtil.putResult(finderPath, finderArgs, count);
} catch (Exception e) {
FinderCacheUtil.removeResult(finderPath, finderArgs);
throw processException(e);
} finally {
closeSession(session);
}
}
return count.intValue();
}
Aggregations