All Projects → dokugaku-engineer → dokugaku-engineer

dokugaku-engineer / dokugaku-engineer

Licence: other
独学エンジニア

Programming Languages

Vue
7211 projects
PHP
23972 projects - #3 most used programming language
HTML
75241 projects
stylus
462 projects

Projects that are alternatives of or similar to dokugaku-engineer

taller-nuxt
🚀Explicación y código del taller de Nuxt para Wecodefest 2019
Stars: ✭ 20 (-89.13%)
Mutual labels:  nuxt
drf-angular-docker-tutorial
Dockerized Django Back-end API using DRF with Angular Front-end Tutorial
Stars: ✭ 53 (-71.2%)
Mutual labels:  auth0
serve-placeholder
♡ Smart placeholder for missing assets
Stars: ✭ 114 (-38.04%)
Mutual labels:  nuxt
movie-app
App using auth0, netlify functions, + Algolia
Stars: ✭ 39 (-78.8%)
Mutual labels:  auth0
nuxt
Nuxt 3 and Vue 3 client for genealogy project. Family tree and genealogy data processing website software client.
Stars: ✭ 97 (-47.28%)
Mutual labels:  nuxt
vuefes-2018
Vue Fes Japan 2018 の Web サイトのソースコードです。ナレッジ共有のために公開します
Stars: ✭ 39 (-78.8%)
Mutual labels:  nuxt
board
A complete admin board template with a large variety of elements and components, based on blexar CSS framework.
Stars: ✭ 55 (-70.11%)
Mutual labels:  nuxt
Kuberam
Kuberam is built on jetpack compose + Auth0 during Hashnode Hackathon.
Stars: ✭ 33 (-82.07%)
Mutual labels:  auth0
supplebox
Rails×Nuxt製プロテイン口コミ共有サービス「SuppleBox(サプリボックス)」
Stars: ✭ 22 (-88.04%)
Mutual labels:  nuxt
aio-rek
Face recognition based attendance system
Stars: ✭ 19 (-89.67%)
Mutual labels:  nuxt
lunr-module
Full-text search with pre-build indexes for Nuxt.js using lunr.js
Stars: ✭ 45 (-75.54%)
Mutual labels:  nuxt
nuxt-netlifycms-boilerplate
A simple boilerplate for using NetlifyCMS with Nuxt
Stars: ✭ 51 (-72.28%)
Mutual labels:  nuxt
auth0-aspnetcore-mvc-samples
Auth0 Integration Samples for ASP.NET Core MVC Web Applications
Stars: ✭ 120 (-34.78%)
Mutual labels:  auth0
loading-screen
🚥Loading screen for webpack plugin inspired by Nuxt.js's loading screen
Stars: ✭ 56 (-69.57%)
Mutual labels:  nuxt
cypress-nextjs-auth0
Cypress commands to support Auth0 and Next.js
Stars: ✭ 56 (-69.57%)
Mutual labels:  auth0
LaraNuxt
Laravel framework with integrated NuxtJs support, preconfigured for eslint, jest and vuetify.
Stars: ✭ 53 (-71.2%)
Mutual labels:  nuxt
nuxt-spa-store-init
A simple Nuxt module that will hydrate the VueX store when running in SPA mode (not SSR)
Stars: ✭ 14 (-92.39%)
Mutual labels:  nuxt
vue-telescope-extensions
Browser extensions for Vue Telescope
Stars: ✭ 121 (-34.24%)
Mutual labels:  nuxt
website
Jobguy Website
Stars: ✭ 116 (-36.96%)
Mutual labels:  nuxt
nuxt-netlify-cms-starter
🏞 A very spartan starter for using Nuxt.js with Netlify CMS.
Stars: ✭ 67 (-63.59%)
Mutual labels:  nuxt

StyleCI Client CI Api CI

独学エンジニアはプログラミング初学者が自走できるエンジニアになるためのプログラミング学習サービスです。

概要

独学エンジニアはプログラミング初学者のためのオンラインプログラミング学習サービスです。Webベースのアプリケーションで、クライアントサイドはNuxt.jsで、APIはLaravelで書かれています。

目的

独学エンジニアは、プログラミング初学者が自走できるエンジニアになることを目標としています。エンジニアとして就職・転職できるようになるのはもちろん、その後の実務で、未知の課題に出会っても自分で情報収集し解決できる実践的スキルの習得を目指します。

プログラミング学習には本やWebページなど、多くの教材があります。しかし実務で自走できるようになるための情報はまとまっていません。また、実務で実際にあるような課題に取り組む機会もありません。独学エンジニアでは実務で必要なスキルをロードマップとして整備し、また実践的な演習を行うことで、実務レベルのスキルを習得します。

特徴

  • 動画教材の閲覧
  • 動画教材のインポート
  • アカウント情報の管理
  • REST API
  • Auth0を利用したユーザー認証
  • ソーシャルログイン
  • CI/CD

