From Fedora Project Wiki
No edit summary
m (Add {{autolang}})
 
(23 intermediate revisions by 6 users not shown)
Line 1: Line 1:
= Introduction =
{{autolang}}


Fedora Developer Portal would be a new place for developers, providing information about tools, technology and other features that are packaged in Fedora. It would raise awareness about new and existing projects among users.
= Fedora Developer Portal =
[https://fedoraproject.org/wiki/Websites/Developer Project Page]  |  [https://github.com/developer-portal/content '''Content Repository''']  |  [https://github.com/developer-portal/website '''Website Repository''']


= Why is this project needed? =
== About The Project ==
I may be a student choosing the best Linux distribution or even the best platform for my development. I also might be a current user of Fedora looking for new developer features I don't know about. I'm not looking for documentation about some particular tool or technology. There are plenty of those resources on the internet already. Let's say that I'm more discovering the possibilities that are out there. Are there any great developer tools? What technology should I use? How can I distribute my program or deploy the service I create?
'''Fedora Developer Portal''' is a place for developers. Providing information about tools, technology and other features that are packaged in Fedora. It aims to raise awareness about new and existing projects among users.
 
== Target Audience ==
The target audience are developers working on Fedora.
Specifically: developers '''building on''' Fedora; not '''contributing to''' Fedora.
 
They might be either:
#  '''Newcomers''':  Either choosing their Linux distribution or looking for information about how to start developing. Also searching recommendations.
#  '''Existing Fedora Developers''':  Discovering what else Fedora offers and learning how to use it.
#  '''Existing Developers''':  Learning about how to use their existing open source toolsets on Fedora.
 
Targeting on developers using Mac or even Windows and deploying to Fedora/CentOS might be considered for later iterations.
 
== Main Purpose ==
The site would help developers to:
# '''Explore''': What tools and tech Fedora offers? (DevAssistant, Vagrant, Python, Ruby, ...)
# '''Build''': How to use this tech? How it is packaged in Fedora?  
# '''Deploy''': Which deployment technology should I use? (Copr, Nulecule, xdg-app, Software Collections, OpenShift ...)
 
 
= Project Resources =
== Testing instance ==
Testing instance of the portal - http://developer.fedorainfracloud.org
 
== Repositories ==
* Content Repo - https://github.com/developer-portal/content
* Website Repo - https://github.com/developer-portal/website
* Design Mockups Repo - https://github.com/developer-portal/mockups
 
== Communication ==
* #developer-portal at FreeNode - http://webchat.freenode.net/?channels=#developer-portal
* Fedora Devel Mailing List - https://lists.fedoraproject.org/mailman/listinfo/devel
 
== Project Tracking ==
* Tasks + Issue Tracking: part of GitHub repositories mentioned above


The Fedora Developer Portal would give me those insights and point me to the particular project/tool/technology I might be looking for. It would provide a description, links to other resources, information about how it's packaged in Fedora, guides, videos, blog posts, ... there are plenty of possibilities what we can include.
= Content =
= Content =
== Structure ==
== Home Page ==
The main categories could be something like these:
The homepage need to explain clearly what is it all about and how/why you would use it. It would also show the main features from current release.
# Development tools:
 
#* Vagrant, Developer Assistant, ...
== Start ==
#* Which tools to use for development and how they can help me
Guides on "How to start a new project" starting from the problem-to-be-solved perspective and guiding developers trough possible options.
#* explain WHAT the project is and HOW to get it running
 
# Languages, technologies, runtimnes:
'''Pages:'''
#* Python, Ruby, Rails, Perl, ...
#Application:
#* Info about packages, the "I am a _ developer" view
#* Web application
#* explain WHAT the project is and HOW to get it running
#* Command line application
# Distribution/deployment:
#* Desktop GUI application
#* Copr, Docker, Openshift, ...
#* Mobile application
#* How to get my project to people?
#Hardware:
#* explain WHAT the project is and HOW to get it running
#* Raspberry Pi
# Docker images, Vagrant boxes, ...
#* Arduino devices
# Blogs
#* Other embedded devices
#Tips:
#* Provide online documentation
#* Collaborate effectively
 
== Tools ==
Show what tools are available in Fedora, how they can help developers and some example use-cases.


== Examples ==
'''Pages:'''
=== Ruby ===
* Docker
* Installation (both RPM and upstream)
* Vagrant
* Explain them why we have ruby-mri bin and why we use rubypick
* Answers to how our Ruby differs from upstream
* Let users know we have a lot or RubyGems packaged
* Show them our https://github.com/zuhao/isitfedoraruby
* Let them know there is something like Fedora Ruby SIG that they can join


=== Vagrant ===
=== An example: Vagrant page structure ===
* how to get packaged Vagrant
* how to get packaged Vagrant
* providers
* providers
Line 44: Line 78:
* Fedora Vagrant boxes (links)
* Fedora Vagrant boxes (links)


=== "I am a Ruby developer" view ===
== Technology ==
* combination/listing of pages we have and are relevant
Mostly language/framework-specific guides about how to install it on Fedora, what is different in Fedora (if), what might be the best practise.
* Ruby, Rails, Vagrant, docker, DevAssistant would show up
 
Each language section should include a link to a DevAssistant Assistant with hello world.
 
'''Pages:'''
#Languages:
#* Python
#* Ruby
#* PHP
#* Perl
#* GO
#* C and C++
#* Node.js
#* Java
#Database:
#* PostgreSQL
#* MariaDB
#* Sqlite
 
=== An example: Ruby page structure ===
See the Ruby page in the prototype: http://developer.fedorainfracloud.org/tech/languages/ruby/ruby-installation.html
* Installation (both RPM and upstream)
* Explain them why we have ruby-mri bin and why we use rubypick
* Answers to how our Ruby differs from upstream
* Let users know we have a lot or RubyGems packaged
* Show them our https://github.com/zuhao/isitfedoraruby
* Let them know there is something like Fedora Ruby SIG that they can join
* 'I am a Ruby dev subpage':
** combination/listing of pages we have and are relevant
** Ruby, Rails, Vagrant, docker, DevAssistant would show up
 
== Deployment ==
Ways of deploying a service or distributing an app to the end users. A guide that would recommend the best option for a particular app type.
 
Could also include a flowchart of 1) identify app type 2) identify pkg type 3) pkg ....
 
