Firefox Application Services
Перейти к файлу
Thom Chiovoloni 6657f50ed2
Merge pull request #865 from mozilla/rel0.22.1
Cut release 0.22.1
2019-03-27 12:05:55 -07:00
.circleci Merge pull request #823 from mozilla/build-ios-fixes 2019-03-22 14:10:22 -07:00
.github Note clippy in pr template 2019-03-22 15:22:06 -07:00
automation Download dump_syms from tooltool 2019-03-26 12:40:50 -04:00
build-scripts Don't build iOS as release by default 2019-03-18 09:29:10 -07:00
components Use Weak<PlacesApi> in APIS. Fixes #749 2019-03-26 11:38:31 -07:00
docs Update and document release process for iOS 2019-03-20 14:21:55 -07:00
gradle/wrapper Pre: Update to Gradle 4.10.2 to work around a publishing issue. 2018-11-15 11:20:46 -08:00
gradle-plugin Publish to mozilla-appservices bintray organization, not a personal bintray account. (#843) 2019-03-22 16:21:16 -07:00
libs Integrate tooltool.py to docker image 2019-03-26 12:40:11 -04:00
megazords Per-module Taskcluster tasks 2019-03-20 15:11:07 -04:00
testing/sync-test Add #![allow(unknown_lints)] to all crates 2019-03-20 09:02:54 -07:00
website Update README and split docs into "consumer" and "contributor" docs. 2019-02-05 13:44:48 +11:00
xcconfig Megazord for iOS 2019-02-14 16:37:18 -05:00
.buildconfig-android.yml Cut release 0.22.1 2019-03-27 12:03:08 -07:00
.detekt.yml Suppress detekt failures 2019-03-22 17:22:12 -04:00
.gitignore Update and document release process for iOS 2019-03-20 14:21:55 -07:00
.taskcluster.yml Per-module Taskcluster tasks 2019-03-20 15:11:07 -04:00
CHANGELOG.md Cut release 0.22.1 2019-03-27 12:03:08 -07:00
Cargo.lock chore(deps): Remove text_io dependency in favour of home-grown support crate. 2019-03-26 14:16:20 +11:00
Cargo.toml feat: Add FFI Descriptors and integrate Push Component into Kotlin 2019-03-05 16:29:09 -08:00
Cartfile Use protobuf for fxa_profile return value 2019-02-12 19:09:45 -05:00
LICENSE [license] License application-services repository as MPL2. (Fixes #220) (#233) 2018-09-11 21:28:50 -04:00
README.md Use google docs for editing the component diagram in the README. 2019-03-04 13:42:12 +11:00
build-carthage.sh Fix SQLCipher build options to match Firefox for iOS <=15.x. (#837) 2019-03-22 15:09:20 -07:00
build.gradle Add ktlint gradle task 2019-03-22 17:07:20 -04:00
clippy.toml Document our use of clippy and add a (empty) clippy.toml 2019-03-20 09:02:54 -07:00
gradle.properties Publish all Maven artifacts to a single bintray package. 2019-03-15 16:00:34 -07:00
gradlew [automation/fxa client] Part 1a: Lift Gradle multi-project to top-level. 2018-09-19 11:09:48 -07:00
gradlew.bat [automation/fxa client] Part 1a: Lift Gradle multi-project to top-level. 2018-09-19 11:09:48 -07:00
proguard-rules-consumer-jna.pro Set consumer Proguard rules. 2018-11-27 20:29:10 -08:00
publish.gradle Publish to mozilla-appservices bintray organization, not a personal bintray account. (#843) 2019-03-22 16:21:16 -07:00
settings.gradle Per-module Taskcluster tasks 2019-03-20 15:11:07 -04:00

README.md

Firefox Application Services

A platform for building cloud-powered applications that target Firefox users

What's this all about?

This repository hosts the code and docs needed to integrate with the products offered by the Firefox Application Services team.

If you're interested in getting involved in the development of those products then you're in the right place! Please review the more detailed guide on how to contribute to this project as well as the Community Participation Guidelines.

If that's not why you're here, then instead you might enjoy:

Overview

This repository is used to build client-side libraries for integrating with Firefox Application services such as Firefox Accounts, Firefox Sync and Push. Each of these is called a "component" and is built using a core of shared code writen in Rust, wrapped with native language bindings for different platforms.

The end result is an application that can be assembled from re-usable components that are largely shared across platforms, like this:

component diagram

The code for these components is organized as follows:

For more details on how the client libraries are built and published, please see the Guide to Building a Rust Component.

This repository also hosts the website source for the Application Services Product Portal, which provides consumer-facing documentation on how to integrate with various Application services products.

The ./docs/ directory holds intenal documentation about working with the code in this repository, and is most likely only of interest to contributors.

Components

The currently-available Rust Components in this repo are:

  • fxa-client - for applications that need to sign in with FxA, access encryption keys for sync, and more.
  • sync15 - shared library for accessing data in Firefox Sync
  • logins - for storage and syncing of a user's saved login credentials
  • places - for storage and syncing of a user's saved browsing history
  • push - for applications to receive real-time updates via WebPush
  • rc_log - for connecting component log output to the application's log stream
  • support - low-level utility libraries
    • support/ffi - utilities for building a component's FFI bindings
    • support/sql - utilities for storing data locally with SQL