use of com.willshex.blogwt.shared.page.search.Filter in project blogwt by billy1380.
the class DownloadJsonServlet method doGet.
/* (non-Javadoc)
*
* @see com.willshex.gson.web.service.server.JsonServlet#doGet() */
@Override
protected void doGet() throws IOException {
String action = REQUEST.get().getParameter("action");
String request = REQUEST.get().getParameter("request");
if (request == null && "download".equals(action)) {
Session userSession = ServletHelper.session(REQUEST.get());
if (userSession != null) {
String idParam = REQUEST.get().getParameter(ENTITY_ID_KEY);
if (idParam != null) {
Long id = Long.valueOf(idParam);
GeneratedDownload generatedDownload = GeneratedDownloadServiceProvider.provide().getGeneratedDownload(id);
if (generatedDownload.userKey.getId() == userSession.userKey.getId()) {
Filter filter = Filter.fromStack(Stack.parse(generatedDownload.parameters));
String fileName = StringUtils.urldecode(generatedDownload.parameters).replace(Filter.QUERY + "/", "").replace("/", "_").replace("&", "_").replace(" ", "_") + "." + DownloadGeneratorProvider.extension(filter.type).get();
RESPONSE.get().setContentType(DownloadGeneratorProvider.contentType(filter.type).get());
RESPONSE.get().setHeader("content-disposition", "inline; filename=\"" + fileName + "\"");
RESPONSE.get().getOutputStream().write(GcsHelper.load(GeneratedDownloadHelper.path(generatedDownload, filter)));
} else {
RESPONSE.get().sendError(403, "Access denied, cannot download other user's file");
}
}
} else {
RESPONSE.get().sendError(403, "Access denied, cannot download file without logging in");
}
} else {
super.doGet();
}
}
use of com.willshex.blogwt.shared.page.search.Filter in project blogwt by billy1380.
the class GenerateDownloadServlet method processGenerateDownload.
/**
* @param input
* @throws InputValidationException
*/
private void processGenerateDownload(GenerateDownloadAction input) throws ServiceException {
GeneratedDownload generatedDownload = GeneratedDownloadValidator.lookup(input.download, "input.download");
try {
generatedDownload.status = GeneratedDownloadStatusType.GeneratedDownloadStatusTypeGenerating;
GeneratedDownloadServiceProvider.provide().updateGeneratedDownload(generatedDownload);
Stack stack = Stack.parse(generatedDownload.parameters);
Filter filter = Filter.fromStack(stack);
IGenerator generator = DownloadGeneratorProvider.generator(filter.type);
if (generator == null)
ApiValidator.throwServiceError(ServiceException.class, ApiError.NoGeneratorFound, filter.type);
byte[] bytes = generator.generate(generatedDownload, filter);
if (bytes != null && generatedDownload.parameters.endsWith("send")) {
GeneratedDownloadHelper.sendEmail(generatedDownload, filter, bytes);
}
generatedDownload.status = GeneratedDownloadStatusType.GeneratedDownloadStatusTypeReady;
generatedDownload.url = "/download?action=download&id=" + generatedDownload.id;
GeneratedDownloadServiceProvider.provide().updateGeneratedDownload(generatedDownload);
} catch (Throwable t) {
generatedDownload.status = GeneratedDownloadStatusType.GeneratedDownloadStatusTypeError;
GeneratedDownloadServiceProvider.provide().updateGeneratedDownload(generatedDownload);
throw new RuntimeException(t);
}
}
use of com.willshex.blogwt.shared.page.search.Filter in project blogwt by billy1380.
the class DevServlet method doGet.
/* (non-Javadoc)
*
* @see com.willshex.service.ContextAwareServlet#doGet() */
@Override
protected void doGet() throws ServletException, IOException {
super.doGet();
String action = REQUEST.get().getParameter("action");
if (action != null) {
action = action.toLowerCase();
}
if ("gentags".equals(action)) {
TagServiceProvider.provide().generateTags();
} else if (action != null && action.startsWith("index")) {
PageServiceProvider.provide();
PostServiceProvider.provide();
UserServiceProvider.provide();
((ISearch<?>) ServiceDiscovery.getService("blogwt." + action.replace("index", ""))).indexAll();
} else if ("clearsearch".equals(action)) {
PersistenceServiceProvider.provide();
String name = REQUEST.get().getParameter("index");
String ids = REQUEST.get().getParameter("ids");
String[] split = ids.split(",");
for (String id : split) {
SearchHelper.deleteSearch(name, id);
}
} else if ("linkall".equals(action)) {
PostServiceProvider.provide().linkAll();
} else if ("clearlinks".equals(action)) {
PostServiceProvider.provide().clearLinks();
} else if ("archiveall".equals(action)) {
ArchiveEntryServiceProvider.provide().generateArchive();
} else if ("fixroles".equals(action)) {
Collection<Role> all = RoleHelper.createAll();
all.stream().forEach(role -> {
Role loaded = RoleServiceProvider.provide().getCodeRole(role.code);
if (loaded == null || loaded.id == null) {
RoleServiceProvider.provide().addRole(role);
}
if (role.permissions != null) {
role.permissions.stream().forEach(i -> {
Permission lp = PermissionServiceProvider.provide().getCodePermission(i.code);
if (lp == null) {
if (LOG.isLoggable(Level.WARNING)) {
LOG.warning("Could not find permission with code [" + i.code + "], might want to run [fixpermissions] action");
}
} else {
if (loaded.permissions == null) {
loaded.permissions = new ArrayList<>();
}
loaded.permissions.add(lp);
}
});
RoleServiceProvider.provide().updateRole(loaded);
}
});
} else if ("fixpermissions".equals(action)) {
Collection<Permission> all = PermissionHelper.createAll();
Permission loaded;
for (Permission permission : all) {
loaded = PermissionServiceProvider.provide().getCodePermission(permission.code);
if (loaded == null || loaded.id == null) {
PermissionServiceProvider.provide().addPermission(permission);
}
}
} else if ("getposts".equals(action)) {
RESPONSE.get().getOutputStream().print(JsonUtils.beautifyJson((new GetPostsActionHandler()).handle((GetPostsRequest) new GetPostsRequest().showAll(Boolean.TRUE).pager(PagerHelper.createDefaultPager()).accessCode(ApiValidator.DEV_ACCESS_CODE)).toString()));
} else if ("staticurl".equals(action)) {
List<Resource> resources = ResourceServiceProvider.provide().getResources(Integer.valueOf(0), Integer.valueOf(Integer.MAX_VALUE), null, null);
JsonObject object;
for (Resource resource : resources) {
if (resource.properties != null) {
if (resource.properties.contains(":image")) {
resource.properties = resource.properties.replace(":image", ":\"image").replace("}", "\"}");
}
object = new JsonParser().parse(resource.properties).getAsJsonObject();
} else {
object = new JsonObject();
}
if (!object.has("staticUrl") || object.get("staticUrl").getAsString().startsWith("http")) {
try {
object.addProperty("staticUrl", ImagesServiceFactory.getImagesService().getServingUrl(ServingUrlOptions.Builder.withBlobKey(new BlobKey(resource.data.replace("gs://", "")))).replaceFirst("https:\\/\\/", "//").replaceFirst("http:\\/\\/", "//"));
} catch (Throwable e) {
if (LOG.isLoggable(Level.FINE)) {
LOG.fine("Could not update resource");
}
}
resource.properties = object.toString();
ResourceServiceProvider.provide().updateResource(resource);
}
}
} else if ("fixmetanotifications".equals(action)) {
List<MetaNotification> metas = MetaNotificationHelper.createAll();
for (MetaNotification meta : metas) {
if (MetaNotificationServiceProvider.provide().getCodeMetaNotification(meta.code) == null) {
meta = MetaNotificationServiceProvider.provide().addMetaNotification(meta);
LOG.info("added meta notification [" + meta.code + "] with id [" + meta.id + "]");
} else {
LOG.info("Meta notification [" + meta.code + "] already exists");
}
}
} else if ("admin".equals(action)) {
User user = UserServiceProvider.provide().getUsernameUser(REQUEST.get().getParameter("user"));
UserServiceProvider.provide().addUserRolesAndPermissions(user, Arrays.asList(RoleServiceProvider.provide().getCodeRole(RoleHelper.ADMIN)), null);
} else if ("genandshowdownload".equals(action)) {
String idParam = REQUEST.get().getParameter("id");
Long id = Long.valueOf(idParam);
GeneratedDownload d = GeneratedDownloadServiceProvider.provide().getGeneratedDownload(id);
Stack stack = Stack.parse(d.parameters);
Filter filter = Filter.fromStack(stack);
switch(filter.type) {
default:
break;
}
}
}
Aggregations