'''Pages:'''
* Copr (Custom RPM repositories)
* Software Collections (decoupling update cycles from host OS)
* Nulecule (multi-container network services)
* xdg-app (containers for desktop applications)
* Rolekit (package installation & configuration flows)
* OpenShift (autoscaling network application hosting)
 
== Resources ==
Docker images and Vagrant boxes to download.


= Possible Implementation =
== Blogs ==
We would like to store the content on GitHub and use all it's features like forks, pull requests and easy collaboration. The individual pages could be written in markdown. The website would be consisting of static pages generated from the git repository.
Aggregation of interesting developer blogs.

Latest revision as of 23:08, 12 September 2019

Fedora Developer Portal

Project Page | Content Repository | Website Repository

About The Project

Fedora Developer Portal is a place for developers. Providing information about tools, technology and other features that are packaged in Fedora. It aims to raise awareness about new and existing projects among users.

Target Audience

The target audience are developers working on Fedora. Specifically: developers building on Fedora; not contributing to Fedora.

They might be either:

  1. Newcomers: Either choosing their Linux distribution or looking for information about how to start developing. Also searching recommendations.
  2. Existing Fedora Developers: Discovering what else Fedora offers and learning how to use it.
  3. Existing Developers: Learning about how to use their existing open source toolsets on Fedora.

Targeting on developers using Mac or even Windows and deploying to Fedora/CentOS might be considered for later iterations.

Main Purpose

The site would help developers to:

  1. Explore: What tools and tech Fedora offers? (DevAssistant, Vagrant, Python, Ruby, ...)
  2. Build: How to use this tech? How it is packaged in Fedora?
  3. Deploy: Which deployment technology should I use? (Copr, Nulecule, xdg-app, Software Collections, OpenShift ...)


Project Resources

Testing instance

Testing instance of the portal - http://developer.fedorainfracloud.org

Repositories

Communication

Project Tracking

  • Tasks + Issue Tracking: part of GitHub repositories mentioned above

Content

Home Page

The homepage need to explain clearly what is it all about and how/why you would use it. It would also show the main features from current release.

Start

Guides on "How to start a new project" starting from the problem-to-be-solved perspective and guiding developers trough possible options.

Pages:

  1. Application:
    • Web application
    • Command line application
    • Desktop GUI application
    • Mobile application
  2. Hardware:
    • Raspberry Pi
    • Arduino devices
    • Other embedded devices
  3. Tips:
    • Provide online documentation
    • Collaborate effectively

Tools

Show what tools are available in Fedora, how they can help developers and some example use-cases.

Pages:

  • Docker
  • Vagrant

An example: Vagrant page structure

  • how to get packaged Vagrant
  • providers
    • libvirt
    • how to run libvirt with vagrant without sudo
  • list of plugins we maintain
  • troubleshooting, how to report problems
  • Fedora Vagrant boxes (links)

Technology

Mostly language/framework-specific guides about how to install it on Fedora, what is different in Fedora (if), what might be the best practise.

Each language section should include a link to a DevAssistant Assistant with hello world.

Pages:

  1. Languages:
    • Python
    • Ruby
    • PHP
    • Perl
    • GO
    • C and C++
    • Node.js
    • Java
  2. Database:
    • PostgreSQL
    • MariaDB
    • Sqlite

An example: Ruby page structure

See the Ruby page in the prototype: http://developer.fedorainfracloud.org/tech/languages/ruby/ruby-installation.html

  • Installation (both RPM and upstream)
  • Explain them why we have ruby-mri bin and why we use rubypick
  • Answers to how our Ruby differs from upstream
  • Let users know we have a lot or RubyGems packaged
  • Show them our https://github.com/zuhao/isitfedoraruby
  • Let them know there is something like Fedora Ruby SIG that they can join
  • 'I am a Ruby dev subpage':
    • combination/listing of pages we have and are relevant
    • Ruby, Rails, Vagrant, docker, DevAssistant would show up

Deployment

Ways of deploying a service or distributing an app to the end users. A guide that would recommend the best option for a particular app type.

Could also include a flowchart of 1) identify app type 2) identify pkg type 3) pkg ....

Pages:

  • Copr (Custom RPM repositories)
  • Software Collections (decoupling update cycles from host OS)
  • Nulecule (multi-container network services)
  • xdg-app (containers for desktop applications)
  • Rolekit (package installation & configuration flows)
  • OpenShift (autoscaling network application hosting)

Resources

Docker images and Vagrant boxes to download.

Blogs

Aggregation of interesting developer blogs.