Changes

From Amahi Wiki
Jump to: navigation, search
Updated Android App Improvements section.
Are you a GSOC student or mentor? Have questions? Contact us via IRC on [http://talk.amahi.org #amahi on irc.freenode.net] or on the amahi-devel [[mailing list]].= About Amahi=
If you are interested We're looking for students with skills in being a mentorthese areas: current technologies like RoR, ruby, we have six great mentors python, PHP, as well as of todaynext generation technologies, but like Go (we're very welcoming of more ideas and more mentors!use it for streaming to our mobile apps), [https://nodejs.org/ Node.js], [https://github.com/amahi/spdy HTTP/2], javascript frameworks for user interaction, visualization or server services, etc.
If you are '''We're also looking for hardware projects! Creating a student, come talk to us about the ideas below Raspberry Pi-style device with great I/O that can run Amahi smoothly is a long-tem goal for possible projectsAmahi! Don't forget that these are subject to suggestions, extensions or adaptations. Even new ideas will be considered. Some of these ideas are more mature and concrete than others.''
The '''most important thing''' is Amahi started of a need to find an '''area that you enjoy''keep a personal/home cloud server, keep all my family's photos, videos, documents, and generally any data. It expanded into running applications, mostly web apps, using a programming language that you know or are willing from anything to doing backups to learn!automatic downloaders, media managers and much more.
=List Amahi is a full and proper server made up of Project Ideas=* A Linux system based on a mainline distribution, currently Fedora, but we supported Ubuntu before as well* An [https://github.com/amahi/hda-ctl installer] to help the user bring bring Amahi up in their system* A [https://github.com/amahi/platform platform], which is a web app that the user uses to manage their server, add apps* [https://www.amahi.org/apps Apps] that are installed by using the platform* Two mobile apps to access data and apps, for [http://www.amahi.org/android Android] and [http://www.amahi.org/ios iOS].
== Platform ==At Amahi we use git (see our [https://github.com/amahi Github repo]) for our version management and the technologies we have ended up using are Ruby, Ruby on Rails, PHP, Linux system internal technologies like system services, configuration areas, web server virtualhosts, databases, DNS, etc., etc.
===Plugin System==What to do (and NOT do) first =
Let's talk about what NOT to do first, because many people automatically start badly by doing these:* do '''not''' comment randomly in github issues, e.g. introducing yourself in a GH issue, saying you would like to do something, or just "make noise"* do ''Description'not'': Make the ability ' blindly try to create build things without understanding what Amahi is and install Amahi plugins easy what it does* do '''not''' just submit a pull request or issue a bug without really knowing what you are up to* do '''not''' just come to IRC, say something and enable the creation of those plugins vanish shortly thereafter. Stay for a variety of purposes, like SMART monitoring, system stuff (network scanning, etcwhile. People come and go.) Ask your question and the two examples below stick around. Get a client that can linger for the disk wizard and the Greyhole UI, among other ideasa while.Sometimes it takes hours for some people to return
'''Objective''': Create an amahi plugin system, where PHP, PythonBUT First, NodeIntroduce yourself, and other modern webapps can be easily integrated. We can currently do this interact with some RoR enginesthe community, but the mechanism is not robust enoughso please [https://docs. The plugins system should allow modern web-based apps to be easily integrated with Amahi -- from Nodegoogle.js apps to Rubycom/forms/d/e/PHP1FAIpQLScP4Q2iSzLXCjz1gK2eNutO8IhX_PETXU2bL8pqmhe2t1nCqg/Python -- viewform?usp=sf_link introduce yourself with this form], so that users can easily reap the benefits of the onslaught of difficult-to-deploy modern web apps with a single click installwe know your background and interests.ProTip: possibly leverage docker containers within Amahi
If you have questions about Amahi or just want to interact, you can contact us via IRC on [http://talk.amahi.org #amahi on irc.freenode.net] (fairly active) or on the amahi-devel [[mailing list]] (not as active). Don'''Skills Required''': RoRt forget that we are open to suggestions, extensions or adaptations. Feel free to discuss or propose new ideas for projects!
One of the most important things is to find an area that you '''Mentorsenjoy''': Carlos, Rodusing a programming environment that you know or that you are willing to learn quickly, so read below or ask questions.
===Disk Wizard===If you are interested in being a mentor, we have a few great mentors as of today, but we're very welcoming of more ideas and more mentors!
'''Description''': Expanding See the storage capacity is an important feature of Amahi but as of now it requires advanced (e[[#Mentors|mentors]] below.g. command line) skills. We want easy disk/partition onboarding.Also add the ability Looking for ideas to be asked to mount USB drives as a share when they're connected & connect external shares from for example a NAS with mentor, see the plugin system using that wizard[[#Other Ideas|other ideas]] below.
'''Objective''': Create an amahi plugin that will streamline this process by providing a UI for disk management. The plugin should detect if a new disk was added and it should provide a wizard to create partitions and format with the desired file system=List of Project Ideas=
We have organized the ideas in groups, depending what area of Amahi they belong in. These groups are not in any particular order. For instance if you are a front-end person who knows HTML and Javascript, the GUI/UX may well be the best fit and we'''Skills Required''': Low level system scriptingd love to hear from you!
'''Mentors''': Dag, Bogdan== Platform ==
'''References''':* [http://www.openmediavault.org/ OpenMediaVault] does have a nice wizard that people like===Plugin Apps ===
===Greyhole UI===Plugins are "mini apps" that live inside the Amahi platform and thus little interface need to be developed for them. They are familiar and provide easy, focused value to the user. Ideas:
* Support for automatic issuing/renewal and installation of [https://letsencrypt.org/ Let'''Description'''s Encrypt] certificates in the platform, for external access across the internet* [https://bugs.amahi.org/issues/1361 Share space usage]: Using [http: Greyhole is an application that uses Samba to create a storage pool of all your available hard drives //d3js.org D3.js] (whatever their size, however they're connectedfor example)to visualize things internal to the system, and allows you to create redundant copies of like finding out the files you storedisk space used by shares, disk usage over time, in order to prevent data loss when part of your hardware failsetc.* [https://bugs.amahi. org/issues/1480 Wake-on-LAN (WOL)]: The purpose of Amahi [http://www.amahi.org/apps/wake-on-lan-server Wake-On-LAN Server] app currently provides this plugin is capability.* [https://bugs.amahi.org/issues/1481 Virus Scan Shares]* [https://bugs.amahi.org/issues/1489 Netboot Settings/Configuration]* [https://bugs.amahi.org/issues/1487 Mail Relay] (i.e. using Gmail or ISP)* [https://bugs.amahi.org/issues/1459 Convert app] [https://www.amahi.org/apps/Amahi-energy-saver Amahi Energy Saver] to provide a UI and the necessary tools under the UI plugin.* View log files in web browser ([https://github.com/tobi/clarity Clarity using RoR])* Ability to make starting and managing a Greyhole UI possible and nice to understand for regular humansupdate default SSL certificates (used by [https://www.amahi.org/apps/openvpn OpenVPN], [https://www.amahi.org/apps/amahi-anywhere Amahi Anywhere], etc).* AmahiTunes revival* RAID (SW, MDADM?) support* [https://bugs.amahi.org/issues/1458 SMART Disk] monitoring
'''Objective''': Create and amahi plugin that provides an UI that allows for the management of the greyhole pool. The plugin should allow an administrator user to:
add/remove disks to/from the pool.
* change the number of copies for individual file/directory
* invoke various gh commands
* view and monitor log files
* gui to visualize data distribution
'''Skills RequiredMentors''': RoRRod, System programingCarlos
'''Mentors'''=== [https: Carlos, Rod//www.amahi.org/apps/disk-wizard Disk Wizard] ===
===Backup app data/settings==='''Description''': Expanding the storage capacity is an important feature of Amahi. The DW is a critical part. However, it's not as stable as it should be. It should detect more partition types and handle everything gracefully, even when it can't act upon certain configurations.
'''DescriptionObjective''': When new versions of Amahi come out, a drawback of Amahi is that it's hard to backup the settings (e.gStability improvements and especially thoroughly testing this plugin for disk/partition management. partitioning) installed applications and their user data
'''ObjectiveSkills Required''': The plugin should allow an administrator to backup any application data either on an external media or in the cloud(e.g.: Dropbox, Google Drive, etc).The restore process should check if the application is installed on the HDA and if not it should be automatically installed from the AppStore before the user data is restored.*Create an amahi plugin that will allow backup and restore of the user data for apps installed from the AppStore*Centralising app data/configs - link them to app folder instead.*"Destructive" update awareness*Ability to list, outline data directories for backups/upgrade checkLow level system scripting
'''Mentors''': Rod, Carlos
'''Skills RequiredReferences''': System scripting* [https://bugs.amahi.org/issues/580 Track the disk wizard]* [[New Disk Wizard]] ideas page* [http://www.openmediavault.org/ OpenMediaVault] does have a nice wizard that people like
'''Mentor''': Rod, Daniel
==Mobile= Amahi 12 ===
Mobile '''Description''': [[Amahi 12]] is a great topic at the moment and there are a lot of opportunities here. In the Android app, definitely more than one student are suitable for the projectour next release.
===Android App Implementation==='''Objective''': Work closely with the core team to define the features and functionality that we need to implement to get Amahi released. This project is about working on RoR and the Amahi platform core. Some of the core technology will need to be upgraded, like Rails 5, latest Phusion Passenger, possibly replace MySQL for the platform, create a native API to the platform that can be used by other apps, like mobile apps. Other ideas include beefing up security and provide support for Amahi hosting on the cloud. Features:
'''Description''': There's huge demand for an Android application following * make platform even more modular and cleaner (at the popularity moment we still have some things that really belong in plugins but still are in controllers/views of our iOS the main app)* possibly using a new metal layer instead of passenger - especially ones that do not take a long time to reload, could be puma, i also like thin, maybe others* better initialization . Our .. like a more standard (wordpress-like) initialization wizard (initially there are no users are looking for , we need to create an application that has feature parity admin user and perhaps ask a few questions and integrate with amahi.org)* Implement sharing of folders among the existing iOS app, and even shows it up with additional features!friend servers.
'''Objective''': An Android app that is on par or better than the iOS app, including mobile streaming, downloading files and sharing them.
'''Skills Required''': JavaRoR, Androidruby, RESTJS, JSON API programmingCSS, media interaction in AndroidHTML5, Bootstrap
'''MentorMentors''': Jesse ReadCarlos, CarlosRod, BogdanSukhbir
===Webapp Browsing in Mobile apps==='''Reference''': [https://github.com/amahi/platform Amahi Platform repo]
'''Description''': Add browsing of installed webapps within our mobile app.== Android Mobile App==
'''Objective''': One requested feature for our Our mobile app (iOS apps have streaming, browsing and later Android) is the ability to browse apps within our mobile app. Our server side of the app needs to be setup to proxy specific webapps that the user has installedsharing and it's a great topic.
This year we'''Skills Required''': Go programming. Collaboration with re going to try emphasizing the iOS/Android devs will also be necessary to prototype itapp a little more.
'''Mentors''': Carlos
'''Reference''': [https://gitbut.org/amahi Amahi Github repo], in particular the SPDY and SPDY-proxy repos written in Golang===Android App Improvements===
===iOS App Improvement==='''Description''': Amahi Android offers the ability to stream your HDA over your Android phone and Android TV, support for Chromecast and auto-upload of images to HDA. The next step is to complete the following objectives:
'''DescriptionObjectives''': While Amahi has an [https://www.amahi.org/ios iOS] application already and it's ''loved'' among our users, there is a lot of room for improvement. For this project, we're looking to improve the existing iOS application and expand it's feature set. We're striving to make Amahi for iOS a polished, fast, and enjoyable application for our users.
'''Objective'''* Android TV Revamp: WeThe Android TV app is outdated at the moment and doesn're looking to improve t follow the the current implementation latest design principles of Android. We have to redesign the iOS project and add additional featuresapp so that Amahi is accessible on Android TV again. Further, here is a list of requested features:*Offer we have to display image-heavy folders and shares within a "gallery" or collection view.*Offer implement the ability PlayerAdapter in Android TV to navigate and stream shares containing music in a streamlined waysupport previews.*Dynamic searchSupport for Dagger 2: The current app is written using Dagger 1.*SPDY support, for both remote and local queriesWe have to port the code to Dagger 2 so that we can use the latest libraries which are dependent on it.*Support for accessing HDA web applications within Amahi NAU: Complete the app with support for iOSNon-Admin User which currently exists on the server-side only.Ref: https://docs.google.com/presentation/d/1jZAdXpSGQRJ6xN2WCzqkiPxQPUW2VHsAnpENZKbT2z0*Share folders UI Improvements and files from your HDA to other apps or usersUI Testing: Adding an Expresso based automated UI testing protocol.*Support Improve Background Service: Improve the app for uploading media on the HDA user permissions (share & web when the app restrictions, etc.)isn't present in the foreground*Add support for Dropbox, Google Drive, and other thirdPhone Auto-party services.Backup: Develop a module that does an Auto backup of the phone to the HDA over Local connection (reference: Helium)*Improve Friending Feature: Implement the firstsharing of folders or shares with other servers. https://docs.google.com/document/d/14JsH9-launch user experienceaZrE3Z-35Oo38IY1-3Nd5BJiR_G0DshhjKSM4/*VPN: Add functionality to assist with support for VPN proxy so that the user can access the HDA setup assistancefrom the phone over a VPN proxy tunnel.
'''Skills Required''': *Objective-C/Cocoa*Experience programming against a REST API would be helpful (Even input on improving and expanding the API!)Java, Android framework
'''Mentors''': Carlos, Chirag
'''MentorsReference''': Jesse Read, Carlos[https://github.com/amahi/android Amahi Android Github repo]
'''Reference''': [http://www.amahi.org/ios Amahi for iOS]  == GUI and UX == ===Better Theme Integration=== '''Description''': Our theme system is pretty good, however, it's very customized and we could do better with a more responsive front-end '''Objective''':* allow the usage of popular themes out there, like themes for Drupal, Wordpress, etc., with minor configuration changes, or even directly* allow the integration of mobile themes* provide hooks to detect mobile devices and present a mobile theme  '''Skills Required''': CSS, HTML5, ruby, RoR '''Mentors''': Jesse, Carlos ==Installer== ===Improved Installation=Apps==
'''Description''': Improved installation experience for users. For example, create a new Anaconda node for Amahi configuration. Similarly for UbuntuInnovative app or app packaging and app-related projects.
'''Objective''': Configuration and installation of Amahi can be painful for some percentage of users. Many who do not know or care about Linux. We want to make the installation as smooth as possible not just for them, but for more even more regular (non-techy) users. Ubuntu has some challenges of its own to make it work without dropping the users to the command line.* Make images that enable booting from USB devices "out of the box"* Detect sub-optimal configurations of disk partitions and provide feedback to the user* Measure and analyze how users get tripped on installation and create ways to tackle these issues, bringing installation issues down===Improved VPN Security===
'''Skills RequiredDescription''': PythonImprove the security of our OpenVPN and IPSec VPN apps. Examples are allowing users to generate their own certificates, Linux boot process internals, creating ISO imagesidentify weak spots and strengthen them.
'''MentorsObjective''': CarlosFor the example of generating their own certificates, Danielbuild a wizard to allow users to create and manage their certificates. Another goal would be to provide logging of VPN connections, Jesseso that the user can see the activity on their VPN.
===User Onboarding==='''Skills Required''': keen sense of security settings, certificates
'''Description''': Help users get their HDA up and running with minimal interaction after installation '''Objective''': Happier users. The idea is to implement an automated configuration check tool. The current interactive network troubleshooter can be used as a starting point. The tool should:* check if the installation was successful* compare current settings against the expected settings* automatically fix inconsistencies with no user interaction '''Skills Required''': RoR, scripting, netflow capture, dhcping scripting '''Mentors''': DanielRod, Carlos '''References''':* [http://www.amahi.net Amahi Interactive Troubleshooter] == Apps== Innovative app packaging or app related projects.
===Caching Server===
'''Description''': a caching proxy to save on bandwidth
'''Objective''': Develop and a plugin that will allow an administrator user to control the traffic for specific devices inside the network. This app (or possibly a plugin) should display all the connected device as well as provide the ability to search by name/MAC address. For a selected device the administrator should:
*Limit access between certain time intervals
*Limit bandwidth
*Block certain websites (either on an individual basis or read them from a file)
*Limit traffic
 
'''Skills Required''': system configuration and scripting
'''Mentors''': DanielCarlos, JesseRod
===Network GroupsCreate UI and package it for RSnapshot===
'''Description''': Develop Make a plugin to allow network device grouping. This will be the framework UI for future plugins.rsnapshot
'''Objective''': Allow an administrator [http://www.rsnapshot.org/ RSnapshot] is a great application to group network devices in groups with different permissionsbackup local data, making efficient use of storage as well as CPU resources and can handle a lot of data. Limit the user access A one-click app that includes a UI to certain apps based on the group settingsset up and manage RSnapshot backups.Also, possibly backup to GDrive, S3, other cloud solutions
'''Skills Required''': RoR, system programming
'''MentorsMentor''': JesseCarlos, DanielRod, Sukhbir '''References'''* [http://sourceforge.net/projects/rsnapshotbackup/ rsnapshot-backup-php]* [http://dobrev.ws/projects/webrsnapshot Webrsnapshot] ==Installer== ===Improved Installation=== '''Description''': Improved installation experience for users. '''Objective''': Configuration and installation of Amahi can be painful for some percentage of users. Many of them do not know much or care for Linux. We want to make the installation as smooth as possible not just for them, but for more even more regular (non-techy) users. Ubuntu has some challenges of its own to make it work without dropping the users to the command line.* Create a new [https://fedoraproject.org/wiki/Anaconda Anaconda] node for Amahi configuration* Similarly for Ubuntu* Make images that enable booting from USB devices "out of the box"* Detect sub-optimal configurations of disk partitions and provide feedback to the user* Measure and analyze how users get tripped on installation and create ways to tackle these issues, bringing installation issues down
===Create UI and package it for RSnapshot===
'''Description'''Idea: Make a UI for rsnapshotuse [https://github.com/diafygi/webrtc-ips this package ] to help improve installation networking issues.
'''ObjectiveSkills Required''': RSnapshot is a great application to backup local dataPython, making efficient use of storage as well as CPU resources and can handle a lot of data. A one-click app that includes a UI to set up and manage RSnapshot backups. AlsoLinux boot process internals, possibly backup to GDrive, S3, other cloud solutionscreating ISO images
'''Skills RequiredMentors''': RoR, system programmingCarlos,Rod
'''Mentor''': Rod, Dag==Amahi Anywhere==
'''References'''* [http://sourceforgeThe mobile apps use API endpoints provided by Amahi Anywhere for browsing, downloading and streaming files and more.net/projects/rsnapshotbackup/ rsnapshot-backup-php]* [http://dobrev.ws/projects/webrsnapshot Webrsnapshot]
===Package VoIP and'''References''':* [https:/or PBX system===/www.amahi.org/apps/amahi-anywhere Amahi Anywhere App]* [https://github.com/amahi/amahi-anywhere-specs Amahi Anywhere Specs]
'''Description''': A frequently requested application that is hard to package and configure is a voice over IP telephony app. Related to this is also a PBX system===Improvements in AA File Server===
'''ObjectiveDescription''': configuring PBX or a VoIP system can be complex. There are several hurdles Amahi Anywhere File Server exposes HDA files and directories via REST APIs and also allows to this. The task is to evaluate all upload new files
'''Skills RequiredObjective''': app scripting and packaging, telephony, VoIP, messaging systemsFollowing features can be implemented:
"''Mentors''"* API to access platform apps over remote via proxy* Better logging ([https: Carlos//github.com/amahi/amahi-anywhere-fs/issues/4 Issue #4])* Simplistic dashboard to view some metrics like number of users connected, Pataccess logs for each user, system health etc.* API to fetch metadata (duration, codec, album art image, title, artist name, album name, year etc.) for audio / video files* Create and cache low resolution thumbnail for image files for faster loading and enhanced experience
== Networking ==
===Clustering Amahi Servers==='''Skills Required''': GoLang, REST API Understanding
'''DescriptionMentors''': Create a system to create data nodes that integrate with the Amahi API as well as auto mount as NFS or SMB shares to allow the usage of applications through locally mounted shares (such as galleryCarlos, subsonic etc). This would allow you to connect Windows / Linux computers as data nodes. Perhaps an installable agent?Chirag
'''ObjectiveReference''': An installer that integrates with [https://github.com/amahi/amahi-anywhere-fs/ Amahi (a stripped down version of Amahi?) and a management pane in the main amahi server that allows you to add a server by IP or DNS name.Anywhere FS Github repo]
'''Skills Required''': Ruby, misc system scripting, ===Improvements in External Proxy===
'''MentorsDescription''': Carlos, Dan, RodExternal proxy provides API endpoints for users to remotely access Amahi Anywhere File Server
===Rolling Distribution==='''Objective''': Following features can be implemented:
'''Description''': Make * Cache implementation for chunks of files passing frequently through proxy to speed up response and save bandwidth* Dashboard to view metrics on both connected mobile and Amahi Anywhere FS clients* Ability to ban a rolling distributionclient
'''Objective''': Being able to upgrade Amahi versions without having to upgrade OSs is very appealing and a huge win.
'''Skills Required''': major Linux packaging mojo, ruby, system scripting, ISO packaging, repo creationGoLang
'''MentorMentors''': Carlos, Jesse ReadChirag
==Reliability=Other Ideas=
===App Testing===* Add features to our popular mobile apps: Offer to display image-heavy folders and shares within a "gallery" or collection view, add the ability to navigate and stream shares containing music in a streamlined way, Dynamic search, SPDY support, for both remote and local queries, support for accessing HDA web applications within Amahi for iOS, share folders and files from your HDA to other apps or users, support for HDA user permissions (share & web app restrictions, etc.). Mentors available: Carlos* PHP API: make a native PHP SDK for the Amahi platform, so that PHP apps (we have a lot of them) can more easy be integrated * Integrate a mail server as an app. Identify any settings or configuration that need to be implemented in the platform* Router integration, UPNP, direct control* Port AES (Amahi Energy Server) to the latest Amahi* Integration of LDAP as a back-end management system, calendaring* Feature development (examples):* Calendaring, and integrated contact manager application. Possible options: 1) ownCloud based or 2) Apache carddav* For the more design-oriented, build mobile theme(s)* Documentation or screencasts/tutorials* Use sandboxing and containers to improve app stability, updating and more* Improve installation and user onboarding (OOBE)* Better upgrades with backup of apps, settings, etc.* Create a backup and restore function for the Amahi Server (Idea is to backup the of the setting like the shares, paths and Fixed IP address and Mac Address, remove all the data drives) reinstall the OS or Upgrade and then put the data dives back in and then restore all the setting)* make the Amahi front end webpage more mobile-friendly* Add Icon for the install app pages and have more screenshots* make it easier to run multi servers on one network* DHCP page a button to add a device to Fixed IP address will be able to change the fix IP address and the Name or just us the default one* update Button on installed apps this will only work on apps that are updateable, it will run an update script from when the was created, lots of apps nowadays are updated able and would save time uninstalled and reinstalling* Create a page or tab on Amahi front end to be able to add docker container apps select icon and name and address:port
'''Description''': App reliability is critical for Amahi.
'''Objective''': Bring up a CI server (aka "the grinder") up Plus, of course we are open to speedsuggestions. Goal is app reliability being 100%Open a dialog. We have 're happy to discuss and determine a suitable project.
'''Skills Required''': RoRAmahi is a platform that will support the deployment of other open source applications. If you are interested in the integration of applications in your area of interest, just contact us with suggestions.
'''=Mentors''': Carlos=
===Improve App Sandboxing===This is a list of '''committed''' mentors. If you are interested in mentoring, let us know via IRC (mention the nicks below):
'''Description'''* Carlos Puchol (cpg, GSoC admin): Use containers to improve team lead for Amahi, experience in RoR, Go, Ruby, RoR, system scripting/development, app stabilitypackaging, C, C++* Bogdan Mitrea (megabitdragon, GSoC admin): Android, Java, app packaging, system programming,C , C++, community lead* Rod Runyon (bigfoot65): app lead for Amahi, system programming, app packaging, reliability, documentation, support* Chirag Maheshwari, former GSoC student for Amahi* Kumar Shashwat, former GSoC student for Amahi* Sukhbir Singh, former GSoC student for Amahi* Dipankar B. Amahi collaborator* Nitin V., Amahi collaborator
'''Objective''': Use containers like Docker for better app installs an interactions. Some apps may be more suitably installed inside a container because they may be too disruptive in a system.
'''Skills Required'''Reference: [httphttps://dockergoogle.github.io Docker], Vagrant (for testing), ruby, bash, [http:/gsocguides/pdos.csail.mit.edu/mboxmentor/ MboxGSoC mentoring page].
'''Mentor:''': Carlos= Prior Years =
===Ubuntu 14.04===Amahi participated in GSOC in 2020, 2019, 2018, [[Google Summer of Code 2017]] 2016, and [[Google Summer of Code 2014]]
'''Description'''== Prior Ideas (NOT for 2021) ==
'''Objective''': Further development on the Amahi platform to be able to install the same applications and have the same features as the ubuntu based version. A new install CD package that allows you to add Amahi functionality to Ubuntu 14.04 (LTS)=== iOS App Improvements ===
'''Skills RequiredDescription''': rubyAmahi iOS app supports all basic functionalities including browsing files on HDA, ISO creationstreaming audio/video, offline file access but still lacks a lot of features compared to its Android counterpart
'''MentorObjective''': Carlos, FransAddition of new features and improvements in pre-existing ones in iOS app in swift to at least match or surpass the Android app
=Other Ideas='''Things to be implemented''': * Secondary user login* Chromecast support* Metadata display* Continuous music play* Upload and delete functionality* Thumbnail previews
* Integrate a mail server
* Router integration, UPNP, direct control
* Port AES (Amahi Energy Server) to Amahi 7
* Integration of LDAP as a back-end management system, calendaring
* Feature development (examples):
* Calendaring, and integrated contact manager application: possible work-around - owncloud
* For the more design-oriented, build mobile theme(s)
'''Skills Required''': iOS programming, Swift
Plus'''Mentors''': Carlos, of course we are open to suggestions. Open a dialog. We're happy to discuss and determine a suitable project.Chirag
'''Reference''': [https://github.com/amahi/ios Amahi is a platform that will support the deployment of other open source applications. If you are interested in the integration of applications in your area of interest, just contact us with suggestions.iOS app repo]
= Reference =
* [https://www.google-melange.com/gsoc/homepage/google/gsoc2014 GSOC 2014]
* [http://drupal.org/node/59037 Drupal]
* [http://forge.mysql.com/wiki/SummerOfCode/ApplicationTemplate MySQL]
* [http://techbase.kde.org/Projects/Summer_of_Code/2009/Ideas KDE Ideas]
1

edit