開発するには

アプリケーションの起動

以下のコマンドを実行してアプリケーションを起動します。

# 環境変数の設定
cp docker/db/db-variables.development.env docker/db/db-variables.env
cp api/.env.dev api/.env
cp client/.env.dev client/.env

# Dockerの起動
docker-compose up -d --build

# APIに必要なライブラリをインストール
docker-compose exec api composer install

# Clientに必要なライブラリをインストール
docker-compose exec client npm install --no-optional

# データベースのマイグレーション
docker-compose exec api php artisan migrate

# レクチャー関連のデータのインポート
docker-compose exec api php artisan import:lecture-csv

これでサイトにアクセスできます。

http://localhost:3333/

ユーザー認証の設定

Auth0を利用してユーザー認証を管理しています。開発にあたって、Auht0の登録、設定を行います。

1. Auth0のアカウントの開設

Auth0にサインアップします。

2. テナントの作成

Create tenant をクリックし、テナントを作成します。

  • Tenant Domain:任意の名前
  • Region:US

3. 言語の設定

Settings > General をクリックし、言語を設定します。

  • Default Language で Japanese(ja) を選択
  • Supported Languages で Japanese(ja), English(en) をチェック

4. APIの作成

APIs > CREATE API をクリックし、APIを作成します。

5. アプリケーションの作成

Applications > CREATE APPLICATION をクリックし、アプリケーションを作成します。

  • Name:Dokugaku Engineer
  • application type:Single Page Web Applications

Applications > Dokugaku Engineer > Settings をクリックし、アプリケーションの設定を行います。

6. ルールの作成

トークンのスコープを検証するルールを作成します。Rules > CREATE RULE > Empty rule をクリックします。

  • Name:Access Token Scopes
  • Script:Auth0/rules/access_token_scopes.js のコードを貼り付ける

ユーザーデータをトークンに追加するルールを作成します。Rules > CREATE RULE > Empty rule をクリックします。

  • Name:Add user data to tokens
  • Script:Auth0/rules/add_userdata_to_tokens.js のコードを貼り付ける

7. ソーシャルコネクトの対応

Connections > Social をクリックする。 Googleのチェックを外し、GitHubとTwitterをチェックする。

GitHubとTwitterの設定についてはAuth0のドキュメントを参考にする。

8. ユニバーサルログインの使用

Universal Login > Settings をクリックして、新ユニバーサルログインページを使用するように設定する。

  • Experience:New

9. 環境変数の設定

api/.env に下記を設定する。

AUTH0_AUDIENCE=http://localhost:3333/api
AUTH0_DOMAIN=${テナント名}.auth0.com
AUTH0_MANAGEMENT_API_AUDIENCE=${Auth0 Management APIのIdentifier}
AUTH0_MANAGEMENT_API_CLIENT_ID=${Auth0 Management APIがAUTHORIZEDしているApplicationのClient ID}
AUTH0_MANAGEMENT_API_CLIENT_SECRET=${Auth0 Management APIがAUTHORIZEDしているApplicationのClient Secret}
}
AUTH0_NAMESPACE=https://dokugaku-engineer.com/

client/.env に下記を設定する。

AUTH0_AUDIENCE=http://localhost:3333/api
AUTH0_CLIENT_ID=${作成したApplicatiopnのClient ID}
AUTH0_DOMAIN=${テナント名}.auth0.com
AUTH0_MANAGEMENT_API_AUDIENCE=${Auth0 Management APIのIdentifier}
AUTH0_MANAGEMENT_API_CLIENT_ID=${Auth0 Management APIがAUTHORIZEDしているApplicationのClient ID}
AUTH0_MANAGEMENT_API_CLIENT_SECRET=${Auth0 Management APIがAUTHORIZEDしているApplicationのClient Secret}
AUTH0_NAMESPACE=https://dokugaku-engineer.com/

Mission, Vision, Value

Mission

  • 本気でキャリアを変えたい人の力になる

Vision

  • プログラミング初学者が実務で自走できるエンジニアになれる道を整備する

Value

  • 高品質な教材のみを提供しよう
  • 人の可能性を信じよう

なぜオープンソースなのか

プログラミングを習得する上で、実際に運用しているWebサービスのソースコードを読むことは大変勉強になります。一方で、運用しているWebサービスのソースコードは公開してないものが多く、プログラミング初学者が参考にしやすいものは少ないです。そこで独学エンジニアではソースコードを公開し、プログラミング初学者が実際に運用中のWebサービスのソースコードに触れる機会を提供することで、プログラミング初学者の学習の参考になればと願っています。

また、オープンソースにすることで多くの開発者の力でサービスをより良いものにしていければと思っています。プログラミング初学者がオープンソースにコミットするきっかけになることも期待しています。

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].