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

cannot access editable source of v2 diagram - www-project-top-10-for-large-language-model-applications/2_0_vulns/artifacts /v2.0 - OWASP Top 10 for LLM Applications and Generative AI - LLM Application HLD - Presentation DLD.jpeg #388

Closed
13 tasks
idj3 opened this issue Jul 19, 2024 · 10 comments
Assignees

Comments

@idj3
Copy link

idj3 commented Jul 19, 2024

Remember, an issue is not the place to ask questions. You can use our Slack channel for that, or you may want to consult the following Slack channels:

When reporting an issue, please be sure to include the following:

  • Before you open an issue, please check if a similar issue already exists or has been closed before.
  • A descriptive title and apply the specific LLM-0-10 label relative to the entry. See our available labels.
  • A description of the problem you're trying to solve, including why you think this is a problem
  • If the enhancement changes current behavior, reasons why your solution is better
  • What artifact and version of the project you're referencing, and the location (I.E OWASP site, llmtop10.com, repo)
  • The behavior you expect to see, and the actual behavior

Steps to Reproduce


What happens?


What were you expecting to happen?


Any logs, error output, etc?


Any other comments?


  • Slack post link (if relevant)

What versions of hardware and software are you using?


Operating System:
Browser:

  • Chrome
  • Firefox
  • Edge
  • Safari 11
  • Safari 10
  • IE 11
Copy link

👋 Thanks for reporting! Please ensure labels are applied appropriately to the issue so that the workflow automation can triage this to the correct member of the core team

@GangGreenTemperTatum
Copy link
Collaborator

thanks for raising this @idj3 , we do not allow an editable version of the document to prevent unintentional changes into the pipeline

can you please list concerns, errors or improvements for the document in here and i'll collaborate with you?

@GangGreenTemperTatum
Copy link
Collaborator

hey @idj3 , ill close this off due to inactivity but plmk if you need anything else! please also see WIP in #393 and would love your feedback on this here or in our Slack thread

@idj3
Copy link
Author

idj3 commented Jul 31, 2024

Hi @GangGreenTemperTatum , my main comment is that we should consider adding an 'orchestrator' component between the client application and the LLM service - that is where many security safeguards are often concentrated (incl. content moderation, masking, throttling, authentication, etc), grounding (e.g. RAG calluots) and it can span trust boundaries.
Also, we should provide general description of the components to include in the final v2 document.
I will bring this back in the slack thread to collaborate there.

Copy link

👋 Thanks for reporting! Please ensure labels are applied appropriately to the issue so that the workflow automation can triage this to the correct member of the core team

@GangGreenTemperTatum
Copy link
Collaborator

adding comments from our Slack thread @idj3 , let's continue the discussion here for vis of the group and community :)

thanks @Ivan!
> Some of the main features that this capability can include:
i like your points, but im worried this can stray away from a "high level abstraction" which the document serves as, it's not a full blown threat modeling exercise
with that said, any suggestions and are you in agreement here? if we list remediations, where does it end? is it not sufficient to link the OWASP top 10 entries which sub-bullet attack scenarios and remediations? this is the point we are trying to emphasize, but the diagram is to elaborate "where" this can occur in a typical LLM app and trust boundary(ies)
> Also, we should provide general (brief) description for all the components to include in the final v2 document, I thought that was one thing missing in v1.
a callout box, or alternative suggestion you have? or should we refer to the glossary in the wiki?

@GangGreenTemperTatum GangGreenTemperTatum self-assigned this Jul 31, 2024
@idj3
Copy link
Author

idj3 commented Jul 31, 2024

I agree that too much detail can be counterproductive, but since LLM10 document aims to provide both vulnerability overview as well as mitigation strategies, IMHO we should have some standardised architecture that guides where/how those controls can be implemented.
for example, there can be a lot of prompt manipulation before it arrives to LLM (RAG, masking) which can affect exposure/defenses for a number of vulnerabilities (e.g. 01, 04, 06)
lot of organisations are looking to build additional defenses as they tap into external LLMs, where the concept of orchestrator is very relevant (it's something we were discussing at Cloud Security Alliance and I thought it made a lot of sense).
on the other hand, there is a great detail on downstream services but not sure what that adds - i may well be wrong though.

re description, imho simple list below the diagram is better than callouts as it declutters the picture.
Nothing too detailed, but for example 'plugin' is very generic so some information on purpose, key features (and perhaps who has responsibility) would be beneficial

@GangGreenTemperTatum
Copy link
Collaborator

GangGreenTemperTatum commented Aug 3, 2024

but since LLM10 document aims to provide both vulnerability overview as well as mitigation strategies

sorry, slightly confused here as this is the template for all vulnerabilities, is there something specific for this vulnerability or do you mean in general?

or example, there can be a lot of prompt manipulation before it arrives to LLM (RAG, masking) which can affect exposure/defenses for a number of vulnerabilities (e.g. 01, 04, 06)
lot of organisations are looking to build additional defenses as they tap into external LLMs, where the concept of orchestrator is very relevant (it's something we were discussing at Cloud Security Alliance and I thought it made a lot of sense).

i agree, can you annotate an example on top of the current architecture diagram for your understanding of thought logic here? async maybe best with a hectic defcon schedule next week and mainly for me to understand what you "envision this looking like" and open to collaborate on ideas

Nothing too detailed, but for example 'plugin' is very generic so some information on purpose, key features (and perhaps who has responsibility) would be beneficial

i do have to be honest and think we should stick to the default Definitions in the wiki to ascertain a single-source-of-truth and avoid drift, would it help if I added a hyperlink reference here, wdyt?

i really appreciate the feedback and you sharing recent experiences from the CSA also

@idj3
Copy link
Author

idj3 commented Aug 12, 2024

@GangGreenTemperTatum :
1 - it was a general comment (not specific for LLM10)

2 - I like the new diagram, I think of "orchestrator" being part of 'application services' or perhaps to sit between app services and LLM.
IMHO, RAG should connect to that layer (orchestrator / app services) rather than LLM service directly - RAG typically contains private (enterprise) data and organisations may want to have better control how that is accessed (e.g. to encrich the prompt before it is passed to the LLM); you could see app services and RAG in the same (organisational) trust boundary. wdyt?

3 - i can't access the Definitions page, the link sends me to the diagram

@GangGreenTemperTatum
Copy link
Collaborator

@idj3

  1. the diagram is only purposed to identify elements of attack vectors where our top 10 vulnerabilities can be introduced. the topic of remediation items and mitigations is listed in the vulnerabilities themselves (not to overblow the diagram verbosity) or would be done in a separate threat modeling runbook such as STRIDE tables etc.
  2. thanks! i feel that you are suggesting some changes to this portion highlighted(?) can you annotate a simple sketch for my understanding pls?

image

  1. my bad, apologies. i updated my old comment and the link again for reference is here (repo->wiki-><search"definitions">

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants