# Jira & Confluence {% hint style="success" %} Aprenda e pratique Hacking AWS:[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)\ Aprenda e pratique Hacking GCP: [**HackTricks Training GCP Red Team Expert (GRTE)**](https://training.hacktricks.xyz/courses/grte)
Support HackTricks * Confira os [**planos de assinatura**](https://github.com/sponsors/carlospolop)! * **Junte-se ao** 💬 [**grupo do Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo do telegram**](https://t.me/peass) ou **siga**-nos no **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks_live)**.** * **Compartilhe truques de hacking enviando PRs para o** [**HackTricks**](https://github.com/carlospolop/hacktricks) e [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) repositórios do github.
{% endhint %}
Se você está interessado em **carreira de hacking** e hackear o inhackeável - **estamos contratando!** (_fluência em polonês escrita e falada é necessária_). {% embed url="https://www.stmcyber.com/careers" %} ## Verificar Privilégios No Jira, **privilégios podem ser verificados** por qualquer usuário, autenticado ou não, através dos endpoints `/rest/api/2/mypermissions` ou `/rest/api/3/mypermissions`. Esses endpoints revelam os privilégios atuais do usuário. Uma preocupação notável surge quando **usuários não autenticados possuem privilégios**, indicando uma **vulnerabilidade de segurança** que pode ser elegível para um **bounty**. Da mesma forma, **privilégios inesperados para usuários autenticados** também destacam uma **vulnerabilidade**. Uma **atualização** importante foi feita em **1º de fevereiro de 2019**, exigindo que o endpoint 'mypermissions' incluísse um **'parâmetro de permissão'**. Este requisito visa **aumentar a segurança** especificando os privilégios que estão sendo consultados: [verifique aqui](https://developer.atlassian.com/cloud/jira/platform/change-notice-get-my-permissions-requires-permissions-query-parameter/#change-notice---get-my-permissions-resource-will-require-a-permissions-query-parameter) * ADD\_COMMENTS * ADMINISTRAR * ADMINISTRAR\_PROJETOS * USUÁRIO\_ATRIBUÍVEL * ATRIBUIR\_TAREFAS * NAVEGAR\_PROJETOS * ALTERAÇÃO\_EM\_BULK * FECHAR\_TAREFAS * CRIAR\_ANEXOS * CRIAR\_TAREFAS * CRIAR\_PROJETO * CRIAR\_OBJETOS\_COMPARTILHADOS * DELETAR\_TODOS\_ANEXOS * DELETAR\_TODOS\_COMENTÁRIOS * DELETAR\_TODOS\_REGISTROS\_DE\_TRABALHO * DELETAR\_TAREFAS * DELETAR\_SEUS\_ANEXOS * DELETAR\_SEUS\_COMENTÁRIOS * DELETAR\_SEUS\_REGISTROS\_DE\_TRABALHO * EDITAR\_TODOS\_COMENTÁRIOS * EDITAR\_TODOS\_REGISTROS\_DE\_TRABALHO * EDITAR\_TAREFAS * EDITAR\_SEUS\_COMENTÁRIOS * EDITAR\_SEUS\_REGISTROS\_DE\_TRABALHO * VINCULAR\_TAREFAS * GERENCIAR\_ASSINATURAS\_DE\_FILTRO\_DE\_GRUPO * GERENCIAR\_PERMISSÃO\_DE\_SPRINTS * GERENCIAR\_OBSERVADORES * MODIFICAR\_REPORTER * MOVER\_TAREFAS * RESOLVER\_TAREFAS * AGENDAR\_TAREFAS * DEFINIR\_SEGURANÇA\_DA\_TAREFA * ADMIN\_DO\_SISTEMA * TRANSICIONAR\_TAREFAS * SELECIONADOR\_DE\_USUÁRIOS * VER\_DADOS\_AGREGADOS * VER\_FERRAMENTAS\_DE\_DEV * VER\_FLUXO\_DE\_TRABALHO\_SOMENTE\_LEITURA * VER\_VOTANTES\_E\_OBSERVADORES * TRABALHAR\_EM\_TAREFAS Exemplo: `https://your-domain.atlassian.net/rest/api/2/mypermissions?permissions=BROWSE_PROJECTS,CREATE_ISSUES,ADMINISTER_PROJECTS` ```bash #Check non-authenticated privileges curl https://jira.some.example.com/rest/api/2/mypermissions | jq | grep -iB6 '"havePermission": true' ``` ## Enumeração automatizada * [https://github.com/0x48piraj/Jiraffe](https://github.com/0x48piraj/Jiraffe) * [https://github.com/bcoles/jira\_scan](https://github.com/bcoles/jira_scan) ## Plugins Atlassian Conforme indicado neste [**blog**](https://cyllective.com/blog/posts/atlassian-audit-plugins), na documentação sobre [Módulos de Plugin ↗](https://developer.atlassian.com/server/framework/atlassian-sdk/plugin-modules/) é possível verificar os diferentes tipos de plugins, como: * [Módulo de Plugin REST ↗](https://developer.atlassian.com/server/framework/atlassian-sdk/rest-plugin-module): Expõe endpoints de API RESTful * [Módulo de Plugin Servlet ↗](https://developer.atlassian.com/server/framework/atlassian-sdk/servlet-plugin-module/): Implanta servlets Java como parte de um plugin * [Módulo de Plugin Macro ↗](https://developer.atlassian.com/server/confluence/macro-module/): Implementa Macros do Confluence, ou seja, templates HTML parametrizados Este é um exemplo do tipo de plugin macro: ```java package com.atlassian.tutorial.macro; import com.atlassian.confluence.content.render.xhtml.ConversionContext; import com.atlassian.confluence.macro.Macro; import com.atlassian.confluence.macro.MacroExecutionException; import java.util.Map; public class helloworld implements Macro { public String execute(Map map, String body, ConversionContext conversionContext) throws MacroExecutionException { if (map.get("Name") != null) { return ("

Hello " + map.get("Name") + "!

"); } else { return "

Hello World!

"; } } public BodyType getBodyType() { return BodyType.NONE; } public OutputType getOutputType() { return OutputType.BLOCK; } } ``` É possível observar que esses plugins podem ser vulneráveis a vulnerabilidades web comuns, como XSS. Por exemplo, o exemplo anterior é vulnerável porque está refletindo dados fornecidos pelo usuário. Uma vez que um XSS é encontrado, no [**este repositório do github**](https://github.com/cyllective/XSS-Payloads/tree/main/Confluence) você pode encontrar alguns payloads para aumentar o impacto do XSS. ## Plugin de Backdoor [**Este post**](https://cyllective.com/blog/posts/atlassian-malicious-plugin) descreve diferentes ações (maliciosas) que um plugin malicioso do Jira poderia realizar. Você pode encontrar [**exemplo de código neste repositório**](https://github.com/cyllective/malfluence). Estas são algumas das ações que um plugin malicioso poderia realizar: * **Ocultar Plugins de Administradores**: É possível ocultar o plugin malicioso injetando algum javascript de front-end. * **Exfiltrar Anexos e Páginas**: Permitir acessar e exfiltrar todos os dados. * **Roubar Tokens de Sessão**: Adicionar um endpoint que irá ecoar os cabeçalhos na resposta (com o cookie) e algum javascript que irá contatá-lo e vazar os cookies. * **Execução de Comandos**: Claro que é possível criar um plugin que irá executar código. * **Shell Reversa**: Ou obter um shell reverso. * **Proxy DOM**: Se o confluence estiver dentro de uma rede privada, seria possível estabelecer uma conexão através do navegador de algum usuário com acesso a ele e, por exemplo, contatar o servidor executando comandos através dele.
Se você está interessado em **carreira em hacking** e hackear o inhackeável - **estamos contratando!** (_fluência em polonês escrita e falada é necessária_). {% embed url="https://www.stmcyber.com/careers" %} {% hint style="success" %} Aprenda e pratique Hacking AWS:[**HackTricks Training AWS Red Team Expert (ARTE)**](https://training.hacktricks.xyz/courses/arte)\ Aprenda e pratique Hacking GCP: [**HackTricks Training GCP Red Team Expert (GRTE)**](https://training.hacktricks.xyz/courses/grte)
Support HackTricks * Confira os [**planos de assinatura**](https://github.com/sponsors/carlospolop)! * **Junte-se ao** 💬 [**grupo do Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo do telegram**](https://t.me/peass) ou **siga**-nos no **Twitter** 🐦 [**@hacktricks\_live**](https://twitter.com/hacktricks_live)**.** * **Compartilhe truques de hacking enviando PRs para os repositórios do** [**HackTricks**](https://github.com/carlospolop/hacktricks) e [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud).
{% endhint %}