This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org
Difference between revisions of "OWASP TASC Framework Project"
Andy Boura (talk | contribs) m (→TASC Framework Project) |
Andy Boura (talk | contribs) (→Minimum Viable Product) |
||
(36 intermediate revisions by 3 users not shown) | |||
Line 13: | Line 13: | ||
Makers, professionally or as hobbyists, are creating "Internet of Things" (IoT) devices using low power systems such as Arduino. Security is often an afterthought or not considered at all. This project will make it easy to secure communications between devices. | Makers, professionally or as hobbyists, are creating "Internet of Things" (IoT) devices using low power systems such as Arduino. Security is often an afterthought or not considered at all. This project will make it easy to secure communications between devices. | ||
− | + | This project will put a communications protocol and medium agnostic encryption and authentication layer onto resource constrained devices such as the Arduino. | |
The use of this framework will require no specialist security knowledge. | The use of this framework will require no specialist security knowledge. | ||
==Description== | ==Description== | ||
− | The TASC Framework ('''T'''hings '''A'''uthentication and '''S'''ecure '''C'''ommunications) provides a lightweight abstracted security framework and supporting libraries to provide authentication and secure communications on resource constrained systems. For example developers creating "Internet of Things" (IoT) devices using low power | + | The TASC Framework ('''T'''hings '''A'''uthentication and '''S'''ecure '''C'''ommunications) provides a lightweight abstracted security framework and supporting libraries to provide authentication and secure communications on resource constrained systems. For example developers creating "Internet of Things" (IoT) devices using low power systems such as Arduino who are not security experts. |
==Licensing== | ==Licensing== | ||
− | + | The libraries and source code / examples associated with this project are licenced under Apache 2.0 Licence in order to encourage the broadest possible use in embedded systems where dynamic linking may not be practical. | |
− | |||
− | |||
− | |||
− | + | The documentation and guidelines are licenced under Creative Commons Attribution ShareAlike 3.0 Licence. | |
− | |||
− | |||
− | |||
<!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | <!-- DO NOT ALTER OR REMOVE THE TEXT ON NEXT LINE --> | ||
| valign="top" style="padding-left:25px;width:200px;border-right: 1px dotted gray;padding-right:25px;" | | | valign="top" style="padding-left:25px;width:200px;border-right: 1px dotted gray;padding-right:25px;" | | ||
− | == What is OWASP | + | == What is OWASP TASC Framework Project? == |
+ | |||
+ | Low powered devices such as those found in IoT developments will often be placed on people's home networks or within range of other's wireless communications devices. This leaves them vulnerable to compromises - particularly with regards to integrity and confidentiality. | ||
+ | |||
+ | The OWASP TASC Framework looks to address these issues in a way that makes no assumptions about the mechanism of the transmission of the data or commands - whether it be visible light, infra-red, 433MHz, 1-wire, serial, I2C, Bluetooth, WiFi etc. This is done by providing the capability to secure the payload and allowing the device developer the freedom to choose the communication medium. | ||
− | + | Using an AES library such as: http://forum.arduino.cc/index.php?topic=88890.0 symmetric key encryption of the message payloads to ensure the authentication, integrity, and confidentiality of messages. | |
− | + | | valign="top" style="padding-left:25px;width:200px;border-right: 1px dotted gray;padding-right:25px;" | | |
− | |||
− | |||
− | + | == Project Resources == | |
− | + | [https://github.com/pwkpete/TASC Source Code] | |
− | + | [https://github.com/pwkpete/TASC Documentation] | |
− | + | [https://github.com/pwkpete/TASC Wiki Home Page] | |
− | |||
− | |||
− | |||
+ | [https://github.com/pwkpete/TASC Issue Tracker] | ||
− | + | [https://github.com/pwkpete/TASC Slide Presentation] | |
− | + | The framework consists of a coordinator, a key manager, and one or more pairing mechanisms. | |
− | + | == Presentation == | |
− | |||
− | |||
− | |||
− | + | Not yet...but watch this space... | |
+ | == Project Leader == | ||
+ | |||
+ | * [https://www.owasp.org/index.php/User:Andy_Boura Andy Boura] | ||
== Related Projects == | == Related Projects == | ||
<!-- Instructions are in RED and should be removed from your document by deleting the text with the span tags.--> | <!-- Instructions are in RED and should be removed from your document by deleting the text with the span tags.--> | ||
− | + | Please let us know of any relevant related projects. | |
− | |||
− | |||
− | |||
− | |||
== Openhub == | == Openhub == | ||
Line 84: | Line 74: | ||
== Quick Download == | == Quick Download == | ||
− | + | Nothing yet but we should have some deliverables ready soon. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
== News and Events == | == News and Events == | ||
− | + | * [23 July 2015] First version of the project wiki page up! | |
− | |||
− | |||
− | |||
− | |||
− | * [ | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Classifications== | ==Classifications== | ||
− | |||
− | |||
− | |||
− | |||
− | |||
{| width="200" cellpadding="2" | {| width="200" cellpadding="2" | ||
Line 128: | Line 89: | ||
| align="center" valign="top" width="50%"| [[File:Owasp-defenders-small.png|link=]] | | align="center" valign="top" width="50%"| [[File:Owasp-defenders-small.png|link=]] | ||
|- | |- | ||
− | | colspan="2" align="center" | [[File:Cc-button-y-sa-small.png|link=http://creativecommons.org/licenses/by-sa/3.0/]] | + | | colspan="2" align="center" | |
+ | [[File:Cc-button-y-sa-small.png|link=http://creativecommons.org/licenses/by-sa/3.0/]][[File:Project_Type_Files_DOC.jpg|link=]] | ||
|- | |- | ||
− | | colspan="2" align="center" | [[File: | + | | colspan="2" align="center" | |
+ | [[File:Apache-feather-small.gif|link=http://www.apache.org/licenses/LICENSE-2.0]][[File:Project_Type_Files_CODE.jpg|link=]] | ||
|} | |} | ||
− | |||
|} | |} | ||
=FAQs= | =FAQs= | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==How can I participate in your project?== | ==How can I participate in your project?== | ||
− | All you have to do is make the Project Leader's aware of your available time to contribute to the project. It is also important to let the Leader's know how you would like to contribute and pitch in to help the project meet it's goals and milestones. There are many different ways you can contribute to an OWASP Project, but communication with the leads is key. | + | All you have to do is make the Project Leader's aware of your available time to contribute to the project. It is also important to let the Leader's know how you would like to contribute and pitch in to help the project meet it's goals and milestones. There are many different ways you can contribute to an OWASP Project, but communication with the leads is key. Please see the getting involved tab. |
==If I am not a programmer can I participate in your project?== | ==If I am not a programmer can I participate in your project?== | ||
− | Yes, you can certainly participate in the project if you are not a programmer or technical. The project needs different skills and expertise and different times during its development. | + | Yes, you can certainly participate in the project if you are not a programmer or technical. The project needs different skills and expertise and different times during its development. See the getting involved tab for some of the ways you might be able to contribute. |
+ | |||
+ | ==What platforms are supported by the framework?== | ||
+ | The framework itself is platform agnostic and can be readily ported to any platform. Initially the Arduino platform will be targeted as a reference implementation due to it's broad adoption, starting point for budding developers, and strong community. | ||
= Acknowledgements = | = Acknowledgements = | ||
Line 153: | Line 112: | ||
==Contributors== | ==Contributors== | ||
− | + | The OWASP Security Principles project is developed by a worldwide team of volunteers. | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | + | <!-- A live update of project [https://github.com/OWASP/Security-Principles/graphs/contributors contributors is found here]. --> | |
The first contributors to the project were: | The first contributors to the project were: | ||
− | * [https://www.owasp.org/index.php/User: | + | * [https://www.owasp.org/index.php/User:Andy_Boura Andy Boura] |
− | * [https:// | + | * [https://www.owasp.org/index.php/User:Pete_Ikusz Pete Ikusz] |
− | + | * Malcolm Boura | |
− | * | ||
= Road Map and Getting Involved = | = Road Map and Getting Involved = | ||
− | |||
− | |||
− | |||
== The key milestones are: == | == The key milestones are: == | ||
+ | # Use cases | ||
+ | # Requirements | ||
+ | # API and data structures | ||
# Documented lightweight security framework and API | # Documented lightweight security framework and API | ||
# Reference implementation for Arduino platform | # Reference implementation for Arduino platform | ||
Line 181: | Line 134: | ||
== The key deliverables are == | == The key deliverables are == | ||
− | # | + | # Formal documentation |
− | |||
− | |||
# Arduino reference implementation and documentation | # Arduino reference implementation and documentation | ||
− | |||
# Additional platform ports for both clients and servers | # Additional platform ports for both clients and servers | ||
− | + | Here is an outline of the modules that will be specified in the documentation and delivered in the reference Arduino implementation: | |
− | + | https://www.lucidchart.com/publicSegments/view/55c3535d-b0f0-4faf-88ea-14a00a005c31/image.png | |
− | |||
+ | == Getting Involved == | ||
+ | Involvement in the development and promotion of the OWASP TASC Framework Project is actively encouraged! | ||
+ | You do not have to be a security expert in order to contribute. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
Some of the ways you can help: | Some of the ways you can help: | ||
* Core framework developer | * Core framework developer | ||
Line 213: | Line 157: | ||
+ | =Minimum Viable Product= | ||
+ | |||
+ | A minimum viable product would meet all requirements of the reference implementation and all previous milestones (see Road Map). The reference implementation includes the foundation of the system, the interface layer and example implementations of the interfaces that can be used as a basis for customization by the end user to meet the specific requirements of their system or environment. | ||
Latest revision as of 14:40, 16 December 2015
TASC Framework ProjectThings Authentication and Secure Communications (for Resource Constrained Systems) Makers, professionally or as hobbyists, are creating "Internet of Things" (IoT) devices using low power systems such as Arduino. Security is often an afterthought or not considered at all. This project will make it easy to secure communications between devices. This project will put a communications protocol and medium agnostic encryption and authentication layer onto resource constrained devices such as the Arduino. The use of this framework will require no specialist security knowledge. DescriptionThe TASC Framework (Things Authentication and Secure Communications) provides a lightweight abstracted security framework and supporting libraries to provide authentication and secure communications on resource constrained systems. For example developers creating "Internet of Things" (IoT) devices using low power systems such as Arduino who are not security experts. LicensingThe libraries and source code / examples associated with this project are licenced under Apache 2.0 Licence in order to encourage the broadest possible use in embedded systems where dynamic linking may not be practical. The documentation and guidelines are licenced under Creative Commons Attribution ShareAlike 3.0 Licence. |
What is OWASP TASC Framework Project?Low powered devices such as those found in IoT developments will often be placed on people's home networks or within range of other's wireless communications devices. This leaves them vulnerable to compromises - particularly with regards to integrity and confidentiality. The OWASP TASC Framework looks to address these issues in a way that makes no assumptions about the mechanism of the transmission of the data or commands - whether it be visible light, infra-red, 433MHz, 1-wire, serial, I2C, Bluetooth, WiFi etc. This is done by providing the capability to secure the payload and allowing the device developer the freedom to choose the communication medium. Using an AES library such as: http://forum.arduino.cc/index.php?topic=88890.0 symmetric key encryption of the message payloads to ensure the authentication, integrity, and confidentiality of messages. |
Project ResourcesThe framework consists of a coordinator, a key manager, and one or more pairing mechanisms. PresentationNot yet...but watch this space... Project LeaderRelated ProjectsPlease let us know of any relevant related projects. Openhub |
Quick DownloadNothing yet but we should have some deliverables ready soon. News and Events
Classifications |
How can I participate in your project?
All you have to do is make the Project Leader's aware of your available time to contribute to the project. It is also important to let the Leader's know how you would like to contribute and pitch in to help the project meet it's goals and milestones. There are many different ways you can contribute to an OWASP Project, but communication with the leads is key. Please see the getting involved tab.
If I am not a programmer can I participate in your project?
Yes, you can certainly participate in the project if you are not a programmer or technical. The project needs different skills and expertise and different times during its development. See the getting involved tab for some of the ways you might be able to contribute.
What platforms are supported by the framework?
The framework itself is platform agnostic and can be readily ported to any platform. Initially the Arduino platform will be targeted as a reference implementation due to it's broad adoption, starting point for budding developers, and strong community.
Contributors
The OWASP Security Principles project is developed by a worldwide team of volunteers.
The first contributors to the project were:
- Andy Boura
- Pete Ikusz
- Malcolm Boura
The key milestones are:
- Use cases
- Requirements
- API and data structures
- Documented lightweight security framework and API
- Reference implementation for Arduino platform
- Client libraries and ports to other platforms
The key deliverables are
- Formal documentation
- Arduino reference implementation and documentation
- Additional platform ports for both clients and servers
Here is an outline of the modules that will be specified in the documentation and delivered in the reference Arduino implementation:
Getting Involved
Involvement in the development and promotion of the OWASP TASC Framework Project is actively encouraged! You do not have to be a security expert in order to contribute.
Some of the ways you can help:
- Core framework developer
- Framework functional testing
- Framework penetration testing
- Helping alpha and beta testing the framework on different hardware:
- Sharing example code
- Creating "How to" articles and videos
- Providing feedback
- Project administration support.
- Publicity and awareness / advocacy
A minimum viable product would meet all requirements of the reference implementation and all previous milestones (see Road Map). The reference implementation includes the foundation of the system, the interface layer and example implementations of the interfaces that can be used as a basis for customization by the end user to meet the specific requirements of their system or environment.